php将图片保存入mysql数据库失败的解决方法

前端之家收集整理的这篇文章主要介绍了php将图片保存入mysql数据库失败的解决方法前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

本文实例分析了PHP图片保存入MysqL数据库失败的解决方法分享给大家供大家参考。具体分析如下:

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

代码如下:
$db->execute("insert db2.testimg (img) values ('$img') ;");

报错:

,Mo?'^WZ4in??T春??????U?楹\?' at line 1

代码如下:

代码如下:

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

代码如下:

插入成功,图片文件17.0k,出来进行base64_decode,显示正常,找到个16进制的办法:

代码如下:

有效,输出不用解密,存入数据库很大 25K,比base64还坑爹呢,再找,后来,发现PHPmyadmin直接上传图片文件可以用文件比base64的小,文件12.8k.

PHPmyadmin 源代码,common.lib.PHP文件183有个神奇的函数,代码如下:

代码如下:
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 $astring;
} // end of the 'PMA
sqlAddslashes()' function$img = PMA_sqlAddslashes($img);


文件大小12.8K 和PHPmyadmin的一样大.

例,前台image.html,代码如下:

代码如下:
<a href="https://www.jb51.cc/tag/shangchuan/" target="_blank" class="keywords">上传</a><a href="https://www.jb51.cc/tag/tupian/" target="_blank" class="keywords">图片</a>
PHP" enctype="multipart/form-data">
后台处理upimage.PHP代码如下:
代码如下:
PHP //向数据库中插入图片 $imgfile=$_FILES['imgfile']; $submitbtn=$_POST['submitbtn']; if($submitbtn=='OK' and is_array($imgfile)){ $name=$imgfile['name']; //取得图片名称 $type=$imgfile['type']; //取得图片类型 $size=$imgfile['size']; //取得图片长度 $tmpfile=$imgfile['tmp_name']; //图片上传上来到临时文件的路径 if($tmpfile and is_uploaded_file($tmpfile)){ //判断上传文件是否为空,文件是不是上传文件 //读取图片流 $file=fopen($tmpfile,"rb"); $imgdata=bin2hex(fread($file,$size)); //bin2hex()将二进制数据转换成十六进制表示 fclose($file);

$MysqLi=MysqL_connect("localhost","root","123456″); //连接数据库函数
MysqL_select_db("test"); //选择数据库
//插入出数据库语句,图片数据前要加上0x,用于表示16进制数
if(MysqL_query("insert into images(name,type,image) values('".$name."','".$type."',0x".$imgdata.")"))
echo "

插入成功!

显示图片
";
else
echo "
插入失败!
";
MysqL_close();
}else
echo "
请先选择图片

点此返回
";
} else
echo "
请先选择图片

点此返回
";
?>

显示图片disimage.PHP,代码如下:
<div class="codetitle"><a style="CURSOR: pointer" data="18215" class="copybut" id="copybut18215" onclick="doCopy('code18215')"> 代码如下:
<div class="codebody" id="code18215"><?php
mysql_connect("localhost","123456″);
mysql_select_db("test");
//显示最新插入的那张图片
$result=mysql_query("select image from images where id=(select max(id) from images)");
$row=mysql_fetch_object($result);
header("Content-Type:image/pjpeg");
echo $row->image;
MysqL_close();
?>

结论:

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

bin2hex 16进制 好用文件25K

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

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

希望本文所述对大家的PHP程序设计有所帮助。

原文链接:https://www.f2er.com/php/22994.html

猜你在找的PHP相关文章