Problem bei der Generierung von thumbnails mit gd

Einklappen
X
 
  • Filter
  • Zeit
  • Anzeigen
Alles löschen
neue Beiträge

  • Problem bei der Generierung von thumbnails mit gd

    Hallo Forum,

    Ich lade Fotos auf meinen webspace und generiere nebenbei verkleinerte Ansichten.

    Dafür benutze ich folgende Funktion:
    PHP-Code:
    function thumbnail($bild=''$bilder_path_originalbild=''$bilder_path_thumbnail=''$thumbnail_neuebreite ){
            
    $sizegetimagesize($bilder_path_originalbild.$bild) OR die('Es konnte keine Bildgröße ermittelt werden.'); 
            
    $breite=$size[0]; 
            
    $hoehe=$size[1]; 
            
    $neuebreite=$thumbnail_neuebreite;
            
    $neuehoeheintval($hoehe*$neuebreite/$breite);
            if(
    $size[2]==2) { 
            
    // JPG 
                
    $altesbildimagecreatefromjpeg($bilder_path_originalbild.$bild) or die ("Fehler in imagecreatefromjpeg()\n");
                
    $neuesbildimagecreatetruecolor($neuebreite,$neuehoehe) or die ("Fehler in imagecreatetruecolor()\n");
                
    $bool imagecopyresampled($neuesbild,$altesbild,0,0,0,0,$neuebreite,$neuehoehe,$breite,$hoehe) or die("Fehler in imagecopyresampled()\n"); 
                
    $ret imagejpeg($neuesbild,$bilder_path_thumbnail.$thumbnail_neuebreite."_".$bild) or die("Fehler in imagejpeg()\n");
            } 
            return 
    $size[2];
        } 
    In den meisten Fällen läuft das einfach durch und ich habe die gewünschte Datei im Zielverzeichnis und die verkleinerte Voransichtsgrafik in deren Zielverzeichnis.
    Regelmäßig funktioniert dieser Vorgang aber nicht; der Upload funktioniert, aber die Erzeugung der verkleinerten Ansicht scheitert.
    Eine Fehlermeldung aus den die() Aufrufen erhalte ich nicht.
    Die aufrufende php Datei wird nicht weiter abgearbeitet; wo beim normalen Ablauf das Eingabeformular wieder angezeigt wird, geschieht dann einfach gar nix mehr.

    Hat jemand einen Tipp, wie ich die Ursache für dieses Fehlverhalten feststellen könnte?
    Hier noch ein paar Infos von phpinfo():
    PHP Version 4.4.9
    GD Version bundled (2.0.28 compatible)
    post_max_size 12M
    upload_max_filesize 12M

    Danke für jede Hilfe schon mal im Voraus,

    /Thomas

  • #2
    error_reporting(E_ALL)?

    Kommentar


    • #3
      macht keinen Unterschied...

      Kommentar


      • #4
        bist du sicher, dass die Datein auch hochgeladen werden? Kannst du einschränken um was für Dateien es sich handelt? Große, kleine, Auflösung?!
        Wie wird die FUnktion aufgerufen?

        Kommentar


        • #5
          Ja, die Dateien sind nachher im Zielverzeichnis, nur bei manchen findet die Erzeugung der thumbnails und der Eintrag in die Datenbank einfach nicht statt.
          Ich habe schon alles untersucht- ich komme auf keinen Unterschied zwischen den Dateien wo es klappt und wo es nicht klappt.
          Hier kommt der Funktionsaufruf:
          PHP-Code:
          if($_FILES['thefile']['size'] <= $groessemax*1024){
              if(
          decoct(fileperms($uploaddir))==40777){
                  if(@
          copy($temp$uploaddir.$filename)){ 
                      echo 
          '<span class="status">Datei ist hochgeladen!<br>'
                          } else {
                      echo 
          '<span class="status">Die Datei konnte nicht auf den Server geladen werden. <a href="'.$_SERVER['PHP_SELF'].'">Noch mal versuchen...</a><br><br></span>';
                      }
                  } else {
                      echo 
          '<div style="color:red;">Keine Schreibberechtigung im Uploadordner! <a href="'.$_SERVER['PHP_SELF'].'">Noch mal versuchen...</a><br><br></div>';
              }

              if (
          $img_type == 'image/jpeg') { 
                  
          $img_typ thumbnail($filename$img_path_up$bilder_path_thumbnail$thumbnail_breite );
              }else {
                  echo 
          "<p class=\"status\">Fehler beim Resample/ Resize!</p>";
              }
            } 
          Danach wir normalerweise der Datenbankeintrag gemacht, aber der findet dann- wie gesagt- nicht statt.

          Kommentar


          • #6
            Darf ich vorstellen: is_uploaded_file(), move_uploaded_file().

            Woher kommt $img_type? Prüfe mal, ob die thumbnail-Funktion überhaupt immer aufgerufen wird. Läuft sie auch immer bis zum Ende durch? Was wird zurückgegeben (var_dump())?

            Kommentar


            • #7
              Hallo und moin,

              >>...woher kommt $img_type?
              [...]
              $img_type = $_FILES['thefile']['type'];
              [...]

              Habe jetzt in die Funktion thumbnail() Aufrufe von var_dump() eingeschoben. Sie wird aufgerufen, aber läuft nicht jedesmal durch.
              Der Schuldige scheint imagecreatetruecolor() zu sein. Nach diesem Funktionsaufruf kommt nichts mehr zurück.

              Mmmh...

              /T

              Kommentar


              • #8
                Das kann eigentlich nicht sein. Bei richtig eingestelltem error reporting gibt es sowas nicht, dass eine built-in Funktion gerufen wird und nicht zurückkehrt. Dann gibt es zumindest eine Fehlermeldung. Ich tippe mal auf "could not allocate ..." wegen memory_limit.

                Kommentar


                • #9
                  PHP-Code:
                  $neuehoeheintval($hoehe*$neuebreite/$breite); 
                  müsste imho
                  PHP-Code:
                  $neuehoeheintval($hoehe*($neuebreite/$breite)); 
                  heißen, da andernfalls die *-Operation zuerst ausgeführt wird.
                  Nur wenige wissen, wieviel man wissen muss, um zu wissen, wie wenig man weiß.

                  Kommentar


                  • #10
                    (...) müsste imho (...) heißen, da andernfalls die *-Operation zuerst ausgeführt wird.
                    Nö, einfachstes Bruchrechnen!

                    Kommentar


                    • #11
                      Hier nochmal der problematische Teil der Funktion thumbnail(), diesmal mit den eingefügten debugging Aufrufen:
                      PHP-Code:
                      $sizegetimagesize($bilder_path_originalbild.$bild) OR die('Es konnte keine Bildgröße ermittelt werden.');
                      var_dump($size);
                      if(
                      $size[2]==2) { 
                              
                      // JPG 
                                  
                      $altesbildimagecreatefromjpeg($bilder_path_originalbild.$bild) or die ("Fehler in imagecreatefromjpeg()\n");
                                  echo 
                      "altesbild: ";
                                  
                      var_dump($altesbild); 
                                  echo 
                      "<br>";
                                  
                      $neuesbildimagecreatetruecolor($neuebreite,$neuehoehe) or die ("Fehler in imagecreatetruecolor()\n");
                                  echo 
                      "neuesbild: ";
                                  
                      var_dump($neuesbild); 
                                  echo 
                      "<br>";
                                  
                      $bool imagecopyresampled($neuesbild,$altesbild,0,0,0,0,$neuebreite,$neuehoehe,$breite,$hoehe) or die("Fehler in imagecopyresampled()\n"); 
                                  echo 
                      "altesbild: ";
                                  
                      var_dump($bool); 
                                  echo 
                      "<br>";
                                  
                      $ret imagejpeg($neuesbild,$bilder_path_thumbnail.$thumbnail_neuebreite."_".$bild) or die("Fehler in imagejpeg()\n");
                                  
                      var_dump($ret); 
                              } 
                      Als Ausgabe erhalte ich:
                      [...]
                      array(7) {
                      [0]=>
                      int(1416)
                      [1]=>
                      int(2136)
                      [2]=>
                      int(2)
                      [3]=>
                      string(26) "width="1416" height="2136""
                      ["bits"]=>
                      int(8)
                      ["channels"]=>
                      int(3)
                      ["mime"]=>
                      string(10) "image/jpeg"
                      }
                      altesbild: resource(6) of type (gd)
                      <br>
                      [und hier ist Ende der Ausgabe]

                      Diese Zeile steht am Anfang des scripts:
                      error_reporting(E_ALL);

                      Noch jemand eine Idee? Ich muss zugeben, ich bin ratlos...

                      /T
                      Zuletzt geändert von tbesand; 09.12.2008, 18:37.

                      Kommentar


                      • #12
                        Das hier ist ein Bild, was einwandfrei durchlief:
                        http://falklund.de/pic/1075-2008.jpg_1228504926.jpg
                        hier die dazugehörige verkleinerte Ansicht:
                        http://falklund.de/ico/500_1075-2008.jpg_1228504926.jpg

                        und hier ein Beispiel für ein Bild, was nicht durchlief:
                        http://falklund.de/pic/0853-2007.jpg_1228504350.jpg

                        d.h. davon gibt es auch keine verkleinerte Version ;-(

                        Kommentar


                        • #13
                          mmmhh, keiner mehr eine weiterführende Idee?

                          too bad,

                          /T

                          Kommentar


                          • #14
                            Original geschrieben von tbesand
                            Hier nochmal der problematische Teil der Funktion thumbnail(), diesmal mit den eingefügten debugging Aufrufen:
                            PHP-Code:
                            $neuesbild= @imagecreatetruecolor($neuebreite,$neuehoehe) or die ("Fehler in imagecreatetruecolor()\n"); 
                            Hallo,

                            entferne mal das @ vor imagecreatetruecolor(), dann ist die Wahrscheinlichkeit von der Anzeige einer Fehlermeldung höher


                            vg
                            gourmet

                            Kommentar


                            • #15
                              Hi gourmet,

                              danke für den Tipp, aber das ändert auch nichts am Ablauf.
                              Das script steigt nach wie vor einfach aus, wie oben beschrieben.
                              Schon deprimierend- und onemorenerd schreibt noch:
                              Das kann eigentlich nicht sein. Bei richtig eingestelltem error reporting gibt es sowas nicht, dass eine built-in Funktion gerufen wird und nicht zurückkehrt. Dann gibt es zumindest eine Fehlermeldung. Ich tippe mal auf "could not allocate ..." wegen memory_limit.
                              Was kann ich tun, wenn das aber doch so ist ;-)

                              PS: "could not allocate" wg. memory_limit bei einem Bild von max. 3,5 MB? Klingt das wahrscheinlich?

                              vg
                              /T
                              Zuletzt geändert von tbesand; 09.12.2008, 14:20.

                              Kommentar

                              Lädt...
                              X