POST内容太大的问题

Posted SHIHUC

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了POST内容太大的问题相关的知识,希望对你有一定的参考价值。

背景:

  最近项目进入尾声,需要做交付测试,发现CMS生成页面在反复修改保存多次后,由于页面存在动态加载js的缘故,使得页面的内容越来越大,最终出现页面没有办法保存(ajax post将页面的内容发送给后端服务器)

 

系统的架构如下图:

  技术分享

即: 前端页面上用户修改了页面内容,点击保存按钮,通过ajax的post将页面的内容传递到后台的tomcat进行存数据库,浏览器上爆出错误net::ERR_CONTENT_LENGTH_MISMATCH

查阅了很多相关的帖子,都说是nginx的用户权限的问题,因为大文件,nginx会做缓存,nginx的主进程没有权限去读取proxy_temp目录下的内容,但是,我的情况是,nginx的配置中user用的是root,所以,这个网上多数人说的解决方案不适合我这个情况。

 

在nginx所在的机器上tcpdump查看包内容,其实能看到,内容是很多的,应该不是nginx丢包。

接下来,去分析tomcat的问题,接着查阅各种大师的建议,说是tomcat的配置中默认对于post的最大包门限是2M,这个倒是非常像我这个错误的情况,因为重复修改保存页面之前,保存是可以的,反复操作,由于另外的问题导致页面的内容不断变多,所以post的内容也就大于2M了,这个时候就爆出问题了。

 

修改tomcat的配置,将server.xml文件中的connector节点的属性中添加maxPostSize=“0”,注意,默认的tomcat是没有这个属性配置的,此处修改为0表示不限制。

 

 1   <Service name="Catalina">
 2 
 3     <!--The connectors can use a shared executor, you can define one or more named thread pools-->
 4     <Executor name="tomcatThreadPool" namePrefix="catalina-exec-"
 5         maxThreads="1000" minSpareThreads="100"/>
 6 
 7 
 8     <!-- A "Connector" represents an endpoint by which requests are received
 9          and responses are returned. Documentation at :
10          Java HTTP Connector: /docs/config/http.html (blocking & non-blocking)
11          Java AJP  Connector: /docs/config/ajp.html
12          APR (HTTP/AJP) Connector: /docs/apr.html
13          Define a non-SSL HTTP/1.1 Connector on port 8080
14     -->
15 
16  <Connector port="8082" protocol="HTTP/1.1"
17                connectionTimeout="20000"
18                redirectPort="8443"
19                maxPostSize="0"
20                            URIEncoding="UTF-8"/>
21 ..............

 

 

这么修改后,重新启动tomcat,再次测试,发现就ok了,可以保存刚才那个大文件了。

 

以上是关于POST内容太大的问题的主要内容,如果未能解决你的问题,请参考以下文章

如何绕过将数据模型传递给片段参数以避免事务太大异常?

STM32CubeMX生成代码体积太大的问题

将太大的值转换为 java short

函数内部有太大的数组,导致异常死机的问题

“画布:Android Studio中试图绘制太大的位图”问题

输入包含无穷大或对于 dtype('float64') 错误来说太大的值