PHP文件上傳-3.7PHP高級教程

通過 PHP,可以把文件上傳到服務器。

目前創新互聯建站已為上千家的企業提供了網站建設、域名、網頁空間、網站運營、企業網站設計、陜西網站維護等服務,公司將堅持客戶導向、應用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協力一起成長,共同發展。

創建一個文件上傳表單

允許用戶從表單上傳文件是非常有用的。

請看下面這個供上傳文件的 HTML 表單:

<html><body><form action="upload_file.php" method="post"enctype="multipart/form-data"><label for="file">Filename:</label><input type="file" name="file" id="file" /> <br /><input type="submit" name="submit" value="Submit" /></form></body></html>

請留意如下有關此表單的信息:

<form> 標簽的 enctype 屬性規定了在提交表單時要使用哪種內容類型。在表單需要二進制數據時,比如文件內容,請使用 "multipart/form-data"。

<input> 標簽的 type="file" 屬性規定了應該把輸入作為文件來處理。舉例來說,當在瀏覽器中預覽時,會看到輸入框旁邊有一個瀏覽按鈕。

注釋:允許用戶上傳文件是一個巨大的安全風險。請僅僅允許可信的用戶執行文件上傳操作。

創建上傳腳本

"upload_file.php" 文件含有供上傳文件的代碼:

<?phpif ($_FILES["file"]["error"] > 0) { echo "Error: " . $_FILES["file"]["error"] . "<br />"; }else { echo "Upload: " . $_FILES["file"]["name"] . "<br />"; echo "Type: " . $_FILES["file"]["type"] . "<br />"; echo "Size: " . ($_FILES["file"]["size"] / 1024) . " Kb<br />"; echo "Stored in: " . $_FILES["file"]["tmp_name"]; }?>

通過使用 PHP 的全局數組 $_FILES,你可以從客戶計算機向遠程服務器上傳文件。

第一個參數是表單的 input name,第二個下標可以是 "name", "type", "size", "tmp_name" 或 "error"。就像這樣:

$_FILES["file"]["name"] - 被上傳文件的名稱$_FILES["file"]["type"] - 被上傳文件的類型$_FILES["file"]["size"] - 被上傳文件的大小,以字節計$_FILES["file"]["tmp_name"] - 存儲在服務器的文件的臨時副本的名稱$_FILES["file"]["error"] - 由文件上傳導致的錯誤代碼

這是一種非常簡單文件上傳方式。基于安全方面的考慮,您應當增加有關什么用戶有權上傳文件的限制。

上傳限制

在這個腳本中,我們增加了對文件上傳的限制。用戶只能上傳 .gif 或 .jpeg 文件,文件大小必須小于 20 kb:

<?phpif ((($_FILES["file"]["type"] == "image/gif")|| ($_FILES["file"]["type"] == "image/jpeg")|| ($_FILES["file"]["type"] == "image/pjpeg"))&& ($_FILES["file"]["size"] < 20000)) { if ($_FILES["file"]["error"] > 0) { echo "Error: " . $_FILES["file"]["error"] . "<br />"; } else { echo "Upload: " . $_FILES["file"]["name"] . "<br />"; echo "Type: " . $_FILES["file"]["type"] . "<br />"; echo "Size: " . ($_FILES["file"]["size"] / 1024) . " Kb<br />"; echo "Stored in: " . $_FILES["file"]["tmp_name"]; } }else { echo "Invalid file"; }?>

注釋:對于 IE,識別 jpg 文件的類型必須是 pjpeg,對于 FireFox,必須是 jpeg。

保存被上傳的文件

上面的例子在服務器的 PHP 臨時文件夾創建了一個被上傳文件的臨時副本。

這個臨時的復制文件會在腳本結束時消失。要保存被上傳的文件,我們需要把它拷貝到另外的位置:

<?phpif ((($_FILES["file"]["type"] == "image/gif")|| ($_FILES["file"]["type"] == "image/jpeg")|| ($_FILES["file"]["type"] == "image/pjpeg"))&& ($_FILES["file"]["size"] < 20000)) { if ($_FILES["file"]["error"] > 0) { echo "Return Code: " . $_FILES["file"]["error"] . "<br />"; } else { echo "Upload: " . $_FILES["file"]["name"] . "<br />"; echo "Type: " . $_FILES["file"]["type"] . "<br />"; echo "Size: " . ($_FILES["file"]["size"] / 1024) . " Kb<br />"; echo "Temp file: " . $_FILES["file"]["tmp_name"] . "<br />"; if (file_exists("upload/" . $_FILES["file"]["name"])) { echo $_FILES["file"]["name"] . " already exists. "; } else { move_uploaded_file($_FILES["file"]["tmp_name"], "upload/" . $_FILES["file"]["name"]); echo "Stored in: " . "upload/" . $_FILES["file"]["name"]; } } }else { echo "Invalid file"; }?>

上面的腳本檢測了是否已存在此文件,如果不存在,則把文件拷貝到指定的文件夾。

注釋:這個例子把文件保存到了名為 "upload" 的新文件夾。

文章標題:PHP文件上傳-3.7PHP高級教程
網址分享:http://www.kartarina.com/article10/dghhogo.html

成都網站建設公司_創新互聯,為您提供面包屑導航外貿網站建設小程序開發網站收錄靜態網站移動網站建設

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

網站托管運營
主站蜘蛛池模板: 粉嫩大学生无套内射无码卡视频 | 久久精品aⅴ无码中文字字幕不卡| 亚洲一区二区三区无码中文字幕| 精品久久久无码人妻中文字幕豆芽 | 国产AV无码专区亚汌A√| 亚洲AV无码专区国产乱码不卡| 精品久久久无码中文字幕边打电话| 无码无套少妇毛多18p| 国产乱子伦精品免费无码专区| 国产成人无码综合亚洲日韩| 亚洲国产精品无码久久98 | 无码人妻少妇伦在线电影| 亚洲VA成无码人在线观看天堂| 无码av大香线蕉伊人久久| 熟妇无码乱子成人精品| 国产成人无码精品一区二区三区| 午夜麻豆国产精品无码| 久久精品无码专区免费东京热 | 免费无码成人AV在线播放不卡| 人妻无码久久精品| 毛片一区二区三区无码| 无码av最新无码av专区| 亚洲精品无码成人片久久| 西西4444www大胆无码| 精品无码一区二区三区爱欲 | 99久久无码一区人妻a黑| 久久久久亚洲AV成人无码网站| 亚洲?V无码乱码国产精品| 无码中文字幕乱码一区 | 无码人妻AV免费一区二区三区| AV无码小缝喷白浆在线观看| 人妻无码一区二区三区| 亚洲AV无码AV日韩AV网站| 最新亚洲春色Av无码专区| av大片在线无码免费| 亚洲精品无码久久| 成人h动漫精品一区二区无码| 久久中文字幕无码专区| 亚洲色无码专区在线观看| 精品无码一级毛片免费视频观看| 亚洲人成人无码网www国产|