2008-08-30 8 views
52

Ich baue ein offenes Such-Add-on für Firefox/IE und das Image muss Base64-codiert werden, also wie kann ich Base 64 codieren das Favicon, das ich habe?Base64 Encoding Image

Ich bin nur vertraut mit PHP

Antwort

74

Soweit ich mich erinnere, gibt es ein XML-Element für die Bilddaten. Sie können diese website verwenden, um eine Datei zu verschlüsseln (verwenden Sie das Upload-Feld). Kopieren Sie dann die Daten und fügen Sie sie in das XML-Element ein.

Sie könnten auch PHP, dies zu tun, wie so:

<?php 
     $im = file_get_contents('filename.gif'); 
     $imdata = base64_encode($im);  
?> 

Verwenden Mozilla's guide Hilfe zur Plugins OpenSearch- zu schaffen. Zum Beispiel wird das Symbol Element wie folgt verwendet:

<img width="16" height="16"></> 

Wo imageData sind Ihre base64-Daten.

+1

base64_encode in diesem Fall wird nur das "Resource Handle" des Bildes, glaube ich, wenn überhaupt, kodieren. Sie müssten den tatsächlichen Inhalt der Datei einlesen. Die Verwendung der base64-Encoder-Website sollte jedoch funktionieren. –

+1

Dies funktioniert überhaupt nicht für mich. '$ im' ist eine 'Ressource' und ich erhalte einen Fehler 'base64_encode() erwartet, dass Parameter 1 eine Zeichenfolge ist, Ressource gegeben' –

+2

Die obigen Kommentare beziehen sich auf eine vorherige Bearbeitung, hakre hat meinen Fehler behoben. @stevether das sollte jetzt funktionieren. – Ross

0

Google me (base64_encode) zu this Lösung geführt. Hoffe das hilft!

+1

ja, ich weiß, wie es zu kodieren, sondern, wie es nur die Bilddaten in dorthin zu gelangen codiert werden. – UnkwnTech

8

Meine Synopse rfc2397 ist:

Sobald Sie Ihre Base64-codierte Bilddaten es ausdrückte in den < Bild> </Bild> -Tags mit dem Präfix „data:{mimetype};base64,“ haben dies auf die Vorfixierung in der getan ähnlich ist Klammer von url() Definition in CSS oder in dem angegebenen Wert des src Attributs des Tags img in [X] HTML. Sie können die Daten-URL in Firefox testen, indem Sie die Zeile  

 
10
$encoded_data = base64_encode(file_get_contents('path-to-your-image.jpg'));  
+4

@davidcorda - Die Kürze ist akzeptabel, aber vollere Erklärungen sind besser. http://stackoverflow.com/questions/how-to-answer – Michal

6

überprüfen Sie das folgende Beispiel

<?php 
    // First get your image 
    $image = 'path-to-your-picture/image.jpg'; 
    $picture = base64_encode(file_get_contents($image)); 
    echo '<img width="100" height="100" src="data:image/jpg;base64,'. $picture .'" />' 
    ?>