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數組的相關信息,即可實現其他類型的文件上傳功能。在函數的外圍,根據自己的需要編寫相關的其他代碼即可實現其他功能,比如和數據庫的關聯等。