因为我们需要将sql拼接在url中,这样会导致http请求很长,当我们需要发送比较长的http请求时,有可能会报Request Url 请求超长的错误,这种错误的报错形式一般有两种:“HTTP Error 400. The request URL is invalid”和“此请求的 URL 的长度超过配置的 maxUrlLength 值”,这两个错误一般会同时存在;
1.处理“此请求的 URL 的长度超过配置的 maxUrlLength 值”
ASP.NET MVC的网站URL长度是有限制的,通过HttpRuntime元素的maxUrlLength属性限制默认URL长度为最大260个字符。如果HTTP请求的网站地址超出了默认长度,就会抛出HttpException 异常,并显示错误信息:此请求的 URL 的长度超过配置的 maxUrlLength 值,这时我们就需要在ASP项目的web.config中对HttpRuntime元素的maxUrlLength属性进行设置
<system.web>
<compilation debug="true" targetFramework="4.5"/>
<httpRuntime targetFramework="4.5" requestPathInvalidCharacters="" maxUrlLength="9999"/>
</system.web>
注:MaxUrlLength 属性的值可以是任何等于或大于零的整数。
更多信息 HttpRuntime元素官方说明文档:
https://docs.microsoft.com/zh-cn/previous-versions/e1f13641(v=vs.110)?redirectedfrom=MSDN
2. 处理“HTTP Error 400. The request URL is invalid”
这个问题是由于我们的操作系统将超长的请求进行了拦截,也就是说请求还没有发送到IIS就已经被干掉了,这时我们就需要修改操作系统的注册表信息,以便放行我们的超长请求
2.1 打开cmd输入regedit打开“注册表编辑器”
2.2 我们可以在HKEY_LOCAL_MACHINE\System\CurrentControlSet\Services\HTTP\Parameters这个路径下新建两个参数UrlSegmentMaxCount、UrlSegmentMaxLength(如下图所示)
2.3 修改完成后需要重新启动http服务
官方说明文档:https://support.microsoft.com/zh-cn/help/820129/http-sys-registry-settings-for-windows