Base64 Encoding Image
Asked Answered
A

5

65

I am building an open search add-on for Firefox/IE and the image needs to be Base64 Encoded so how can I base 64 encode the favicon I have?

I am only familiar with PHP

Archerfish answered 30/8, 2008 at 11:1 Comment(0)
W
81

As far as I remember there is an xml element for the image data. You can use this website to encode a file (use the upload field). Then just copy and paste the data to the XML element.

You could also use PHP to do this like so:

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

Use Mozilla's guide for help on creating OpenSearch plugins. For example, the icon element is used like this:

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

Where imageData is your base64 data.

Wandie answered 30/8, 2008 at 11:20 Comment(4)
base64_encode in this case will only encode the image's "resource handle", I believe, if anything at all. You would need to read in the file's actual contents. Just using that base64 encoder website should work, though.Scholz
This doesn't work at all for me. $im is a resource and I'm getting an error base64_encode() expects parameter 1 to be string, resource givenFennelflower
The above comments were referring to a previous edit, hakre fixed my mistake. @stevether this should now work.Wandie
<img src="" width="16" height="16">Where imageData is your base64 data worked to show it for me, I am in ChromeRegulation
R
14
$encoded_data = base64_encode(file_get_contents('path-to-your-image.jpg'));    
Rube answered 16/3, 2012 at 17:53 Comment(1)
@davidcorda - Brevity is acceptable, but fuller explanations are better. stackoverflow.com/questions/how-to-answerKoah
B
9

My synopsis of rfc2397 is:

Once you've got your base64 encoded image data put it inside the <Image></Image> tags prefixed with "data:{mimetype};base64," this is similar to the prefixing done in the parenthesis of url() definition in CSS or in the quoted value of the src attribute of the img tag in [X]HTML. You can test the data url in firefox by putting the 


Barvick answered 25/11, 2008 at 19:43 Comment(0)
Y
6

Check the following example:

// First get your image
$imgPath = 'path-to-your-picture/image.jpg';
$img = base64_encode(file_get_contents($imgPath));
echo '<img width="100" height="100" src="data:image/jpg;base64,'. $img .'" />'
Yolandayolande answered 3/9, 2015 at 10:7 Comment(0)
G
0

Google led me to this solution (base64_encode). Hope this helps!

Goodish answered 30/8, 2008 at 11:6 Comment(1)
yes I know how to encode it but how to get just the image data in there for it to be encoded.Archerfish

© 2022 - 2024 — McMap. All rights reserved.