php图片保存入mysql数据库失败解决办法_PHP教程
代码如下 | 复制代码 |
require 'class/db.php'; $img = fread($fp, filesize($fileName)); $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)); |
继续报错
各种搜索,百度里的结果都是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) |
文件大小12.8K 和phpmyadmin的一样大。
例
前台(image.html):
代码如下 | 复制代码 |
|
后台处理(upimage.php):
代码如下 | 复制代码 |
//向数据库中插入图片 显示图片 else echo " mysql_close(); }else echo " 点此返回 } else echo " 点此返回 ?> |
显示图片(disimage.php):
代码如下 | 复制代码 |
mysql_connect("localhost","root","123456″); |
结论
PMA_sqlAddslashes好用 文件12.8k 和原来图片一样大
bin2hex 16进制 好用文件25K
base64_encode 好用,出来的文件需要base64_decode 17K
addslashes 不好用,继续报错(注明:在某些windows机器上addslashes好用)
推荐阅读
-
php把图片存入mysql数据库中并在网页上显示
-
php下将图片以二进制存入mysql数据库中并显示的实现代码
-
PHP中怎么样将图片储存在MySQL数据库_PHP教程
-
mysql - 用php把本地要上传的图片经过剪切,存入数据库
-
PHP中怎么样将图片储存在MySQL数据库_PHP教程
-
oneThink 数据库连接失败,总提示密码不对的解决办法,onethink数据库连接_PHP教程
-
php下将图片以二进制存入mysql数据库中并显示的实现代码
-
php将图片保存入mysql数据库失败的解决方法_PHP
-
关于UEditor编辑器远程图片上传失败的解决办法_PHP教程
-
免费mysql数据库 php下将图片以二进制存入mysql数据库中并显示的实现代码