配置php.ini实现PHP文件上传功能


Posted in PHP onNovember 27, 2014

昨天分享了在PHP网站开发中如何在php.ini中配置实现session功能的PHP教程,今天继续分享在利用PHP实现文件上传功能时几点关键php.ini的配置。

说到在php.ini中的文件上传的配置,其实在之前介绍PHP文件上传功能代码实例教程以及Jquery AjaxUpload实现文件上传功能代码实例教程时我都有所提及。PHP文件上传功能配置主要涉及php.ini配置文件中的upload_tmp_dir、upload_max_filesize、post_max_size等选项。

php.ini中文件上传功能配置选项说明

打开php.ini配置文件找到File Uploads

file_uploads = On

默认允许HTTP文件上传,此选项不能设置为OFF。

upload_tmp_dir =

默认为空,此选项在手动配置PHP运行环境时,也容易遗忘,如果不配置这个选项,文件上传功能就无法实现,这个选项设置的是文件上传时存放文件的临时目录,你必须给这个选项赋值,比如upload_tmp_dir ='/leapsoulcn',代表在C盘目录下有一个leapsoulcn目录,和session配置一样,如果你是在linux环境下,你必须赋予这个目录可写权限。

如何上传超过8M的大文件?

上传大文件主要涉及配置upload_max_filesize和post_max_size两个选项。

php.ini配置文件中的默认文件上传大小为2M,php初学者容易犯的一个错误是在编写文件上传功能时通过设置上传文件最大大小的表单区域,即允许上传文件的最大值,max_file_size(隐藏值域)的值来规定上传文件的大小,其实一般别人可以绕过这个值,所以安全起见,最好是在php.ini配置文件中配置upload_max_filesize选项,设定文件上传的大小。

默认upload_max_filesize = 2M,即文件上传的大小为2M,如果你想上传超过8M的文件,比如20M,你必须设定upload_max_filesize = 20M。

但是光设置upload_max_filesize = 20M还是无法实现大文件的上传功能,你必须修改php.ini配置文件中的post_max_size选项,其代表允许POST的数据最大字节长度,默认为8M。如果POST数据超出限制,那么$_POST和$_FILES将会为空。要上传大文件,你必须设定该选项值大于upload_max_filesize指令的值,我一般设定upload_max_filesize和post_max_size值相等。另外如果启用了内存限制,那么该值应当小于memory_limit选项的值。

文件上传的其他注意事项

在上传大文件时,你会有上传速度慢的感觉,当超过一定的时间,会报脚本执行超过30秒的错误,这是因为在php.ini配置文件中max_execution_time配置选项在作怪,其表示每个脚本最大允许执行时间(秒),0 表示没有限制。你可以适当调整max_execution_time的值,不推荐设定为0。

至此,在php.ini配置文件中对文件上传选项进行配置的PHP教程就介绍完毕了,通过上面的步骤实践与学习,再结合PHP程序,文件上传功能就可以实现了。

下面是一些补充:

本文介绍了如何配置php.ini实现PHP文件上传功能。其中涉及到php.ini配置文件中的upload_tmp_dir、upload_max_filesize、post_max_size等选项,这些选项是文件上传成败的关键。我们以php.5.3.5的Windows版本为例说明。

php.ini中文件上传功能配置选项说明
用文本工具(推荐EditPlus)打开php.ini 配置文件,查找 File Uploads ,在这个区域有以下3个选项:

file_uploads = On

是否允许HTTP文件上传。默认值为On允许HTTP文件上传,此选项不能设置为Off。

upload_tmp_dir =

文件上传的临时存放目录。如果没指定则PHP会使用系统默认的临时目录。该选项默认为空,此选项在手动配置PHP运行环境时,也容易遗忘,如果不配置这个选项,文件上传功能就无法实现,你必须给这个选项赋值,比如upload_tmp_dir = "d:/fileuploadtmp" ,代表在D盘目录下有一个fileuploadtmp目录,并且给这目录读写权限。

upload_max_filesize = 2M

上传文件的最大尺寸。这个选项默认值为2M,即文件上传的大小为2M,如果你想上传一个50M的文件,你必须设定 upload_max_filesize = 50M。
但是仅设置upload_max_filesize = 50M 还是无法实现大文件的上传功能,我们还必须修改php.ini文件中的 post_max_size 选项。

继续在 php.ini 中查找 Data Handling ,在这个区域有1个选项:

post_max_size = 8M

指通过表单POST给PHP的所能接收的最大值,包括表单里的所有值。默认为8M。如果POST数据超出限制,那么$_POST和$_FILES将会为空。
要上传大文件,你必须设定该选项值大于upload_max_filesize选项的值,例如你设置了upload_max_filesize = 50M ,这里可以把post_max_size = 100M。
另外如果启用了内存限制,那么该值应当小于memory_limit 选项的值。

继续在 php.ini 中查找 Resource Limits ,在这个区域有3个选项:

max_execution_time = 30

