Heim >Datenbank >MySQL-Tutorial >Wie zeige ich Bild-BLOBs von MySQL in PHP korrekt an?

Wie zeige ich Bild-BLOBs von MySQL in PHP korrekt an?

Barbara Streisand
Barbara StreisandOriginal
2024-12-14 12:47:14595Durchsuche

How to Correctly Display Image BLOBs from MySQL in PHP?

PHP zeigt Bild-BLOB von MySQL an

Beim Versuch, ein in einer MySQL-BLOB-Spalte gespeichertes Bild anzuzeigen, stoßen einige Benutzer auf Probleme, bei denen Chrome oder IE zeigt ein Bildsymbol anstelle des eigentlichen Bildes an. Dies kann an der fehlenden richtigen Kodierung und Handhabung der binären Bilddaten liegen.

Lösung

Die korrekte Art und Weise, ein Bild-BLOB in PHP anzuzeigen, umfasst:

  • Vorbereitung der Daten:

    • Rufen Sie die Bilddaten mithilfe einer Abfrage aus der MySQL-Datenbank ab (z. B. SELECT * FROM products WHERE id = ?).
    • Speichern Sie die abgerufenen Bilddaten in eine Variable (z. B. $image).
  • Codieren der Binärdaten:

    • Verwenden Sie die Funktion base64_encode(), um das Binärbild zu konvertieren Daten in einen Base64-codierten String. Dieser Schritt ist notwendig, um die Binärdaten in ein Format zu kodieren, das für die Anzeige als Bild geeignet ist.
  • Anzeigen des Bildes:

    • Legen Sie den entsprechenden HTTP-Header fest, um den Bildtyp anzugeben (z. B. image/jpeg).
    • Geben Sie das aus base64-kodierte Bilddaten als Bildquelle. Zum Beispiel:
    header("Content-Type: image/jpeg");
    echo '<img src="data:image/jpeg;base64,' . base64_encode($image) . '" />';

Hinweis: Stellen Sie sicher, dass die aus der Datenbank abgerufenen Bilddaten gültig sind und dass vor oder keine nachgestellten Leerzeichen stehen nach dem Tags.

Das obige ist der detaillierte Inhalt vonWie zeige ich Bild-BLOBs von MySQL in PHP korrekt an?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn