我有这个包含图像作为字符串的数据库。这些字符串看起来像这样:
data:image/jpeg;base64,/9j/4AAQSkZJRgABAQEAYABgAAD...
我需要创建一个显示此图像的链接。像something.com/?id=27
一样是一张图片。所有图像都是jpeg格式。这是我尝试但没有奏效的内容:
<?php
$host = "smth";
$user = "smth";
$pass = "smth";
$db_name = "smth";
$dbh = new PDO("mysql:host=$host;dbname=$db_name", $user, $pass);
$dbh->exec("SET NAMES utf8");
$q = $dbh->prepare("select content from img where id = :id");
$q->execute(array(':id'=>$_GET['id']));
$row = $q->fetch(PDO::FETCH_BOTH);
header("Content-type: image/jpeg");
echo $row['content'];
?>
正在正确获取数据,但不显示图像。
我需要能够像<img src="mysite.com?id=21" />
一样使用此链接,我不想要这个解决方案:<img src="data:image/jpeg;base64,/9j/4AAQSkZJRgABA..." />
谢谢!
答案 0 :(得分:25)
How to decode a base64 string (gif) into image in PHP / HTML
如果您去除第一个案例并选择解码字符串,则应在回显解码图像数据之前添加此字符串:
header("Content-type: image/gif");
$data = "/9j/4AAQSkZJRgABAQEAYABgAAD........";
echo base64_decode($data);
在第二种情况下,请改用:
echo '<img src="data:image/gif;base64,' . $data . '" />';
第二种情况很糟糕,因为如果在多个页面上显示相同的图像,浏览器不会执行缓存。
答案 1 :(得分:3)
使用此:
$code_base64 = $row['content'];
$code_base64 = str_replace('data:image/jpeg;base64,','',$code_base64);
$code_binary = base64_decode($code_base64);
$image= imagecreatefromstring($code_binary);
header('Content-Type: image/jpeg');
imagejpeg($image);
imagedestroy($image);
答案 2 :(得分:2)
试试这个
//your image data
$logodata = "/9j/4AAQSkZJRgABAQEAYABgAAD........";
echo '<img src="data:image/gif;base64,' . $logodata . '" />';
答案 3 :(得分:1)
如果要处理存储在PostgreSQL数据库 bytea 字段中的数据,则在获取PDO时会收到 stream 。要进一步处理数据,请先将流转换为常规数据,如下所示:controls
答案 4 :(得分:0)
试试这个:
echo '<img src="data:image/png;base64,' . $base64encodedString . '" />
答案 5 :(得分:0)
/**
* @param $base64_image_content
* @param $path
* @return bool|string
*/
function base64_image_content($base64_image_content,$path){
if (preg_match('/^(data:\s*image\/(\w+);base64,)/', $base64_image_content, $result)){
$type = $result[2];
$new_file = $path."/".date('Ymd',time())."/";
$basePutUrl = C('UPLOAD_IMG_BASE64_URL').$new_file;
if(!file_exists($basePutUrl)){
//Check if there is a folder, if not, create it and grant the highest authority.
mkdir($basePutUrl, 0700);
}
$ping_url = genRandomString(8).time().".{$type}";
$ftp_image_upload_url = $new_file.$ping_url;
$local_file_url = $basePutUrl.$ping_url;
if (file_put_contents($local_file_url, base64_decode(str_replace($result[1], '', $base64_image_content)))){
ftp_upload(C('REMOTE_ROOT').$ftp_image_upload_url,$local_file_url);
return $ftp_image_upload_url;
}else{
return false;
}
}else{
return false;
}
}