PHP的檔案上傳處理驗證樣本

來源:互聯網
上載者:User

最近遇到一個事,把自己坑了好久,我想說說我開始的想法

PHP的上傳機制封裝的很完全,基本幾行代碼就能實現,他的實現流程是這樣的

UPLOAD到檔案到臨時目錄中?>使用move_uploadde_file()到指定的目錄

這就是PHP上傳流程,或者你在中途再進行一些驗證。例如判斷是不是通過upload方式提交的文檔,或者檔案的擴充是不是我們允許的

等等一系列驗證。我給出簡單的代碼也算是拋磚引玉了。

$targetFolder = '/uploads'; // 定義根目錄if (!empty($_FILES)) {    $tempFile = $_FILES['Filedata']['tmp_name'];if(is_uploaded_file($tempFile)){    $targetPath = $_SERVER['DOCUMENT_ROOT'] . $targetFolder;    $targetFile = rtrim($targetPath,'/') . '/' . $_FILES['Filedata']['name'];    $fileTypes = array('jpg','jpeg','gif','png'); // 允許的尾碼擴充    $fileParts = pathinfo($_FILES['Filedata']['name']);    if (in_array($fileParts['extension'],$fileTypes)) {        move_uploaded_file($tempFile,$targetFile);        echo '1';    } else {        echo '非法上傳文檔.';    }}else{   echo "非法上傳檔案";}}

上面的這種方式基本就滿足了檔案上傳。但我需要的不是這樣的。


 

 需求:先點擊上傳文檔,然後選擇上傳檔案,JS上傳後會返回一個值,顯示目前時間戳問名稱的檔案在文檔名稱這個框框中。

然後點擊提交後,提交表單。

伺服器處理提交的表單,對上傳的檔案進行重新命名。

問題也隨之而來了,伺服器是IIS的,然後它是用的映射的方式實現的虛擬跟目錄。

這樣的話$_SERVER[‘DOCUMENT_ROOT’]就不在PHP網站的根目錄

雖然完成了上傳的功能,但無法下載這個檔案。從伺服器的安全考慮,還是打算把檔案放在PHP網站內。

然後我就陷進了一個思維局限中。

再仔細想一想:

為何我不用實現PHP的上傳機制的方式在重複一次。

PHP不是將檔案先放到臨時目錄裡面嗎?然後我為嘛假設JS上傳成功後的目錄也是一個臨時目錄,

然後在再一次提交表單的時候進行檔案複製。到指定的目錄這樣就完成了需要的功能。

PHP有一個檔案複製函數Copy(); 然後在配合rename()函數。這樣就可以完成上傳後檔案的第二次移動和重新命名了。

注意:在window平台下如果複製一個零位元組的檔案,copy() 將返回 FALSE ,但檔案也會被正確複製。

然後PHP在檔案處理上,積極的參考了Liunx的檔案處理機制。PHP的檔案操作效率,這跟I/O對寫和作業系統有關。

總結:其實解決問題的方式很多,而且不要給自己畫圈從而限定自己的思維。

 

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.