配置php.ini實現(xiàn)PHP文件上傳功能
昨天分享了在PHP網(wǎng)站開發(fā)中如何在php.ini中配置實現(xiàn)session功能的PHP教程,今天繼續(xù)分享在利用PHP實現(xiàn)文件上傳功能時幾點關(guān)鍵php.ini的配置。
說到在php.ini中的文件上傳的配置,其實在之前介紹PHP文件上傳功能代碼實例教程以及Jquery AjaxUpload實現(xiàn)文件上傳功能代碼實例教程時我都有所提及。PHP文件上傳功能配置主要涉及php.ini配置文件中的upload_tmp_dir、upload_max_filesize、post_max_size等選項。
php.ini中文件上傳功能配置選項說明
打開php.ini配置文件找到File Uploads
file_uploads = On
默認允許HTTP文件上傳,此選項不能設(shè)置為OFF。
upload_tmp_dir =
默認為空,此選項在手動配置PHP運行環(huán)境時,也容易遺忘,如果不配置這個選項,文件上傳功能就無法實現(xiàn),這個選項設(shè)置的是文件上傳時存放文件的臨時目錄,你必須給這個選項賦值,比如upload_tmp_dir ='/leapsoulcn',代表在C盤目錄下有一個leapsoulcn目錄,和session配置一樣,如果你是在linux環(huán)境下,你必須賦予這個目錄可寫權(quán)限。
如何上傳超過8M的大文件?
上傳大文件主要涉及配置upload_max_filesize和post_max_size兩個選項。
php.ini配置文件中的默認文件上傳大小為2M,php初學(xué)者容易犯的一個錯誤是在編寫文件上傳功能時通過設(shè)置上傳文件最大大小的表單區(qū)域,即允許上傳文件的最大值,max_file_size(隱藏值域)的值來規(guī)定上傳文件的大小,其實一般別人可以繞過這個值,所以安全起見,最好是在php.ini配置文件中配置upload_max_filesize選項,設(shè)定文件上傳的大小。
默認upload_max_filesize = 2M,即文件上傳的大小為2M,如果你想上傳超過8M的文件,比如20M,你必須設(shè)定upload_max_filesize = 20M。
但是光設(shè)置upload_max_filesize = 20M還是無法實現(xiàn)大文件的上傳功能,你必須修改php.ini配置文件中的post_max_size選項,其代表允許POST的數(shù)據(jù)最大字節(jié)長度,默認為8M。如果POST數(shù)據(jù)超出限制,那么$_POST和$_FILES將會為空。要上傳大文件,你必須設(shè)定該選項值大于upload_max_filesize指令的值,我一般設(shè)定upload_max_filesize和post_max_size值相等。另外如果啟用了內(nèi)存限制,那么該值應(yīng)當(dāng)小于memory_limit選項的值。
文件上傳的其他注意事項
在上傳大文件時,你會有上傳速度慢的感覺,當(dāng)超過一定的時間,會報腳本執(zhí)行超過30秒的錯誤,這是因為在php.ini配置文件中max_execution_time配置選項在作怪,其表示每個腳本最大允許執(zhí)行時間(秒),0 表示沒有限制。你可以適當(dāng)調(diào)整max_execution_time的值,不推薦設(shè)定為0。
至此,在php.ini配置文件中對文件上傳選項進行配置的PHP教程就介紹完畢了,通過上面的步驟實踐與學(xué)習(xí),再結(jié)合PHP程序,文件上傳功能就可以實現(xiàn)了。
下面是一些補充:
本文介紹了如何配置php.ini實現(xiàn)PHP文件上傳功能。其中涉及到php.ini配置文件中的upload_tmp_dir、upload_max_filesize、post_max_size等選項,這些選項是文件上傳成敗的關(guān)鍵。我們以php.5.3.5的Windows版本為例說明。
php.ini中文件上傳功能配置選項說明
用文本工具(推薦EditPlus)打開php.ini 配置文件,查找 File Uploads ,在這個區(qū)域有以下3個選項:
file_uploads = On
是否允許HTTP文件上傳。默認值為On允許HTTP文件上傳,此選項不能設(shè)置為Off。
upload_tmp_dir =
文件上傳的臨時存放目錄。如果沒指定則PHP會使用系統(tǒng)默認的臨時目錄。該選項默認為空,此選項在手動配置PHP運行環(huán)境時,也容易遺忘,如果不配置這個選項,文件上傳功能就無法實現(xiàn),你必須給這個選項賦值,比如upload_tmp_dir = "d:/fileuploadtmp" ,代表在D盤目錄下有一個fileuploadtmp目錄,并且給這目錄讀寫權(quán)限。
upload_max_filesize = 2M
上傳文件的最大尺寸。這個選項默認值為2M,即文件上傳的大小為2M,如果你想上傳一個50M的文件,你必須設(shè)定 upload_max_filesize = 50M。
但是僅設(shè)置upload_max_filesize = 50M 還是無法實現(xiàn)大文件的上傳功能,我們還必須修改php.ini文件中的 post_max_size 選項。
繼續(xù)在 php.ini 中查找 Data Handling ,在這個區(qū)域有1個選項:
post_max_size = 8M
指通過表單POST給PHP的所能接收的最大值,包括表單里的所有值。默認為8M。如果POST數(shù)據(jù)超出限制,那么$_POST和$_FILES將會為空。
要上傳大文件,你必須設(shè)定該選項值大于upload_max_filesize選項的值,例如你設(shè)置了upload_max_filesize = 50M ,這里可以把post_max_size = 100M。
另外如果啟用了內(nèi)存限制,那么該值應(yīng)當(dāng)小于memory_limit 選項的值。
繼續(xù)在 php.ini 中查找 Resource Limits ,在這個區(qū)域有3個選項:
max_execution_time = 30
每個PHP頁面運行的最大時間值(單位秒),默認30秒。當(dāng)我們上傳一個較大的文件,例如50M的文件,很可能要幾分鐘才能上傳完,但php默認頁面最久執(zhí)行時間為30秒,超過30秒,該腳本就停止執(zhí)行,這就導(dǎo)致出現(xiàn)無法打開網(wǎng)頁的情況。因此我們可以把值設(shè)置的較大些,如 max_execution_time = 600。 如果設(shè)置為0,則表示無時間限制。
max_input_time = 60
每個PHP腳本解析請求數(shù)據(jù)所用的時間(單位秒),默認60秒。當(dāng)我們上傳大文件時,可以將這個值設(shè)置的較大些。 如果設(shè)置為0,則表示無時間限制。
memory_limit = 128M
這個選項用來設(shè)置單個PHP腳本所能申請到的最大內(nèi)存空間。這有助于防止寫得不好的腳本消耗光服務(wù)器上的可用內(nèi)存。如果不需要任何內(nèi)存上的限制將其設(shè)為 -1。
php5.2.0以前的版本默認8M; php.5.2.0版本默認為16M。php 5.2.0之后的版本默認為 128M;
php.ini 配置上傳文件功能示例
假設(shè)要上傳一個50M的大文件。配置 php.ini 如下:
file_uploads = On
upload_tmp_dir = "d:/fileuploadtmp"
upload_max_filesize = 50M
post_max_size = 100M
max_execution_time = 600
max_input_time = 600
memory_limit = 128M
提示:需要保持 memory_limit > post_max_size > upload_max_filesize
此例僅供參考,你可以根據(jù)實際情況調(diào)整。
相關(guān)文章
PHP面向?qū)ο蟪绦蛟O(shè)計高級特性詳解(接口,繼承,抽象類,析構(gòu),克隆等)
這篇文章主要介紹了PHP面向?qū)ο蟪绦蛟O(shè)計高級特性,結(jié)合實例形式分析了php面向?qū)ο蟪绦蛟O(shè)計中所涉及的靜態(tài)屬性、常量屬性、接口、繼承、抽象類、析構(gòu)、克隆等概念與使用技巧,需要的朋友可以參考下2016-12-12
php判斷文件上傳類型及過濾不安全數(shù)據(jù)的方法
這篇文章主要介紹了php判斷文件上傳類型及過濾不安全數(shù)據(jù)的方法,可實現(xiàn)對$_COOKIE、$_POST、$_GET中不安全字符的過濾功能,非常具有實用價值,需要的朋友可以參考下2014-12-12
mysql_fetch_row,mysql_fetch_array,mysql_fetch_assoc的區(qū)別
一直以來,有很多初學(xué)者搞不懂這些Mysql中從查詢結(jié)果集中取得數(shù)據(jù)的函數(shù)之間有什么區(qū)別,今天我就來秀一把,在秀之前先給大家一段PHP實例2009-04-04

