php mysql遇到不存入_php图片保存入mysql数据库失败解决办法_PHP教程

图片保存数据库并不是一个明智的做法,我们多半是把图片保存到服务器,然后把图片地址保存到数据库,这样我们每次只要读出图片地址就可以显示了,但下面我还是来介绍一个图片保存到mysql数据库的问题解决办法。

代码如下

require 'class/db.php';

$fileName = "a1.jpg";

$fp = fopen($fileName, "r");

$img = fread($fp, filesize($fileName));

fclose($fp);

$db->execute("insert db2.testimg (`img`) values ('$img') ;");

报错

You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '`?绶q?仳!????1丶>,Mo?'^WZ4in??T春??????U?楹\?' at line 1

代码如下

$img = fread($fp, filesize($fileName));

$img = addslashes($img)

继续报错

各种搜索,百度里的结果都是addslashes,要不就是addslashes也没有的。真是扯淡啊

base64_decode

$img = base64_encode($img);

插入成功。图片文件17.0k

出来进行base64_decode ,显示正常

找到个16进制的办法

$img = bin2hex($img);

有效,输出不用解密 。存入数据库很大 25K。比base64还坑爹呢。

再找。

后来,后来。发现phpmyadmin直接上传的图片文件可以用文件比base64的小。文件12.8k

翻phpmyadmin 源代码

common.lib.php文件183有个神奇的函数

代码如下

function PMA_sqlAddslashes($a_string = '', $is_like = false, $crlf = false, $php_code = false)

{

if ($is_like) {

$a_string = str_replace('\', '\\\\', $a_string);

} else {

$a_string = str_replace('\', '\\', $a_string);

}

if ($crlf) {

$a_string = str_replace("n", 'n', $a_string);

$a_string = str_replace("r", 'r', $a_string);

$a_string = str_replace("t", 't', $a_string);

}

if ($php_code) {

$a_string = str_replace(''', '\'', $a_string);

} else {

$a_string = str_replace(''', '''', $a_string);

}

return $a_string;

} // end of the 'PMA_sqlAddslashes()' function$img = PMA_sqlAddslashes($img);

文件大小12.8K 和phpmyadmin的一样大。

前台(image.html):

代码如下

上传图片

后台处理(upimage.php):

代码如下

插入成功!

显示图片";

else

echo "插入失败!";

mysql_close();

}else

echo "请先选择图片!

点此返回";

} else

echo "请先选择图片!

点此返回";

?>

显示图片(disimage.php):

代码如下

结论

PMA_sqlAddslashes好用 文件12.8k 和原来图片一样大

bin2hex 16进制 好用文件25K

base64_encode 好用,出来的文件需要base64_decode 17K

addslashes 不好用,继续报错(注明:在某些windows机器上addslashes好用)

http://www.bkjia.com/PHPjc/630680.htmlwww.bkjia.comtruehttp://www.bkjia.com/PHPjc/630680.htmlTechArticle图片保存数据库并不是一个明智的做法,我们多半是把图片保存到服务器,然后把图片地址保存到数据库,这样我们每次只要读出图片地址...

本条技术文章来源于互联网,如果无意侵犯您的权益请点击此处反馈版权投诉

本文系统来源:php中文网

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值