Могу ли я вставить a.png изображение в html-страницу?

Как я могу вставить .png файл в пустой " файл.html " так что, когда вы открываете этот файл в любом браузере, вы видите это изображение? В этом случае файл изображения не связан с HTML, а данные изображения встроены в самом HTML.

5 ответов


есть несколько кодеров base64 онлайн, чтобы помочь вам в этом, это, вероятно, лучшее, что я видел:

http://www.greywyvern.com/code/php/binary2base64

поскольку эта страница показывает ваши основные параметры для этого CSS:

div.image {
  width:100px;
  height:100px;
  background-image:url(data:image/png;base64,iVBORwA<MoreBase64SringHere>); 
}

или <img> сам тег, вот так:

<img alt="My Image" src="data:image/png;base64,iVBORwA<MoreBase64SringHere>" />

метод 64base работает и для больших изображений, я использую этот метод для встраивания всех изображений в свой сайт, и он работает каждый раз. Я закончил с файлами до 2 Мб размер, jpg и png.


Я не знаю, как долго этот пост был здесь. Но теперь я столкнулся с подобной проблемой. Следовательно, публикация решения, чтобы оно могло помочь другим.

#!/usr/bin/env perl
use strict;
use warnings;
use utf8;

use GD::Graph::pie;
use MIME::Base64;
my @data = (['A','O','S','I'],[3,16,12,47]);

my $mygraph = GD::Graph::pie->new(200, 200);
my $myimage = $mygraph->plot(\@data)->png;

print <<end_html;
<html><head><title>Current Stats</title></head>
<body>
<p align="center">
<img src="data:image/png;base64,
end_html

print encode_base64($myimage);

print <<end_html;
" style="width: 888px; height: 598px; border-width: 2px; border-style: solid;" /></p>
</body>
</html>

end_html

быстрый поиск google говорит, что вы можете встроить его так:

<img src="data:image/gif;base64,R0lGODlhEAAOALMAAOazToeHh0tLS/7LZv/0jvb29t/f3//Ub/
/ge8WSLf/rhf/3kdbW1mxsbP//mf///yH5BAAAAAAALAAAAAAQAA4AAARe8L1Ekyky67QZ1hLnjM5UUde0ECwLJoExKcpp
V0aCcGCmTIHEIUEqjgaORCMxIC6e0CcguWw6aFjsVMkkIr7g77ZKPJjPZqIyd7sJAgVGoEGv2xsBxqNgYPj/gAwXEQA7" 
width="16" height="14" alt="embedded folder icon">

но вам нужна другая реализация в Internet Explorer.

http://www.websiteoptimization.com/speed/tweak/inline-images/


использовать mod_rewrite для перенаправления вызова в файл.html к изображению.png без изменения url-адреса для пользователя

вы пытались просто переименовать изображение.png файл в файл.HTML-код? Я думаю, что большинство браузеров берут заголовок mime над расширением файла:)