国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > PHP > 正文

php將圖片保存入mysql數據庫失敗的解決方法

2024-05-04 23:29:30
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了php將圖片保存入mysql數據庫失敗的解決方法,詳細分析了php將圖片保存入數據庫遇到的問題及對應的解決方法,并總結了相關的技巧,具有一定的參考借鑒價值,需要的朋友可以參考下
 
 

本文實例分析了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);

文件大小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程序設計有所幫助。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 内乡县| 襄垣县| 探索| 芦溪县| 道真| 铜山县| 松滋市| 沁源县| 洞口县| 曲阳县| 乡城县| 漠河县| 曲松县| 旬阳县| 巫山县| 喀喇沁旗| 甘谷县| 邹平县| 蓬安县| 榆社县| 莎车县| 安阳县| 盐津县| 花莲县| 林西县| 顺平县| 涡阳县| 太白县| 天峨县| 广元市| 望城县| 敦煌市| 海口市| 青岛市| 金秀| 台东市| 右玉县| 河西区| 石景山区| 沙湾县| 泸定县|