欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  php教程

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

程序员文章站 2022-03-21 14:25:48
...
图片保存数据库并不是一个明智的做法,我们多半是把图片保存到服务器,然后把图片地址保存到数据库,这样我们每次只要读出图片地址就可以显示了,但下面我还是来介绍一个图片保存到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); 
文件大小12.8K 和phpmyadmin的一样大.

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

 
上传图片
File:

后台处理upimage.php代码如下:

插入成功!

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

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

点此返回
"; ?>

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

image; 
 mysql_close(); 
?>

结论:

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

bin2hex 16进制 好用文件25K

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

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


教程链接:

随意转载~但请保留教程地址★