中文字幕日韩精品一区二区免费_精品一区二区三区国产精品无卡在_国精品无码专区一区二区三区_国产αv三级中文在线

php保存圖片到數(shù)據(jù)庫(kù),php上傳圖片存儲(chǔ)

怎樣用php實(shí)現(xiàn)上傳圖片到數(shù)據(jù)庫(kù)

php實(shí)現(xiàn)上傳圖片保存到數(shù)據(jù)庫(kù)的方法。具體分析如下:

創(chuàng)新互聯(lián)專注于企業(yè)營(yíng)銷型網(wǎng)站建設(shè)、網(wǎng)站重做改版、八宿網(wǎng)站定制設(shè)計(jì)、自適應(yīng)品牌網(wǎng)站建設(shè)、H5開(kāi)發(fā)、商城網(wǎng)站建設(shè)、集團(tuán)公司官網(wǎng)建設(shè)、外貿(mào)營(yíng)銷網(wǎng)站建設(shè)、高端網(wǎng)站制作、響應(yīng)式網(wǎng)頁(yè)設(shè)計(jì)等建站業(yè)務(wù),價(jià)格優(yōu)惠性價(jià)比高,為八宿等各大城市提供網(wǎng)站開(kāi)發(fā)制作服務(wù)。

php 上傳圖片,一般都使用move_uploaded_file方法保存在服務(wù)器上。但如果一個(gè)網(wǎng)站有多臺(tái)服務(wù)器,就需要把圖片發(fā)布到所有的服務(wù)器上才能正常使用(使用圖片服務(wù)器的除外)

如果把圖片數(shù)據(jù)保存到數(shù)據(jù)庫(kù)中,多臺(tái)服務(wù)器間可以實(shí)現(xiàn)文件共享,節(jié)省空間。

首先圖片文件是二進(jìn)制數(shù)據(jù),所以需要把二進(jìn)制數(shù)據(jù)保存在mysql數(shù)據(jù)庫(kù)。

mysql數(shù)據(jù)庫(kù)提供了BLOB類型用于存儲(chǔ)大量數(shù)據(jù),BLOB是一個(gè)二進(jìn)制對(duì)象,能容納不同大小的數(shù)據(jù)。

BLOB類型有以下四種,除存儲(chǔ)的最大信息量不同外,其他都是一樣的??筛鶕?jù)需要使用不同的類型。

TinyBlob?????? 最大 255B

Blob????????????? 最大 65K

MediumBlob? 最大 16M

LongBlob????? 最大 4G

數(shù)據(jù)表photo,用于保存圖片數(shù)據(jù),結(jié)構(gòu)如下:

CREATE?TABLE?`photo`?(??

`id`?int(10)?unsigned?NOT?NULL?auto_increment,??

`type`?varchar(100)?NOT?NULL,??

`binarydata`?mediumblob?NOT?NULL,??

PRIMARY?KEY??(`id`)??

)?ENGINE=MyISAM?DEFAULT?CHARSET=latin1?AUTO_INCREMENT=1?;

upload_image_todb.php代碼如下:

?php??

//?連接數(shù)據(jù)庫(kù)??

$conn=@mysql_connect("localhost","root","")??or?die(mysql_error());??

@mysql_select_db('demo',$conn)?or?die(mysql_error());?//?判斷action??

$action?=?isset($_REQUEST['action'])??$_REQUEST['action']?:?'';?

//?上傳圖片??

if($action=='add'){??

$image?=?mysql_escape_string(file_get_contents($_FILES['photo']['tmp_name']));??

$type?=?$_FILES['photo']['type'];??

$sqlstr?=?"insert?into?photo(type,binarydata)?values('".$type."','".$image."')";??

@mysql_query($sqlstr)?or?die(mysql_error());??

header('location:upload_image_todb.php');??

exit();??

//?顯示圖片??

}elseif($action=='show'){??

$id?=?isset($_GET['id'])??intval($_GET['id'])?:?0;??

$sqlstr?=?"select?*?from?photo?where?id=$id";??

$query?=?mysql_query($sqlstr)?or?die(mysql_error());??

$thread?=?mysql_fetch_assoc($query);??

if($thread){??

header('content-type:'.$thread['type']);??

echo?$thread['binarydata'];??

exit();??

}??

}else{??

//?顯示圖片列表及上傳表單??

???

!DOCTYPE?HTML?PUBLIC?"-//W3C//DTD?HTML?4.01?Transitional//EN"?""??

html??

head??

meta?http-equiv="content-type"?content="text/html;?charset=utf-8"??

title?upload?image?to?db?demo?/title??

/head??

body??

form?name="form1"?method="post"?action="upload_image_todb.php"?enctype="multipart/form-data"??

p圖片:input?type="file"?name="photo"/p??

pinput?type="hidden"?name="action"?value="add"input?type="submit"?name="b1"?value="提交"/p??

/form??

?php??

$sqlstr?=?"select?*?from?photo?order?by?id?desc";??

$query?=?mysql_query($sqlstr)?or?die(mysql_error());??

$result?=?array();??

while($thread=mysql_fetch_assoc($query)){??

$result[]?=?$thread;??

}??

foreach($result?as?$val){??

echo?'pimg?

src="upload_image_todb.php?action=showid='.$val['id'].'t='.time().'"

width="150"/p';??

}??

???

/body??

/html??

?php??

}??

