首页 > php教程 > php手册 > 正文

php图片保存入mysql数据库失败解决办法

php中文网
发布: 2016-05-25 16:37:57
原创
1223人浏览过

图片保存数据库并不是一个明智的做法,我们多半是把图片保存到服务器,然后把图片地址保存到数据库,这样我们每次只要读出图片地址就可以显示了,但下面我还是来介绍一个图片保存到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)

立即学习PHP免费学习笔记(深入)”;

继续报错,各种搜索,百度里的结果都是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有个神奇的函数,代码如下:

影像之匠PixPretty
影像之匠PixPretty

商业级AI人像后期软件,专注于人像精修,色彩调节及批量图片编辑,支持Windows、Mac多平台使用。适用于写真、婚纱、旅拍、外景等批量修图场景。

影像之匠PixPretty 299
查看详情 影像之匠PixPretty
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,代码如下:

<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>
登录后复制

后台处理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 "<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>"; 
?>
登录后复制

显示图片disimage.php,代码如下:

<?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速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号