drupal檔案上傳表單的例子
複製代碼 代碼如下:function upload_form() {
$form = array();
// If this #attribute is not present, upload will fail on submit
$form['#attributes']['enctype'] = 'multipart/form-data';
$form['file_upload'] = array(
'#title' => t('Upload file'),
'#type' => 'file',
);
$form['submit_upload'] = array(
'#type' => 'submit',
'#value' => 'Submit'
);
return $form;
}
function upload_submit($form, &$form_state) {
$validators = array();
$dest = file_directory_path();
$file = file_save_upload('file_upload', $validators, $dest);
//$file will be 0 if the upload doesn't exist, or the $dest directory
//isn't writable
if ($file != 0) {
$file->filepath; // 檔案相對路徑
}
else {
form_set_error('myform', t("Failed to save the file."));
}
}
PHP檔案上傳功能代碼執行個體教程
在PHP網站開發中,PHP程式如何?檔案上傳功能,一直是新手的課題。而且檔案上傳功能一般都用得著,比片上傳。今天就結合具體代碼執行個體和詳細註解和大家分享如何編寫PHP檔案上傳代碼,適合php初學者學習。
PHP代碼執行個體主要講述的是圖片上傳,看懂程式後你可以修改相關檔案類型就可以實現其他檔案的上傳功能。
編程環境
PHP5.2.4,基本上PHP4.3以上版本,此代碼都可以使用
準備工作
檢查upload_tmp_dir項
如果PHP的開發環境是自行搭建的,你需要在編寫檔案上傳程式前編輯php.ini檔案,找到並編輯upload_tmp_dir選項,此項用來設定檔案上傳至伺服器時的臨時檔案夾,比如upload_tmp_dir = E:/phpos/uploads,然後再重啟Apache。如果PHP的開發環境使用的是傻瓜式一鍵安裝包,一般upload_tmp_dir都是設定好了的,你也可以用phpinfo()函數查看下配置。
編寫一個upload檔案,設定檔案上傳表單 複製代碼 代碼如下:<form enctype="multipart/form-data" action="upload.php" method="post">
<input type="hidden" name="max_file_size" value="100000">
<input name="userfile" type="file">
<input type="submit" value="上傳檔案">
</form>
注意
1、表單中enctype=”multipart/form-data”必須指定,以便讓伺服器知道檔案帶有常規的表單資訊。
2、必須有一個可以設定上傳檔案最大長度的表單區域,即允許上傳檔案的最大值(按位元組計算),它是隱藏範圍,即max_file_size,通過設定其Value(值)可以限制上傳檔案的大小,避免使用者在花時間等待上傳大檔案之後才發現該檔案太大了的麻煩。但是一般別人可以繞過這個值,所以安全起見,最好是在php.ini檔案中配置upload_max_filesize選項,設定檔案上傳的大小,預設是2M。
檔案上傳程式 複製代碼 代碼如下:function uploadfile($type,$name,$ext,$size,$error,$tmp_name,$targetname,$upload_dir)
{
$MAX_SIZE = 2000000;
$FILE_MIMES = array('image/pjpeg','image/jpeg','image/jpg','image/gif','image/png');
$FILE_EXTS = array('.jpg','.gif','.png','.JPG','.GIF','.PNG');
$file_path = $upload_dir.$targetname;
if(!is_dir($upload_dir))
{
if(!mkdir($upload_dir))
die("檔案上傳目錄不存在並且無法建立檔案上傳目錄");
if(!chmod($upload_dir,0755))
die("檔案上傳目錄的許可權無法設定為可讀可寫");
}
if($size>$MAX_SIZE)
die("上傳的檔案大小超過了規定大小");
if($size == 0)
die("請選擇上傳的檔案");
if(!in_array($type,$FILE_MIMES) || !in_array($ext,$FILE_EXTS))
die("請上傳符合要求的檔案類型");
if(!move_uploaded_file($tmp_name, $file_path))
die("複製檔案失敗,請重新上傳");
switch($error)
{
case 0:
return ;
case 1:
die("上傳的檔案超過了 php.ini 中 upload_max_filesize 選項限制的值");
case 2:
die("上傳檔案的大小超過了 HTML 表單中 MAX_FILE_SIZE 選項指定的值");
case 3:
die("檔案只有部分被上傳");
case 4:
die("沒有檔案被上傳");
}
}
參數說明
$type,$name,$size,$error,$tmp_name對應全域變數$_FILES中的相關變數,即:
$_FILES['userfile']['type']:檔案的MIME類型,需要瀏覽器提供該資訊的支援,例片類型“image/gif”。
$_FILES['userfile']['name']:用戶端檔案的原名稱。
$_FILES['userfile']['size']:已上傳檔案的大小,單位為位元組。
$_FILES['userfile']['tmp_name']:檔案被上傳後在服務端儲存的臨時檔案名稱。
$_FILES['userfile']['error']:和該檔案上傳相關的錯誤碼,即
值:0:沒有錯誤發生,檔案上傳成功。
值:1:上傳的檔案超過了 php.ini 中 upload_max_filesize 選項限制的值。
值:2:上傳檔案的大小超過了 HTML 表單中 MAX_FILE_SIZE 選項指定的值。
值:3:檔案只有部分被上傳。
值:4:沒有檔案被上傳。
$ext:上傳副檔名
$targetname:檔案上傳後的最終檔案名稱
$upload_dir:上傳至哪個目錄下,採用的是相對路徑
注釋:
第3行~第6行:設定圖片檔案上傳的大小,以及檔案的MIME類型以及副檔名,由於此代碼為圖片檔案上傳程式,所以兩個數組中羅列了所有的圖片類型,比如PNG,GIF,JEPG等。
第17行~第24行:如果檔案是空的,size等於0;如果圖片檔案的副檔名或者類型不符,則跳出。
第26行:move_uploaded_file函數的功能是將upload_tmp_dir設定的服務端臨時目錄中的檔案移至由$file_path指定的檔案,注意如果目標檔案已存在則覆蓋目標檔案
如何上傳多個檔案?比如同時上傳3個檔案
只需將 複製代碼 代碼如下:<input name="userfile" type="file">
改成 複製代碼 代碼如下:<input name="userfile[]" type="file">
<input name="userfile[]" type="file">
<input name="userfile[]" type="file">
對應的在調用此函數時,$_FILES['userfile']['name'][0],代表第一個檔案的相關檔案資訊,依此類推,其他也一樣。
總結
此函數是PHP檔案上傳中最簡單的核心代碼,圖片上傳只是其中一種,只需要修改或者擴充$FILE_MIMES和$FILE_EXTS數組的相關資訊,即可實現其他類型的檔案上傳功能。在函數的外圍,根據自己的需要編寫相關的其他代碼即可實現其他功能,比如和資料庫的關聯等。