本文实例分析了php将图片保存入mysql数据库失败的解决方法。分享给大家供大家参考。具体分析如下:
图片保存数据库并不是一个明智的做法,我们多半是把图片保存到服务器,然后把图片地址保存到数据库,这样我们每次只要读出图片地址就可以显示了,但下面我还是来介绍一个图片保存到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);
例,前台image.html,代码如下:
<html> <head> <title>上传图片</title> </head> <body> <form method="post" action="upimage.php" enctype="multipart/form-data"> <input type="hidden" value="204800" name="MAX_FILE_SIZE"/> File: <input type="file" name="imgfile" /> <input type="submit" value="OK" name="submitbtn" style="width:100px;height:23px"/></center> </form> </body> </html>
<?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 "<center>插入成功!<br><br><a href='disimage.php'>显示图片</a></center>"; else echo "<center>插入失败!</center>"; mysql_close(); }else echo "<center>请先选择图片!<br><br><a href='image.html'>点此返回</a></center>"; } else echo "<center>请先选择图片!<br><br><a href='image.html'>点此返回</a></center>"; ?>
<?php mysql_connect("localhost","root","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程序设计有所帮助。
本文向大家介绍js input输入百分号保存数据库失败的解决方法,包括了js input输入百分号保存数据库失败的解决方法的使用技巧和注意事项,需要的朋友参考一下 解决办法如下: 1.用ASCII码替换百分号和与符号 2.在jquery中用编码转换来实现百分号的保存 结果为: my%20test.php?name=%25fff&car=saab#& 这里将百分号编码为 %25 该方法不会对 AS
本文向大家介绍php实现上传图片保存到数据库的方法,包括了php实现上传图片保存到数据库的方法的使用技巧和注意事项,需要的朋友参考一下 php实现上传图片保存到数据库的方法。分享给大家供大家参考。具体分析如下: php 上传图片,一般都使用move_uploaded_file方法保存在服务器上。但如果一个网站有多台服务器,就需要把图片发布到所有的服务器上才能正常使用(使用图片服务器的除外) 如果把
问题内容: 我的客户在php + mysql中创建了一个脚本,该脚本将图像直接保存在数据库中,并且每个图像都有这样的url:www.example.com/image.php?id=421 您认为这是一个非常错误的解决方案?我应该重建所有站点吗? 每天大约有1000次访问,数据库中大约有600张图像。 问题答案: 图像文件是文件,除非有充分的理由将它们存储在数据库中,否则它们应属于文件系统,在文件
本文向大家介绍MySQL数据库innodb启动失败无法重启的解决方法,包括了MySQL数据库innodb启动失败无法重启的解决方法的使用技巧和注意事项,需要的朋友参考一下 问题介绍 电脑在使用过程中死机,重启后发现mysql没有启动成功,查看错误日志发现是innodb出现问题导致mysql启动失败。 错误日志 解决方法 1.如果数据不重要或已经有备份,只需要恢复mysql启动 进入mysql目录,
本文向大家介绍php查询mysql数据库并将结果保存到数组的方法,包括了php查询mysql数据库并将结果保存到数组的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了php查询mysql数据库并将结果保存到数组的方法。分享给大家供大家参考。具体分析如下: 这里主要用到了mysql_fetch_assoc函数 mysql_fetch_assoc语法如下: 范例代码如下: 希望本文所述对
本文向大家介绍SQL附加数据库失败问题的解决方法,包括了SQL附加数据库失败问题的解决方法的使用技巧和注意事项,需要的朋友参考一下 为了偷个懒,利用这个数据库,但是在附加的时候出错了。 错误如下: 一开始还以为数据库位置存在问题,所以重新放置了一个位置,仍然无效。最后,上网寻找解决方法。所幸的是此类问题还真有人遇到了,而且也有好几种解决方法。我就用了两种方法,分享一下吧: 方法一: 将要附加的文件