客户端收到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块配置。

相关推荐
Avan_菜菜3 天前
FRP 内网穿透完整实战:从 HTTP 映射到 HTTPS 自签代理
运维·nginx·https
ping某7 天前
为什么 Nginx 明明监听了 80,转发后端时却用了 4xxxx 端口?
后端·nginx
難釋懷9 天前
Nginx反向代理中的容错机制
运维·nginx
bloglin999999 天前
Nginx高危漏洞CVE-2021-23017及配置样例
运维·nginx
进阶的小名9 天前
Spring Boot SSE + Nginx 配置:解决 EventSource 不实时返回、连接超时、流式响应被缓冲问题
spring boot·后端·nginx
難釋懷9 天前
Nginx获取客户端真实IP
服务器·前端·nginx
qq_谁赞成_谁反对10 天前
甲方IT的成长之路--nginx实战--2604
服务器·数据库·nginx
图灵追慕者10 天前
Nginx安裝以及配置顯示本地服務器文件夾
运维·nginx
rabbit_pro10 天前
Nginx配置维护模式
运维·nginx
楠目10 天前
Nginx 解析漏洞利用总结
nginx·网络安全