<form
> 標籤的enctype
屬性規定了在提交表單時要使用哪種內容型別。在表單需要二進位制資料時,比如檔案內容,請使用multipart/form-data
。
<input
> 標籤的type="file"
屬性規定了應該把輸入作為檔案來處理。舉例來說,當在瀏覽器中預覽時,會看到輸入框旁邊有乙個瀏覽按鈕。
通過使用 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"]
- 由檔案上傳導致的錯誤**
有時我們需要對使用者上傳的檔案型別進行限制,**如下:
<?php
//png且體積小於200kb
if( $_files["file"]["type"] == "image/png" && $_files["file"]["size"] < 204800)else
}else
?>
// 判斷當期目錄下的 upload 目錄是否存在該檔案
if(file_exists("upload/".$_files["file"]["name"]))else
php.ini中的引數:
file_uploads //是否允許上傳檔案,預設on
upload_tmp_dir //上傳檔案防止的臨時目錄,未指定則使用系統預設位置
upload_max_filesize //允許上傳檔案的大小的最大值,預設為2m
post_max_size //控制採用post方法進行一次表單提交中php所能接受的最大資料量,如果希望用php檔案上傳,則此值要改為比upload_max_filesize要大
max_input_time //以秒為單位對通過post/get/put方式接受資料時間進行限制。
memory_limit //為了避免正在執行的指令碼大量使用系統記憶體,php允許定義記憶體使用限額。通過設定此引數來制定單個指令碼程式可以使用的最大記憶體容量,應適當大於post_max_size值
max_execution_time //用來設定在強制終止指令碼前php等待指令碼執行完畢的時間,單位秒。次選項可限制死迴圈指令碼,但當存在乙個長時間的合法活動時(如:上傳大檔案),這項功能也會導致操作失敗。這樣情況下必須考慮將此變數增加。
$filename = $_get['filename']; //得到檔名
header( "content-disposition: attachment; filename=".$filename); //告訴瀏覽器通過附件形式來處理檔案
readfile($filename); //讀取檔案內容
至此,php檔案上傳已經介紹完畢,熟悉整套操作流程,方法不是問題,加油!
PHP檔案上傳及其突破上傳檔案大小限制
php如何實現檔案上傳 1.表單部分 允許使用者上傳檔案,在html表單的宣告中要加上乙個上傳的屬性 enctype multipart form data 表單的method必須是post 表單選項max file size隱藏域用於限制上傳檔案大小,它必須放在檔案表單元素前面,單位為位元組。如 ...
php mysql上傳檔案 PHP 檔案上傳
通過 php,可以把檔案上傳到伺服器。建立乙個檔案上傳表單 允許使用者從表單上傳檔案是非常有用的。請看下面這個供上傳檔案的 html 表單 芝麻教程 web3.xin 檔名 將以上 儲存到 form.html 檔案中。有關上面的 html 表單的一些注意項列舉如下 標籤的 enctype 屬性規定了...
雙檔案上傳突破利用
這個漏洞在南方cms 上出現的 主要是上傳時候利用bp抓包 然後滑鼠右鍵吧資料報傳送到repeater模組 找到你上傳的包內容 一般是 61234564788 content disposition form data name filename filename 1.png 內容 61234564...