上周五去了沈阳,把系统部署上了,修正了一点视图,发现了一点BUG。本以为一切会顺利些,没想到无论是本地开发还是实验室测试还是动态DNS测试还是公司网内测试都没问题的系统,大连泰山厂使用时就发生了一个很奇怪很纠结的现象:用户管理页面的用户列表,是用updatepanel实现的局部刷新,只要试图局部刷新,系统就会等待漫长的时间后,跳出消息框报告12031异常,查了一下,该异常是指网络连接被重置。之前让用户登录实验室服务器的系统试用,却不会出现这个问题。
从周二下午,一直到今天上午,一直在研究这个问题,包括远程操作、更新、打电话让用户测试,以及今早4点多起来继续上网查询,其间也看到老外也遇到过跟我几乎一样的问题:本地、外网、公网统统OK,部署到企业内部网就OVER。查来查去,已经查不到更多的内容了,心里似乎有些眉目,却又有些茫然。
把网上查到的此问题相关的解决方案总结了一下,先记下来吧,其中不包括捕获这个错误自行处理的办法,因为我认为那样是治标不治本。单总今天去了沈阳,说是明天上午到北票,下午到抚顺(还是阜新,忘了)。明天让他帮忙联调吧。
总结的解决方案(若是哪位过路的能有好的方案,还望不吝赐教!):
1:加大IIS中的连接超时时间,包括HTTP连接超时和ASP.NET的请求执行超时(怀疑,因为从下面的各个方法看,都没提及这一点)
2:文件夹、文件都别包含中文(无中文)
3:在body最后加:
<script language="javascript" type="text/javascript">
Sys.Application.add_load(
function()
{
var form = Sys.WebForms.PageRequestManager.getInstance()._form;
form._initialAction = form.action = window.location.href;
}
);
</script>
4:在webconfig的sys.web段中,加<httpRuntime maxRequestLength="8192"/>(在IIS中修改ASP.NET的超时时间后,自动会有这个)
5:在@page中加EnableEventValidation="false"(已有)
6:在@page中加ValidateRequest="false"(怀疑)
7:添加以下代码,将视图状态保存在session中:
protected override PageStatePersister PageStatePersister
{
get
{
return new SessionPageStatePersister(this);
}
}
8:最终下策:取消局部刷新(不过据说能显示真正的问题?):
<asp:ScriptManager ID="ScriptManager1" runat="server" EnablePartialRendering="false"/>
9:防火墙