php文件上傳代碼編寫過程
1. 先判斷是否上傳文件
2. 如果有再來判斷上傳中是否出錯
3. 如果出錯,則提示出錯信息
4. 如查沒出錯,再判斷文件類型
5. 如果類型符合條件,再判斷指定目錄中有沒有存在該文件
6. 如果沒有就把該文件移至指定目錄
在php中上傳文件必須知道的幾個東西
$_FILES['myfile']['name'] 是指被上傳文件的名稱
$_FILES['myfile']['type'] 是指被上傳文件的類型
$_FILES['myfile']['size'] 是指被上傳文件的大小,單位為字節(B)
$_FILES['myfile']['tmp_name'] 是指被上傳文件存在服務器中的臨時副本文件名稱,文件被移動到指定目錄後臨文件將被自動消毀。
$_FILES['myfile']["error"] 是指由文件上傳中有可能出現的錯誤的狀態碼,關於各狀態含義後在會說明。
先來看一下HTML部分。
?<form action="upload.php" method="post" enctype="multipart/form-data">
上傳:<input type="file" name="myfile" />
<input type="submit" name="submit" value="上傳" />
</form>
說明:
form標答的action="upload.php"是指點擊這個form中的submit的時候,這個上傳命令會被發送到這個叫 upload.php的頁面去處理。method="post"是指以post方式去送,enctype="multipart/form-data"屬性規定了在提交這個表單時要使用哪種內容類型,在表單需要二進制數據時,比如文件內容,請使用"multipart/form-data",如果要上傳文件,這個屬性是必要的。input中的type="file"時,規定了應該把輸入作為文件來處理,並且在input後面會有一個浏覽的按鈕。
我們再來看一個PHP處理頁面 upload.php
代碼如下 復制代碼
<?php
if($_FILES['myfile']['name'] != '') {
if($_FILES['myfile']['error'] > 0) {
echo "錯誤狀態:" . $_FILES['myfile']['error'];
} else {
move_uploaded_file($_FILES['myfile']['tmp_name'] , "uploads/" . $FILES['myfile']['name']);
echo "<script>alert(上傳成功!);</script>";
}
} else{
echo "<script>alert(請上傳文件!);</script>";
}
?>
上面超級簡單,我們現在來升級一下
1、upload.php
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>ddd</title>
<meta http-equiv="content-type" content="text/html; charset=UTF-8">
</head>
<body>
<!--文件上傳要注意:1、要有enctyp,2、method="post"-->
<form enctype="multipart/form-data" action="uploadProcess.php" method="post" >
<table>
<tr><td>請填寫用戶名</td><td><input type="text" name="username"></td></tr>
<tr><td>請簡單介紹文件</td><td><textarea rows="7" cols="50" name="fileintro" style="width:300px;"></textarea></td></tr>
<tr><td>請上傳你的文件</td><td><input type="file" name="myfile"></td></tr>
<tr><td colspan="2"><input type="submit" value="上傳"><td></tr>
</table>
</form>
</body>
</html>
2、uploadProcess.php
代碼如下 復制代碼
<?php
//接收
$username=$_POST['username'];
$fileintro=$_POST['fileintro'];
//echo $username.$fileintro;
//獲取文件信息
/* echo "<pre>";
print_r($_FILES);
echo "</pre>";
*/
//獲取文件的大小
$file_size=$_FILES['myfile']['size'];
if($file_size>2*1024*1024){
echo "<script type='text/javascript'>window.alert('文件不能大於2M')</script>";
exit();
}
//獲取文件類型
$file_type=$_FILES['myfile']['type'];
if($file_type!="image/jpeg" && $file_type!="image/pjpeg"){
echo "文件類型只能是 jpg 格式";
exit();
}
//判斷上傳是否OK
if(is_uploaded_file($_FILES['myfile']['tmp_name'])){
//得到上傳的文件 轉存到你希望的目錄
$upload_file=$_FILES['myfile']['tmp_name'];
//防止圖片覆蓋問題,為每個用戶建立一個文件夾
$user_path=$_SERVER['DOCUMENT_ROOT']."/file/up/".$username;
if(!file_exists($user_path)){
mkdir ($user_path);
}
//$move_to_file=$user_path."/".$_FILES['myfile']['name'];
//防止用戶上傳用戶名相同的問題
$file_true_name=$_FILES['myfile']['name'];
$move_to_file=$user_path."/".time().rand(1,1000).substr($file_true_name,strripos($file_true_name,"."));
//echo $upload_file.$move_to_file;
//中文要轉碼
if(move_uploaded_file($upload_file,iconv("utf-8","gb2312","$move_to_file"))){
echo $_FILES['myfile']['name']."上傳成功";
}else{
echo "上傳失敗";
}
}else{
echo "上傳失敗";
}
?>
注意:
我舉個例子大家就知道,比如一個圖片文件 pic.jpg,我們用 strrchr處理,strrchr(pic.jpg,'.'),它將返回.jpg,明白了嗎?該函數返回指定字符在該字符串最後出現的位置後的字符。配合 substr() 我們就可以取到jpg,這樣我們就得到了文件的後綴名,來判斷上傳文件是否符合指定格式。本程序把指定的格式放在一個數組中,實際使用時可根據需要添加。
接下來看產生隨機數文件名部分, 我們看到mt_srand()這個函數,手冊上叫他“播下一個更好的隨機數發生器種子”,其實就是初始化一個隨機數的函數,參數是(double)microtime() * 1000000,這裡如果不這是參數就會自動設置個隨機數,當然這不符合我們的需要,如此一來,隨機數就具備一定的長度,保證了上傳文件不重名