客户端收到413 Request Entity Too Large错误该如何解决?

今天在做图片上传的时候,生产环境莫名其妙出现一个问题

bash 复制代码
413 Request Entity Too Large

搜了一圈,发现Nginx默认的上传文件大小限制为1MB,超过该限制会导致客户端收到413 Request Entity Too Large错误!!! 以下是解决方案:


1. 修改Nginx配置文件 在Nginx配置文件中(通常为nginx.conf或站点配置文件),通过client_max_body_size指令调整限制:

nginx 复制代码
# 全局生效(http块)
http {
    client_max_body_size 20M;  # 设置为20MB,按需调整
    ...
}

# 或针对特定Server生效(server块)
server {
    client_max_body_size 20M;
    ...
}

# 或针对特定路由生效(location块)
location /upload {
    client_max_body_size 20M;
    ...
}

说明: • http块配置全局生效,server块作用于站点,location块作用于具体路径。

• 支持单位:k(KB)、m(MB)、g(GB)。


2. 重启Nginx服务 修改配置后需重载配置(无需完全重启):

bash 复制代码
nginx -s reload

3. 其他注意事项 • 后端服务限制:若后端(如PHP、Laravel)也有文件大小限制,需同步调整(如php.ini中的upload_max_filesizepost_max_size)。

• 缓冲区优化:若上传大文件,可调整client_body_buffer_sizeclient_header_buffer_size减少磁盘I/O。

• 安全风险:将client_max_body_size设为0可禁用限制,但可能引发资源耗尽攻击,需谨慎使用。


小结

通过修改Nginx的client_max_body_size参数并重载配置,即可解决文件上传大小超限问题。若需更细粒度控制,可结合serverlocation块配置。

相关推荐
遇见火星27 分钟前
Nginx限流配置:防止接口被刷,服务器稳如泰山
运维·服务器·nginx
Jinkxs18 小时前
LoadBalancer- 主流负载均衡工具盘点:Nginx / Haproxy / Keepalived 基础介绍
运维·nginx·负载均衡
ReaF_star21 小时前
【安全】SSL证书更新操作手册(Nginx+Cloudflare+acme.sh)
nginx·安全·ssl
云动课堂1 天前
【运维实战】Nginx 高性能Web服务 · 一键自动化部署方案 (适配银河麒麟 V10 / openEuler / CentOS 7/8)
运维·前端·nginx
2601_949817921 天前
nginx 代理 redis
运维·redis·nginx
java1234_小锋1 天前
解释一下NGINX的反向代理和正向代理的区别?
运维·nginx
techdashen2 天前
Cloudflare 为何抛弃 NGINX,用 Rust 自研了一个代理
运维·nginx·rust
人生匆匆2 天前
通过nginx解决跨域问题
运维·nginx
子木HAPPY阳VIP2 天前
信创UOS,Docker 完整操作部署(Dockerfile部署方式)&排错整合
linux·运维·redis·nginx·docker·容器·tomcat
吹个口哨写代码2 天前
小程序图片不显示,直接访问显示,头部配置问题
javascript·css·nginx