PHP經過長時間的發展,很多用戶都很了解PHP了,這裡我發表一下個人理解,和大家討論討論,對PHP上傳文件支持也越來越完美,在PHP 4.0.3以前我們只能用copy() 和 is_uploaded_file()方法結合來上傳文件,呵呵,其實就是這樣我們也會感覺到PHP相對於ASP來說上傳文件要方便很多,這也就是本人選擇PHP的一點小小的引以為豪的地方。
PHP上傳文件例:
- if (!copy($file, $file.’.bak’)) {
- print (”failed to copy $file…<br>n”);
- }
- is_uploaded_file(string filename)
如果 filename 所給出的文件是通過 HTTP POST 上傳的則返回 TRUE。
- move_uploaded_file(string filename, string destination)
本函數檢查並確保由 filename 指定的文件是合法的PHP上傳文件(即通過 PHP 的 HTTP POST 上傳機制所上傳的)。如果文件合法,則將其移動為由 destination 指定的文件。由三個函數的解釋就可以得到一個結論,move_uploaded_file()是copy()和is_uploaded_file()函數的結合,講了這麼半天大家用起這三個函數可能還會有些生疏,下面給大家兩個例子:首先,建立一個前台頁面,命名為index.html。
- <form enctype=”multipart/form-data” action=”_URL_” method=”post”>
- Send this file: <input name=”filename” type=”file”>
- <input type=”submit” value=”Send File”>
- </form>
1,下面是關於copy()和is_uploaded_file()方法上傳文件的方法(保存為:copy.php,上傳文件需要將index.html中的_URL_改為copy.php)
- <?php
- $path=”./uploadfiles/”;//上傳文件的路徑
- if(is_uploaded_file($filename))
- //特別注意這裡,傳遞給is_uploaded_file的為$filename,可不要傳遞$_FILES[”filename”][”name”]
- {
- $file1=$_FILES[”filename”][”name”];
- //注意這裡$_POST[]方法為PHP4.1.0及以上版本支持,PHP以下的版本要用$HTTP_POST_FILES[]方法
- $file2=$path.time().$file1;
- $flag=1;
- }
- if($flag) $result=copy($file1,$file2);
- if($result) echo “上傳成功!”;
- ?>
2,下面是關於move_uploaded_file()方法上傳文件的方法(保存為:move.php,上傳文件需要將index.html中的_URL_改為move.php)
- <?php
- $path=”./uploadfiles/”;//上傳路徑
- if($_FILES[”filename”][”name”])
- {
- $file1=$_FILES[”filename”][”name”];
- $file2 = $path.time().$file1;
- $flag=1;
- }
- if($flag) $result=move_uploaded_file($_FILES[”filename”][”tmp_name”],$file2);
- //特別注意這裡傳遞給move_uploaded_file的第一個參數為上傳到服務器上的臨時文件
- if($result) echo “上傳成功!”;
- ?>
文件上傳就講到這裡了,這只是兩個小程序,其實要完成文件上傳所要的代碼可不是這些就能了事的。一般還要有文件大小限制,文件擴展名選取,還有一些其它的安全方案。本人就寫到這了,大家有興趣寫個完善的文件上傳系統。呵呵!!!