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,代码如下:
image; mysql_close(); ?>
结论:
PMA_sqlAddslashes好用 文件12.8k 和原来图片一样大
bin2hex 16进制 好用文件25K
base64_encode 好用,出来的文件需要base64_decode 17K
addslashes 不好用,继续报错,注明,在某些windows机器上addslashes好用.
教程链接:
随意转载~但请保留教程地址★
推荐阅读
-
php下将图片以二进制存入mysql数据库中并显示的实现代码
-
mysql - 用php把本地要上传的图片经过剪切,存入数据库
-
php下将图片以二进制存入mysql数据库中并显示的实现代码
-
php将图片保存入mysql数据库失败的解决方法_PHP
-
免费mysql数据库 php下将图片以二进制存入mysql数据库中并显示的实现代码
-
php将图片保存入mysql数据库失败的解决方法
-
php将图片保存入mysql数据库失败的解决方法_php技巧
-
php将图片保存入mysql数据库失败的解决方法,_PHP教程
-
php将图片保存入mysql数据库失败的解决方法_php技巧
-
php将图片保存入mysql数据库失败的解决方法,_PHP教程