找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 674|回复: 0
打印 上一主题 下一主题

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

[复制链接]

2617

主题

2617

帖子

7789

积分

论坛元老

Rank: 8Rank: 8

积分
7789
跳转到指定楼层
楼主
发表于 2018-2-14 05:50:52 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

            本文实例分析了php将图片保存入mysql数据库失败的解决方法。分享给大家供大家参考。具体分析如下:
图片保存数据库并不是一个明智的做法,我们多半是把图片保存到服务器,然后把图片地址保存到数据库,这样我们每次只要读出图片地址就可以显示了,但下面我还是来介绍一个图片保存到mysql数据库的问题解决办法,代码如下:
[U]复制代码[/U] 代码如下:require 'class/db.php';
$fileName = "a1.jpg";
$fp = fopen($fileName, "r");
$($fp, filesize($fileName));
fclose($fp);

$db->execute("insert db2.test(`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
代码如下:
[U]复制代码[/U] 代码如下($fp, filesize($fileName));
$($img)
继续报错,各种搜索,百度里的结果都是addslashes,要不就是addslashes也没有的,真是扯淡啊.
[U]复制代码[/U] 代码如下:base64_decode
$($img);
插入成功,图片文件17.0k,出来进行base64_decode,显示正常,找到个16进制的办法:
[U]复制代码[/U] 代码如下($img);
有效,输出不用解密,存入数据库很大 25K,比base64还坑爹呢,再找,后来,后来,发现phpmyadmin直接上传的图片文件可以用文件比base64的小,文件12.8k.
翻phpmyadmin 源代码,common.lib.php文件183有个神奇的函数,代码如下:
[U]复制代码[/U] 代码如下: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);
文件大小12.8K 和phpmyadmin的一样大.
例,前台image.html,代码如下:
[U]复制代码[/U] 代码如下:

  上传图片





File:



后台处理upimage.php代码如下:
[U]复制代码[/U] 代码如下:插入成功!
显示图片";
  else
   echo "插入失败!";
  mysql_close();
}else
echo "请先选择图片!
点此返回";
} else
echo "请先选择图片!
点此返回";
?>
显示图片disimage.php,代码如下:
[U]复制代码[/U] 代码如下:image;
mysql_close();
?>
结论:
PMA_sqlAddslashes好用 文件12.8k 和原来图片一样大
bin2hex 16进制 好用文件25K
base64_encode 好用,出来的文件需要base64_decode 17K
addslashes 不好用,继续报错,注明,在某些windows机器上addslashes好用.
希望本文所述对大家的php程序设计有所帮助。
            
            
您可能感兴趣的文章:
  • 用PHP和MySQL保存和输出图片
  • 图片存储与浏览一例(Linux+Apache+PHP+MySQL)
  • php mysql数据库操作类
  • php下将图片以二进制存入mysql数据库中并显示的实现代码
  • PHP导入Excel到MySQL的方法
  • php中将图片gif,jpg或mysql longblob或blob字段值转换成16进制字符串
  • 测试PHP连接MYSQL成功与否的代码
  • Php连接及读取和写入mysql数据库的常用代码
  • PHP连接和操作MySQL数据库基础教程
  • PHP+MYSQL实现用户的增删改查
  • PHP操作MySQL中BLOB字段的方法示例【存储文本与图片】
            
  • 分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    用户反馈
    客户端