
百度开发者的云代码空间为了保证高可用,不允许用户将图片保存到代码空间中,使用cdn或者对象存储不仅收费而且使用比较复杂,于是考虑能否将img存储在数据库中,虽然很多人说会造成性能问题,权当一试。
1、准备三个文件

第一个用于将图片存储为数据库字符,第二个php文件用于获取数据库字符并生成图片,第三个是文件1所使用的图片。
2、数据库设计
立即学习“PHP免费学习笔记(深入)”;
超长字符串或者二进制数据分别可以用TEXT(65535),BLOB(64k)保存,但是尝试使用二进制保存失败,便使用TEXT保存,但是一张500多kb的图片经过base64加密的字符长度高度75万!
仅仅靠一个TEXT是存不下去的,而且应该也会造成严重的性能问题,所以分割成N份保存,这里以50000字符长度为一个单位。记录imgid,方便拼接。

部分功能简介:商品收藏夹功能热门商品最新商品分级价格功能自选风格打印结算页面内部短信箱商品评论增加上一商品,下一商品功能增强商家提示功能友情链接用户在线统计用户来访统计用户来访信息用户积分功能广告设置用户组分类邮件系统后台实现更新用户数据系统图片设置模板管理CSS风格管理申诉内容过滤功能用户注册过滤特征字符IP库管理及来访限制及管理压缩,恢复,备份数据库功能上传文件管理商品类别管理商品添加/修改/
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 <$step ; $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、生成的数据

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、成功生成图片

推荐教程:PHP视频教程