每个PHP页面运行的最大时间值(单位秒),默认30秒。当我们上传一个较大的文件,例如50M的文件,很可能要几分钟才能上传完,但php默认页面最久执行时间为30秒,超过30秒,该脚本就停止执行,这就导致出现无法打开网页的情况。因此我们可以把值设置的较大些,如 max_execution_time = 600。 如果设置为0,则表示无时间限制。

max_input_time = 60

每个PHP脚本解析请求数据所用的时间(单位秒),默认60秒。当我们上传大文件时,可以将这个值设置的较大些。 如果设置为0,则表示无时间限制。

memory_limit = 128M

这个选项用来设置单个PHP脚本所能申请到的最大内存空间。这有助于防止写得不好的脚本消耗光服务器上的可用内存。如果不需要任何内存上的限制将其设为 -1。
php5.2.0以前的版本默认8M; php.5.2.0版本默认为16M。php 5.2.0之后的版本默认为 128M;

php.ini 配置上传文件功能示例
假设要上传一个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

此例仅供参考,你可以根据实际情况调整。
 

PHP 相关文章推荐
十天学会php(2)
Oct 09 PHP
php 远程关机操作的代码
Dec 05 PHP
PHP的简易冒泡法代码分享
Aug 28 PHP
作为PHP程序员应该了解MongoDB的五件事
Jun 03 PHP
php生成缩略图填充白边(等比缩略图方案)
Dec 25 PHP
PHP生成数组再传给js的方法
Aug 07 PHP
PHP类型约束用法示例
Sep 28 PHP
php 生成加密公钥加密私钥实例详解
Jun 16 PHP
Yii2.0多文件上传实例说明
Jul 24 PHP
原生JS实现Ajax通过POST方式与PHP进行交互的方法示例
May 12 PHP
php操作redis数据库常见方法实例总结
Feb 20 PHP
php程序员应具有的7种能力小结
Nov 27 #PHP
分享最受欢迎的5款PHP框架
Nov 27 #PHP
PHP比你想象的好得多
Nov 27 #PHP
简单说说PHP优化那些事(经验分享)
Nov 27 #PHP
几个实用的PHP内置函数使用指南
Nov 27 #PHP
简单谈谈php中ob_flush和flush的区别
Nov 27 #PHP
浅谈php优化需要注意的地方
Nov 27 #PHP
You might like
php 过滤器实现代码
2010/08/09 PHP
让Json更懂中文(JSON_UNESCAPED_UNICODE)
2011/10/27 PHP
PHP使用strtotime计算两个给定日期之间天数的方法
2015/03/18 PHP
CodeIgniter配置之autoload.php自动加载用法分析
2016/01/20 PHP
php unicode编码和字符串互转的方法
2020/08/12 PHP
php 删除指定文件夹的实例讲解
2017/07/25 PHP
Thinkphp 框架扩展之行为扩展原理与实现方法分析
2020/04/23 PHP
鼠标图片振动代码
2006/07/06 Javascript
javascript 单选框,多选框美化代码
2008/08/01 Javascript
jquery1.83 之前所有与异步列队相关的模块详细介绍
2012/11/13 Javascript
jquery中的ajax方法怎样通过JSONP进行远程调用
2014/05/04 Javascript
ExtJs动态生成treepanel的Json格式
2015/07/19 Javascript
JS实现的跨浏览器解析XML文件实例
2016/06/21 Javascript
作为老司机使用 React 总结的 11 个经验教训
2017/04/08 Javascript
微信小程序动态显示项目倒计时效果
2017/06/13 Javascript
浅谈Node.js爬虫之网页请求模块
2018/01/11 Javascript
Layui 动态禁止select下拉的例子
2019/09/03 Javascript
解决vue bus.$emit触发第一次$on监听不到问题
2020/07/28 Javascript
浅析微信小程序自定义日历组件及flex布局最后一行对齐问题
2020/10/29 Javascript
在vue中使用eslint,配合vscode的操作
2020/11/09 Javascript
SpringBoot+Vue 前后端合并部署的配置方法
2020/12/30 Vue.js
Python基于PycURL实现POST的方法
2015/07/25 Python
对python抓取需要登录网站数据的方法详解
2018/05/21 Python
使用Python-OpenCV向图片添加噪声的实现(高斯噪声、椒盐噪声)
2019/05/28 Python
python按行读取文件并找出其中指定字符串
2019/08/08 Python
Python学习之路之pycharm的第一个项目搭建过程
2020/06/18 Python
详解python变量与数据类型
2020/08/25 Python
Python3.9.0 a1安装pygame出错解决全过程(小结)
2021/02/02 Python
C/C++ 笔试、面试题目大汇总
2015/11/21 面试题
中职应届生会计求职信
2013/10/23 职场文书
学校政风行风自查自纠报告
2014/10/21 职场文书
详解MySQL 用户权限管理
2021/04/20 MySQL
jquery插件实现悬浮的菜单
2021/04/24 jQuery
浅谈Redis存储数据类型及存取值方法
2021/05/08 Redis
Django migrate报错的解决方案
2021/05/20 Python
撤回我也能看到!教你用Python制作微信防撤回脚本
2021/06/11 Python