?

程序運(yùn)行截圖和數(shù)據(jù)庫(kù)截圖:

php如何上傳圖片到數(shù)據(jù)庫(kù)

把圖片保存到服務(wù)器,拼接圖片地址

保存圖片地址到數(shù)據(jù)庫(kù)

讀取圖片地址就能訪問(wèn)到圖片了。

PHP將圖片存入數(shù)據(jù)庫(kù)

插入圖片和一般的數(shù)據(jù)沒(méi)什么不同的,一般數(shù)據(jù)會(huì)了,傳圖片時(shí)候就用個(gè)move_uploaded_file改變下參數(shù),主要是做這個(gè)的時(shí)候不要有負(fù)擔(dān)

以下供參考

?

function upload_file($files,$folder)//上傳圖片

{

$file_tyle = $files['type'];

$file_type_arr = array('image/gif','image/x-png','image/jpg','image/pjpeg');

if(!in_array($file_tyle,$file_type_arr) )

{

exit('file type only can be: png,jpeg,jpg,gif');

}

$knamearray = explode(".",$files["name"]);

$kname = $knamearray[count($knamearray)-1];

$rand_str = date("ymdhis");

$file_name = $rand_str.".".$kname;

$savepath = "$folder/";

/*$savepath = "$folder/date_".date('YmdHis')."/";

if( !is_dir($savepath) ) mkdir($savepath);*/

$upfile = $savepath.$file_name;

if( !move_uploaded_file($files['tmp_name'],$upfile) )

{

exit('upload error, please check your file type: png,jpeg,jpg,gif');

}

return $file_name;//不要回傳值此行可注釋掉

}

?

PHP如何把上傳到服務(wù)器里的圖片路徑保存到數(shù)據(jù)庫(kù)里,添加代碼謝謝

?php

$type=$_FILES['filephoto']['type'];

if($type=='image/gif'|| $type=='image/jpeg'||$type=='image/pjpeg')

{

if($_FILES['filephoto']['size']2*1024*1024)

{

$aa=substr($_FILES['filephoto']['name'],strpos($_FILES['filephoto']['name'],'.'));//圖片類型名 如 .png

$photo=date("yndhis").rand(10000,99999).$aa;//圖片名字

move_uploaded_file( $_FILES['filephoto']['tmp_name'] , 'photo/'.$photo );//上傳指定文件夾

}//$image=文件夾名/圖片名 添加數(shù)據(jù)庫(kù)

}

?

php 數(shù)據(jù)庫(kù)圖片存儲(chǔ)問(wèn)題?

存儲(chǔ)的是相對(duì)路徑,可以到網(wǎng)站服務(wù)器上查看,應(yīng)該有upload文件夾,里面就是存儲(chǔ)的圖片,這樣寫(xiě)的好處是節(jié)省了數(shù)據(jù)庫(kù)存儲(chǔ)空間,轉(zhuǎn)移的時(shí)候可以直接將整個(gè)服務(wù)器的圖片打包轉(zhuǎn)移。

訪問(wèn)的時(shí)候,前面可以拼接域名和指定的路徑,這些后臺(tái)可以輕松獲取到,然后拼接上服務(wù)器的路徑,我們就可以直接在網(wǎng)頁(yè)上訪問(wèn)到圖片了。

這是很常見(jiàn)的圖片數(shù)據(jù)庫(kù)保存方式,和直接把圖片的二進(jìn)制存入數(shù)據(jù)庫(kù),這樣的方式便于檢索,占用空間小。當(dāng)然,目前主流都采用oss來(lái)單獨(dú)存儲(chǔ)文件了,就是有專門(mén)的文件服務(wù)器,這個(gè)時(shí)候,一般存儲(chǔ)的是完整的圖片路徑。

php圖片保存到數(shù)據(jù)庫(kù)

1.圖片轉(zhuǎn)換 將上傳的圖片讀取到一個(gè)字符串中,再用base64對(duì)數(shù)據(jù)進(jìn)行編碼 $img =base64_encode(file_get_contents($_FILES['file_head']['tmp...

2.顯示圖片 imgsrc="{$base64String}" 這樣就能把圖片顯示出來(lái)了

本文標(biāo)題:php保存圖片到數(shù)據(jù)庫(kù),php上傳圖片存儲(chǔ)
轉(zhuǎn)載來(lái)源:http://www.rwnh.cn/article14/dsigjde.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供搜索引擎優(yōu)化、微信小程序、Google域名注冊(cè)、定制網(wǎng)站、微信公眾號(hào)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

搜索引擎優(yōu)化
海林市| 赤水市| 合作市| 乌鲁木齐市| 沙河市| 乐亭县| 临安市| 涟水县| 黔江区| 长子县| 建水县| 和静县| 改则县| 渑池县| 鱼台县| 申扎县| 靖州| 九龙县| 昂仁县| 庆城县| 长丰县| 集贤县| 宿迁市| 伊通| 利津县| 汾西县| 祥云县| 顺义区| 福鼎市| 梁河县| 开鲁县| 张掖市| 乐山市| 福清市| 巴青县| 葫芦岛市| 宜川县| 上饶市| 赤壁市| 泗水县| 乐业县|