PHP 文件上传限制

PHP 大文件上传占用大量资源,所以须要对上传的大小进行限制,如下为相关的三个参数:php

  1. nginx 的 client_max_body_size
  2. php.ini 的 upload_max_filesize
  3. php.ini 的 post_max_size

与以上相对应的三个报错信息:nginx

  1. 状态码 413 Request Entiry Too Large.
  2. Warning: POST Content-Length of 9663102 bytes exceeds the limit of 8388608 bytes in Unknown on line 0
  3. $_FILES['file']['error']==1

nginx错误:413 Request Entiry Too Large

client_max_body_size 用于设置客户端 Request body(请求体)的大小上限,要上传的文件就在 body 体 中,因此此参数能够间接的看作是对文件上传大小的限制。服务器

nginx 服务器经过请求头的 Content-Length 肯定 body 体的大小。超过设置的上限会返回错误码 413 Request Entity Too Large,将此参数设置为 0 能够取消对长度的限制。post

Syntax:    client_max_body_size size;
Default:    
client_max_body_size 1m;
Context:    http, server, location

client_max_body_size 能够设置在 http、server、location 块中,因此咱们能够对域名甚至一个请求地址来提升上传包的大小值。code

php错误:

Warning: POST Content-Length of 9663102 bytes exceeds the limit of 8388608 bytes in Unknown on line 0

此时为上传文件大小大于 post_max_sizeserver

php 无警告可是获取不到上传的文件

此时 $_FILES['file']['error']==1,错误缘由是上传文件的大小小于 post_max_size 可是大于 upload_max_filesize资源

相关文章
相关标签/搜索