文件上传大小限制

修改PHP上传文件大小限制的方法
1. 一般的文件上传,除非文件很小.就像一个5M的文件,很可能要超过一分钟才能上传完.
但在php中,默认的该页最久执行时间为 30 秒.就是说超过30秒,该脚本就停止执行.
这就导致出现 无法打开网页的情况.这时我们可以修改 max_execution_time
在php.ini里查找
max_execution_time
默认是30秒.改为
max_execution_time = 0
0表示没有限制
2. 修改 post_max_size 设定 POST 数据所允许的最大大小。此设定也影响到文件上传。
php默认的post_max_size 为2M.如果 POST 数据尺寸大于 post_max_size $_POST 和 $_FILES superglobals 便会为空.
查找 post_max_size .改为
post_max_size = 150M
3. 很多人都会改了第二步.但上传文件时最大仍然为 8M.
为什么呢.我们还要改一个参数upload_max_filesize 表示所上传的文件的最大大小。
查找upload_max_filesize,默认为8M改为
upload_max_filesize = 100M

另外要说明的是,post_max_size 大于 upload_max_filesize 为佳.

4.上传报413错误,

产生该错误的原因,客户端发送的实体主体部分比服务器能够或者希望处理的要大。 一般情况下我们看不到这个状态码。 因为浏览器不会发送太大的数据给网站,但是服务器间的接口交互可能会出现该问题。

nginx出现这个问题的原因是请求实体太长了。一般出现这种情况是Post请求时Body内容Post的数据太大了,如上传大文件过大、POST数据比较多。

解决方法: 
打开nginx主配置文件nginx.conf,找到http{}段,修改或者添加 client_max_body_size 的值

client_max_body_size 20m;



文件上传其它:

1.表单部分 
允许用户上传文件,在HTML表单的声明中要加上一个上传的属性: 
enctype = 'multipart/form-data' 
表单的method必须是POST 
表单选项MAX_FILE_SIZE隐藏域用于限制上传文件大小,它必须放在文件表单元素前面,单位为字节。 
如: 

复制代码代码如下:

<form enctype='multipart/form-data' id='aa' name='aaa' method='post' action='xxx.php'> 
<input type='hidden' name='MAX_FILE_SIZE' value='2621114' /> 
<input name='upload_file' type='file' /> 
</form> 


2.处理上传文件 
上传时,PHP收到关于该文件的信息数组,这些信息可以在$_FILES这个超级全局数组中找到。 
如:如果表单中的文件输入框名字为upload_file,那么关于该文件的所有信息都包含在数组$_FILES['upload_file']里面。 
如:客户上传了一个“aaa.jpg”的图片数组值如下: 
name "p5pp.jpg" 上传时文件的名字 
type “image/jpeg" 文件类型 
tmp_name "/tmp/phpjksdf" 服务器端的临时文件名 
error 上传错误的返回值 
size 2045 文件实际大小 

上面数组里面的error会返回不同的常量值,如下: 
UPLOAD_ERR_OK 没有错误发生,文件上传成功 
UPLOAD_ERR_INI_SIZE 文件大小超过了PHP.INI中upload_max_filesize选项限制的值 
UPLOAD_ERR_FORM_SIZE 上传文件的大小超过了HTML表单中MAX_FILE_SIZE选项值。可在程序中检查表单$FILES ['up_file']['size']来处理 
UPLOAD_ERR_PARTIAL 文件只有部分被上传 
UPLOAD_ERR_NO_FILE 用户没有提供任何文件上传 
上传后处理的具体例子: 

复制代码代码如下:

if(!move_uploaded_file($_FILES['f']['tmp_name'],"uploads/".$_FILES['f']['name'].".jpg")){ 
echo "error"; 


函数: 
move_uploaded_file 移动上传的临时文件到指定的目录下 
例子: 
move_uploaded_file('临时文件名','指定文件路径') 

is_uploaded_file 判断是否是通过http Post上传的文件 
例子: 

复制代码代码如下:

if(!is_uploaded_file($_FILES['f']['tmp_name'])){ 
echo '非法'; 



3.相关参数 

PHP上传设计到的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等待脚本执行完毕的时间,单位秒。次选项可限制死循环脚本,但当存在一个长时间的合法活动时(如:上传大文件),这项功能也会导致操作失败。这样情况下必须考虑将此变量增加。 

4.考虑多文件上传 
可以利用$_FILES数组就可以轻松实现多文件上传。$_FILES数组可以获取客户端表单里面所有的file域内容,从而获得所有在同一表单上传的文件。 

5.突破上传的内存限制 

方法一: 
修改php.ini中memory_limit值,改为更大,如 64M 
方法二: 
使用Apache Rewrite方法,动态修改memory_limit的值。首先建立一个.htaccess文件,保存在上传文件程序的 当前目录即可.代码如下: 
php_value memory_limit 100M 
php_value post_max_size 30M 
php_value upload_max_filesize 30M 
php_value max_execution_time 300 
php_value max_input_tim 300 
php_value display_errors On


猜你喜欢

转载自blog.csdn.net/y18749247391/article/details/80332297