php向数据库中插入图片,php如何向数据库添加图片

56e7e1ff69470df99ca19e6bb2de2a44.png

百度开发者的云代码空间为了保证高可用,不允许用户将图片保存到代码空间中,使用CDN或者对象存储不仅收费而且使用比较复杂,于是考

虑能否将img存储在数据库中,虽然很多人说会造成性能问题,权当一试。

1、准备三个文件

92db21a94ba6785b177c36a90374b18f.png

第一个用于将图片存储为数据库字符,第二个php文件用于获取数据库字符并生成图片,第三个是文件1所使用的图片。

2、数据库设计

超长字符串或者二进制数据分别可以用TEXT(65535),BLOB(64k)保存,但是尝试使用二进制保存失败,便使用TEXT保存,但是一张500多kb的

图片经过base64加密的字符长度高度75万!

仅仅靠一个TEXT是存不下去的,而且应该也会造成严重的性能问题,所以分割成N份保存,这里以50000字符长度为一个单位。记录

imgid,方便拼接。

7a73a7df2e844b402ad5c096ee186c73.png

3、将图片保存到数据库[dm01_imgTobase64.php]/*链接数据库*/

// 1.转为普通字符

$file = file_get_contents('test.jpg');

$base64_str = base64_encode($file);

$len = strlen($base64_str);

$step = ceil($len/50000);

for ($i=0; $i

$substr = substr($base64_str, $i*50000,50000);

$sql = "INSERT INTO b64_img VALUES( null,1,1,$i,'$substr') ";

$res = mysqli_query($link,$sql);

}

4、生成的数据

9c65e4b22f9e952f3d152a61fc8d0f4d.png

5、读取数据库记录,生成图片[dm02_getImg.php]/*链接数据库*/

$sql = "SELECT * FROM b64_img WHERE imgid = 1 ORDER BY bakid ASC ";

$res = mysqli_query($link,$sql);

$data = array();

$imgStr = '';

while ($row = mysqli_fetch_assoc($res)) {

$imgStr .= $row['bstr'] ;

}

$binaryStr = base64_decode($imgStr);

file_put_contents("ThisImg.jpg", $binaryStr);

6、成功生成图片

50eff26c9a20b572ed7e3fdb6b009cc1.png

推荐教程:PHP视频教程

  • 2
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值