1、新建一個1107.php文件,在文件中寫出以下代碼:php
<DOCTYPE html>html
<html>安全
<head>服務器
<title>文件上傳</title>ide
</head>函數
<body>post
<form method="post" action="t2.php" enctype="multipart/form-data">spa
<input type="hidden" name="MAX_FILE_SIZE" value="1000000"/><br>orm
選擇文件:<input type="file" name="myfile"/><br>htm
<input type="submit" value="上傳文件"/><br>
</form>
</body>
</html>
二、新建一個t2.php文件,在文件中寫出以下代碼:
$allowtype=array("gif","png","jpg"); //設置容許上傳的文件類型
$size=1000000; //設置容許上傳的文件大小
$path="./uploads"; //設置上傳後保存文件的路徑
//判斷文件是否能夠成功上傳到服務器,$_FILES["myfile"]["error"]爲0表示上傳成功
if($_FILES["myfile"]["error"]>0){
echo "文件上傳錯誤";
switch($_FILES["myfile"]["error"]){
case 1:die("上傳文件大小超出了PHP配置文件中的約定值"); break;
case 2:die("上傳文件大小超出了表單中中的約定值"); break;
case 3:die("文件只被部分上載"); break;
case 4:die("沒有上傳任何文件"); break;
default :die("未知錯誤"); break;
}
}
//經過文件的後綴名,判斷上傳的文件是否爲容許的類型
$hz=array_pop(explode(".",$_FILES["myfile"]["name"]));
if(!in_array($hz,$allowtype)){
die("這個文件後綴是<b>{$hz}</b>,不是容許的文件類型!");
}
//判斷上傳的文件是否爲容許大小
if($_FILES["myfile"]["name"]>$size){
die("超過了容許的<b>{$size}</b>字節大小");
}
//爲了系統安全,也爲了同名文件不被覆蓋,上傳後將文件名使用系統定義
$filename=date("YmdHis").rand(100,999).".".$hz;
//判斷是否爲上傳文件
if(is_uploaded_file($_FILES["myfile"]["tmp_name"])){
if(!move_uploaded_file($_FILES["myfile"]["tmp_name"],$path."/".$filename)){
die("問題:不能將文件移動到指定目錄");
}
}else{
die("問題:上傳文件{$_FILES["myfile"]["name"]}不是一個合法文件!");
}
//若是文件上傳成功則輸出
echo "文件{$upfile}上傳成功,保存在目錄{$path}中,文件大小爲{$_FILES["myfile"]["size"]}字節";
執行上例時,須要在當前目錄建立一個uploads目錄(即文件夾)!
die()函數輸出一條消息,並退出當前腳本
該函數是 exit() 函數的別名。
die(status)
參數 | 描述 |
---|---|
status | 必需。規定在退出腳本以前寫入的消息或狀態號。狀態號不會被寫入輸出。 |
若是 status 是字符串,則該函數會在退出前輸出字符串。
若是 status 是整數,這個值會被用做退出狀態。退出狀態的值在 0 至 254 之間。退出狀態 255 由 PHP 保留,不會被使用。狀態 0 用於成功地終止程序。
註釋:若是 PHP 的版本號大於等於 4.2.0,那麼在 status 是整數的狀況下,不會輸出該參數。