|
首先來(lái)看下上傳部分的表單代碼:
復(fù)制代碼 代碼如下: <form method="post" action="upload.php" enctype="multipart/form-data">
<table border=0 cellspacing=0 cellpadding=0 align=center width="100%">
<tr>
<td width=55 height=20 align="center"><input type="hidden" name="MAX_FILE_SIZE" value="2000000">文件: </TD>
<td height="16">
<input name="file" type="file" value="瀏覽" >
< input type="submit" value="上傳" name="B1">
</td>
</tr>
</table>
</form>
這里有幾個(gè)要注意的地方,首先看這句<form method="post" action="upload.php" enctype="multipart/form-data">,這里我們采用POST方法,個(gè)別瀏覽器還支持PUT方法,當(dāng)然這需要對(duì)腳本進(jìn)行修改,我并不建議這么做。表單中必須設(shè)置enctype="multipart/form-data,這樣,服務(wù)器就知道上傳文件帶有常規(guī)表單信息,記住,這個(gè)是必須設(shè)置的。此外還需要一個(gè)隱藏域來(lái)限制上傳文件的最大長(zhǎng)度:<input type="hidden" name="MAX_FILE_SIZE" value="2000000">,這里name必須設(shè)置成MAX_FILE_SIZE,其值就是上傳文件的最大長(zhǎng)度,單位是B,這里我限制成2M。再看這句:<input name="file" type="file" value="瀏覽" >,type="file"說(shuō)明了文件類型,這樣一個(gè)基本的上傳文件接口就完成了,接下來(lái)講講如何用php來(lái)處理上傳的文件,此外你的php.ini中設(shè)置的上傳文件最大長(zhǎng)度可能會(huì)影響到你的實(shí)際上傳,請(qǐng)根據(jù)實(shí)際情況修改,另php的上傳是先傳到臨時(shí)目錄,在移至指定目錄的,了;臨時(shí)目錄的可根據(jù)需要修改,也可使用默認(rèn)值。
好的,表單提交upload.php,來(lái)看看這個(gè)頁(yè)面都有什么:
php代碼如下:
復(fù)制代碼 代碼如下:<?php
/*****************************************
Title :文件上傳詳解
Author:leehui1983(輝老大)
Finish Date :2006-12-28
*****************************************/
$uploaddir = "./files/";//設(shè)置文件保存目錄 注意包含/
$type=array("jpg","gif","bmp","jpeg","png");//設(shè)置允許上傳文件的類型
$patch="http://127.0.0.1/cr_downloadphp/upload/files/";//程序所在路徑
//獲取文件后綴名函數(shù)
function fileext($filename)
{
return substr(strrchr($filename, '.'), 1);
}
//生成隨機(jī)文件名函數(shù)
function random($length)
{
$hash = 'CR-';
$chars = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789abcdefghijklmnopqrstuvwxyz';
$max = strlen($chars) - 1;
mt_srand((double)microtime() * 1000000);
for($i = 0; $i < $length; $i++)
{
$hash .= $chars[mt_rand(0, $max)];
}
return $hash;
}
$a=strtolower(fileext($_FILES['file']['name']));
//判斷文件類型
if(!in_array(strtolower(fileext($_FILES['file']['name'])),$type))
{
$text=implode(",",$type);
echo "您只能上傳以下類型文件: ",$text,"<br>";
}
//生成目標(biāo)文件的文件名
else{
$filename=explode(".",$_FILES['file']['name']);
do
{
$filename[0]=random(10); //設(shè)置隨機(jī)數(shù)長(zhǎng)度
$name=implode(".",$filename);
//$name1=$name.".Mcncc";
$uploadfile=$uploaddir.$name;
}
while(file_exists($uploadfile));
if (move_uploaded_file($_FILES['file']['tmp_name'],$uploadfile)){
if(is_uploaded_file($_FILES['file']['tmp_name'])){
//輸出圖片預(yù)覽
echo "<center>您的文件已經(jīng)上傳完畢 上傳圖片預(yù)覽: </center><br><center><img src='$uploadfile'></center>";
echo"<br><center><a href='Javascript:history.go(-1)'>繼續(xù)上傳</a></center>";
}
else{
echo "上傳失敗!";
}
}
}
?>
剛看這些你可能有點(diǎn)暈~~,不過(guò)不要緊,聽我講完,你就會(huì)發(fā)現(xiàn)其實(shí)這玩意SO EASY!!首先我講下原理,該程序以上傳圖片為例,先判斷文件類型是否為圖片格式,若是則上傳文件,以隨機(jī)數(shù)和時(shí)間的組合重新命名文件(避免上傳文件重名,這樣做很有必要!),接著上傳文件到指定目錄,成功上傳則輸出上傳的圖片預(yù)覽。這里要對(duì)程序中一些函數(shù)作些解釋。先看return substr(strrchr($filename, '.'), 1), strrchar()函數(shù)有什么作用呢,我舉個(gè)例子大家就知道,比如一個(gè)圖片文件 pic.jpg,我們用 strrchr處理,strrchr(pic.jpg,'.'),它將返回.jpg,明白了嗎?該函數(shù)返回指定字符在該字符串最后出現(xiàn)的位置后的字符。配合 substr() 我們就可以取到j(luò)pg,這樣我們就得到了文件的后綴名,來(lái)判斷上傳文件是否符合指定格式。本程序把指定的格式放在一個(gè)數(shù)組中,實(shí)際使用時(shí)可根據(jù)需要添加。
接下來(lái)看產(chǎn)生隨機(jī)數(shù)文件名部分, 我們看到mt_srand()這個(gè)函數(shù),手冊(cè)上叫他“播下一個(gè)更好的隨機(jī)數(shù)發(fā)生器種子”,其實(shí)就是初始化一個(gè)隨機(jī)數(shù)的函數(shù),參數(shù)是(double)microtime() * 1000000,這里如果不這是參數(shù)就會(huì)自動(dòng)設(shè)置個(gè)隨機(jī)數(shù),當(dāng)然這不符合我們的需要,如此一來(lái),隨機(jī)數(shù)就具備一定的長(zhǎng)度,保證了上傳文件不重名。接著,我們調(diào)用判斷文件類型的函數(shù),并將其轉(zhuǎn)化為小寫strtolower(fileext($_FILES['file']['name'])),這里有個(gè)很關(guān)鍵的東東$_FILES ,這是個(gè)超級(jí)全局?jǐn)?shù)組,保存了需要處理的表單數(shù)據(jù),如果開啟了register_globals,也可以直接訪問(wèn),但這是不安全的。看剛才那個(gè)上傳接口<input name="file" type="file" value="瀏覽" >,根據(jù)這個(gè)表單名稱,我們可以得到很多信息:
$_FILES['file']['name']-- 得到文件名稱
$_FILES['file']['tmp_name']--得到臨時(shí)存儲(chǔ)位置
$_FILES['file']['size']--得到文件大小
$_FILES['file']['type']--得到文件MIME類型
得到這些信息,我們就可以輕松判斷文件的信息了,是不是很方便?^_^,接下來(lái)還有一些函數(shù)需要了解,file_exists()--判斷指定目錄是否存在,不存在我們當(dāng)然不能上傳(好像是廢話!),move_uploaded_file--將上傳文件移至指定目錄,is_uploaded_file--判斷文件是否已經(jīng)通過(guò)HTTP POST上傳。成功上傳,我們就輸出預(yù)覽,否則輸出上傳失敗!大功告成
大家可根據(jù)這個(gè)進(jìn)行擴(kuò)展,比如配合JS實(shí)現(xiàn)多文件上傳,如DZ的上傳效果,再深一點(diǎn)結(jié)合AJAX實(shí)現(xiàn)無(wú)刷新上傳,很多博客都有采用,最后播放下下兩篇原創(chuàng)文章的預(yù)告
1 我將把這個(gè)例子擴(kuò)展,增加后臺(tái)和數(shù)據(jù)庫(kù)部分,實(shí)現(xiàn)上傳文件管理,審核,將發(fā)布在原創(chuàng)區(qū)。
2 利用目錄函數(shù)實(shí)現(xiàn)文件管理,將發(fā)布在新手區(qū)
希望感興趣的朋友屆時(shí)觀看~~~,謝謝!!!!!!
php技術(shù):PHP文件上傳實(shí)例詳解!!!,轉(zhuǎn)載需保留來(lái)源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。