Как отобразить изображения Base64 в HTML?

У меня возникли проблемы с отображением встроенного изображения Base64.

может кто-нибудь указать мне в правильном направлении?

<!DOCTYPE html>
<html>
  <head>
    <title>Display Image</title>
  </head>
  <body>
    <img style='display:block; width:100px;height:100px;' id='base64image'                 
       src='data:image/jpeg;base64, LzlqLzRBQ...<!-- base64 data -->' />
  </body>
</html>

10 ответов


мой подозреваемый, конечно, фактические данные base64, иначе это выглядит хорошо для меня. См.эта скрипка где работает аналогичная схема. Вы можете попробовать указать набор символов.

<div>
    <p>Taken from wikpedia</p>
    <img src="data:image/png;base64, iVBORw0KGgoAAAANSUhEUgAAAAUA
AAAFCAYAAACNbyblAAAAHElEQVQI12P4//8/w38GIAXDIBKE0DHxgljNBAAO
    9TXL0Y4OHwAAAABJRU5ErkJggg==" alt="Red dot" />
</div> 

вы можете попробовать этот декодер base64 чтобы узнать, верны ли ваши данные base64 или нет.


вам нужно указать правильный тип контента, кодировку контента и кодировку как

 data:image/jpeg;charset=utf-8;base64, 

в соответствии с синтаксисом схема URI данных:

 data:[<media type>][;charset=<character set>][;base64],<data>

Также см. http://danielmclaren.com/node/90


вы можете использовать этот

$image = 'http://images.itracki.com/2011/06/favicon.png';
// Read image path, convert to base64 encoding
$imageData = base64_encode(file_get_contents($image));

// Format the image SRC:  data:{mime};base64,{data};
$src = 'data: '.mime_content_type($image).';base64,'.$imageData;

// Echo out a sample image
echo '<img src="'.$src.'">';

сначала преобразуйте изображение в Base64 (encode to Base64). Вы можете сделать это онлайн или с PHP-скрипт.

после преобразования вы получите результат как

iVBORw0KGgoAAAANSUhEUgAAABkAAAAZCAYAAADE6YVjAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAyJpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuMy1jMDExIDY2LjE0NTY2MSwgMjAxMi8wMi8wNi0xNDo1NjoyNyAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvIiB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIgeG1sbnM6c3RSZWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZVJlZiMiIHhtcDpDcmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENTNiAoV2luZG93cykiIHhtcE1NOkluc3RhbmNlSUQ9InhtcC5paWQ6MEVBMTczNDg3QzA5MTFFNjk3ODM5NjQyRjE2RjA3QTkiIHhtcE1NOkRvY3VtZW50SUQ9InhtcC5kaWQ6MEVBMTczNDk3QzA5MTFFNjk3ODM5NjQyRjE2RjA3QTkiPiA8eG1wTU06RGVyaXZlZEZyb20gc3RSZWY6aW5zdGFuY2VJRD0ieG1wLmlpZDowRUExNzM0NjdDMDkxMUU2OTc4Mzk2NDJGMTZGMDdBOSIgc3RSZWY6ZG9jdW1lbnRJRD0ieG1wLmRpZDowRUExNzM0NzdDMDkxMUU2OTc4Mzk2NDJGMTZGMDdBOSIvPiA8L3JkZjpEZXNjcmlwdGlvbj4gPC9yZGY6UkRGPiA8L3g6eG1wbWV0YT4gPD94cGFja2V0IGVuZD0iciI/PjjUmssAAAGASURBVHjatJaxTsMwEIbpIzDA6FaMMPYJkDKzVYU+QFeEGPIKfYU8AETkCYI6wANkZQwIKRNDB1hA0Jrf0rk6WXZ8BvWkb4kv99vn89kDrfVexBSYgVNwDA7AN+jAK3gEd+AlGMGIBFDgFvzouK3JV/lihQTOwLtOtw9wIRG5pJn91Tbgqk9kSk7GViADrTD4HCyZ0NQnomi51sb0fUyCMQEbp2WpU67IjfNjwcYyoUDhjJVcZBjYBy40j4wXgaobWoe8Z6Y80CJBwFpunepIzt2AUgFjtXXshNXjVmMh+K+zzp/CMs0CqeuzrxSRpbOKfdCkiMTS1VBQ41uxMyQR2qbrXiiwYN3ACh1FDmsdK2Eu4J6Tlo31dYVtCY88h5ELZIJJ+IRMzBHfyJINrigNkt5VsRiub9nXICdsYyVd2NcVvA3ScE5t2rb5JuEeyZnAhmLt9NK63vX1O5Pe8XaPSuGq1uTrfUgMEp9EJ+CQvr+BJ/AAKvAcCiAR+bf9CjAAluzmdX4AEIIAAAAASUVORK5CYII=

Теперь он прост в использовании.

вы должны просто положить его в src изображения и определить там, как это в кодированной форме base64.

пример:

<img src="">

Это покажет изображение базы 64 данных:

<style>
.logo {
            width: 290px;
            height: 63px;
            background: url(-paste-base64-data-here) no-repeat;
        }
</style>

<div class="logo"/>

символ+, встречающийся в URI данных, должен быть закодирован как %2B. Это похоже на кодирование любой другой строки в URI. Например, разделители аргументов (? и &) должен быть закодирован, когда URI с аргументом отправляется как часть другого URI.


вы можете поместить свои данные непосредственно в заявлении адрес, как

src = 'url(imageData)' ;

и для получения данных изображения u может использовать функцию php

$imageContent = file_get_contents("imageDir/".$imgName);

$imageData = base64_encode($imageContent);

таким образом, вы можете скопировать вставить значение imageData и вставить его непосредственно в url-адрес и назначить его атрибуту src вашего изображения


кажется, есть какая-то ошибка в URL-адресе данных.

вы можете использовать этот онлайн кодировка base64 / base64 декодировать инструмент для кодирования изображений для встраивания: http://base64online.org/encode/

проверить формат "в качестве URL-адресов" в формате base64-данные в URL-адрес.

то, что я сделал, это завершить url с img.jpg, чтобы избежать кэширования и потерять возможность проверить, если клиент открыл письмо полный URL выглядит как"http://midomain.com/<Random letters numbers>/img.jpg"

используя случайные вещи, как часть URL, Google не будет кэшировать изображения. Важной частью является завершение URL-адреса с допустимым именем изображения с расширением.

Это мой код Symfony (я думаю, что это будет хорошо для голого PHP тоже), чтобы отправить изображение.

$im = imagecreatetruecolor(1,1);
$white = imagecolorallocate($im, 255, 255, 255);
imagesetpixel ($im , 0 , 0 , $white);
header('Content-Type: image/jpeg');
// Output the image
imagejpeg($im);
// Free up memory
imagedestroy($im);
exit;

на exit очень важно, чтобы PHP не отправлял что-нибудь другое.


попробуйте и это:

let base64="iVBORw0KGgoAAAANSUhEUgAAAAUAAAAFCAYAAACNbyblAAAAHElEQVQI12P4//8/w38GIAXDIBKE0DHxgljNBAAO9TXL0Y4OHwAAAABJRU5ErkJggg==";
let buffer=Uint8Array.from(atob(base64), c => c.charCodeAt(0));
let blob=new Blob([buffer], { type: "image/gif" });
let url=URL.createObjectURL(blob);
let img=document.createElement("img");
img.src=url;
document.body.appendChild(img);

не рекомендуется для производства, поскольку он совместим только с современными браузерами.