WCF GET URL长度限制问题:错误请求 - 无效的URL

时间:2013-02-21 14:05:08

标签: jquery ajax wcf browser get

我尝试通过使用GET方法的jQuery AJAX调用来访问WCF服务。因此,有时URL的参数很长。

当参数变得如此冗长时,jQuery AJAX调用失败,并且什么都不返回。所以我提出了一个断点,并将URL用于测试。当我在浏览器中尝试使用相同的URL时(我尝试过FireFox和Chrome),当URL长度过长时会返回以下内容。

  

错误请求 - 网址无效

     

HTTP错误400.请求网址无效。

我也检查了长度限制。当URL中的字符数(编码格式)超过1011个字符(包括http://)时,我才会收到错误。

任何人都有相同的情况,并找到任何解决方案吗?是Windows限制还是可以通过编程方式通过任何设置进行管理?

我尝试了POST方法,但我不知道我无法使其工作。因为它需要一些web.config更改。

修改

我测试过生成错误的网址

http://localhost:64973/Member.svc/SaveMemberWithDetail/%7B%22ID%22%7C%222%22,%22TypeID%22%7C%222%22,%22Title%22%7C%22Mr.%22,%22FirstName%22%7C%22Firnas%22,%22MiddleName%22%7C%22%22,%22LastName%22%7C%22Aliyar%22,%22Gender%22%7C%221%22,%22DateOfBirth%22%7C%222000-01-01%22,%22Nationality%22%7C%22Sri%20Lankan%22%7D/%5B%7B%22AddressLine1%22%7C%22Changed%20Address%20Line1%22,%22AddressLine2%22%7C%22Colombo%22,%22City%22%7C%22Colombo%2010%22,%22State%22%7C%22WP%22,%22PostCode%22%7C%2201000%22,%22CountryID%22%7C%221%22,%22ID%22%7C%227%22,%22TypeID%22%7C%221%22%7D%5D/%5B%7B%22Telephone%22%7C%22015154645%22,%22TypeID%22%7C%221%22%7D%5D/%5B%7B%22EmailAddress%22%7C%22gen1@dfs%22,%22ID%22%7C%2226%22,%22TypeID%22%7C%221%22%7D,%7B%22EmailAddress%22%7C%22gen2@jfasd%22,%22ID%22%7C%2227%22,%22TypeID%22%7C%221%22%7D,%7B%22EmailAddress%22%7C%22g1@e.cm%22,%22ID%22%7C%2228%22,%22TypeID%22%7C%221%22%7D,%7B%22EmailAddress%22%7C%22g2@gogle.com%22,%22ID%22%7C%2229%22,%22TypeID%22%7C%221%22%7D,%7B%22EmailAddress%22%7C%22g@go.com%22,%22ID%22%7C%2229%22,%22TypeID%22%7C%221%22%7D%5D/%7B%7D/481

未编码的网址版本:

http://localhost:64973/Member.svc/SaveMemberWithDetail/{"ID"|"2","TypeID"|"2","Title"|"Mr.","FirstName"|"Firnas","MiddleName"|"","LastName"|"Aliyar","Gender"|"1","DateOfBirth"|"2000-01-01","Nationality"|"Sri Lankan"}/[{"AddressLine1"|"Changed Address Line1","AddressLine2"|"Colombo","City"|"Colombo 10","State"|"WP","PostCode"|"01000","CountryID"|"1","ID"|"7","TypeID"|"1"}]/[{"Telephone"|"015154645","TypeID"|"1"}]/[{"EmailAddress"|"gen1@dfs","ID"|"26","TypeID"|"1"},{"EmailAddress"|"gen2@jfasd","ID"|"27","TypeID"|"1"},{"EmailAddress"|"g1@e.cm","ID"|"28","TypeID"|"1"},{"EmailAddress"|"g2@gogle.com","ID"|"29","TypeID"|"1"},{"EmailAddress"|"g@go.com","ID"|"29","TypeID"|"1"}]/{}/481

我的参数是Json对象的集合。我不认为任何字符会导致问题,因为,如果我只是将少量字母数字字符减少到小于限制,它就可以工作。

我正在使用Windows 8 Professional中的Visual Studio 2012 Premium运行我的应用程序,所以它是.NET 4.5和IIS Express随之而来。

进一步研究

当我尝试进一步调查时,这不是我已经提到的限制,即完整网址的长度。但是,每个参数的长度限制为260个字符。

所以,我不确定URL的总长度,但是每个参数(用“/”分隔)都有限制。我发布的上述URL的问题是电子邮件地址JSON参数长度为261个字符,如下所示。

[{"EmailAddress"|"gen1@dfs","ID"|"26","TypeID"|"1"},{"EmailAddress"|"gen2@jfasd","ID"|"27","TypeID"|"1"},{"EmailAddress"|"g1@e.cm","ID"|"28","TypeID"|"1"},{"EmailAddress"|"g2@gogle.com","ID"|"29","TypeID"|"1"},{"EmailAddress"|"g@go.com","ID"|"29","TypeID"|"1"}]

如果我从中删除1个字符,则可以正常工作。

是浏览器限制吗?操作系统限制?

更新:解决方案

当我进一步研究这个问题时,我找到了一个对我有用的解决方案。我在这里更新,因为它可能对遇到这个问题的其他人有用。

这是一个IIS设置

问题是因为,REST url中每个参数的默认字符限制是260,它是在注册表中定义的。

因此,您必须更新注册表以增加运行IIS服务器/ IIS Express的大小限制。

以下是注册表的位置:

HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\services\HTTP\Parameters

值名称为UrlSegmentMaxLength。如果不存在,请创建类型为REG_DWORD的项目。并为value data指定更高的值,例如十六进制的1000或十进制的4096。

这是一个http.sys设置。有关http.sys设置的更多信息:http://support.microsoft.com/kb/820129

确保重新启动服务器/计算机以应用注册表更改。 就是这样。

5 个答案:

答案 0 :(得分:11)

将更新重新发布为“应答”,因为有些人可能会直接跳到“答案”部分。

当我进一步研究这个问题时,我找到了一个对我有用的解决方案。我在这里更新,因为它可能对遇到这个问题的其他人有用。

这是一个IIS设置

问题是因为,REST url中每个参数的默认字符限制是260,它是在注册表中定义的。

因此,您必须更新注册表以增加运行IIS服务器/ IIS Express的大小限制。

以下是注册表的位置:

HKEY_LOCAL_MACHINE \ SYSTEM \ CURRENTCONTROLSET \服务\ HTTP \参数 值名称为UrlSegmentMaxLength。如果不存在,请使用类型REG_DWORD创建一个。并为值数据指定更高的值,例如十六进制的1000或十进制的4096。

这是一个http.sys设置。有关http.sys设置的更多信息:http://support.microsoft.com/kb/820129

确保重新启动服务器/计算机以应用注册表更改。就是这样。

答案 1 :(得分:2)

要考虑几件事:

1)您不应该使用GET来保存数据,尽可能使用POST。主要原因与安全有关。使用GET可以为您提供更多潜在的CSRF攻击。请记住,POST不能免于CSRF,但使用它可以减少漏洞。

2)查看网址时,逗号看起来不合适,可能是您收到无效网址错误的原因。

3)你在运行什么版本的IIS?这可能会决定您需要做些什么来增加最大URL长度。

对于IIS7,您可以在配置文件中添加到System.Web:

<httpRuntime maxUrlLength="2000" />

修改

您应该尝试再次将其更改为POST,因为它不会尝试将其映射到文件系统。

MSDN起,windows api只允许260.

  

在Windows API中(以下讨论了一些例外情况)   段落),路径的最大长度是MAX_PATH,即   定义为260个字符。本地路径的结构如下   顺序:驱动器号,冒号,反斜杠,名称组件分隔   反斜杠和终止空字符。例如,   驱动器D上的最大路径是“D:\某些256个字符的路径字符串”   其中“”表示不可见的终止空字符   当前的系统代码页。 (字符&lt;&gt;用于此处   视觉清晰度,不能成为有效路径字符串的一部分。)

答案 2 :(得分:1)

通过编辑regestry,它解决了我的错误请求400的问题,但stil对我来说不起作用,直到我添加,

<httpRuntime maxUrlLength="6144" relaxedUrlToFileSystemMapping="true" />

注意我试着在编辑我的regestry之前添加这个配置,但它没有工作所以我想在编辑Regestry后,我想这个配置我设置得很好。 它可以帮助其他人。

答案 3 :(得分:1)

为完整性添加另一个答案。在我的例子中,我在web.config中拥有所有正确的值:

[FunctionName("QueueProcessor")]

但是,我仍然在其中一个IIS服务器上收到400错误。经过更多的调查和配置比较,结果发现UrlScan IIS模块是罪魁祸首。通过卸载模块或编辑UrlScan.ini文件来修改最大长度值,问题已得到解决:

    <system.web>
    ...
        <!--Make sure to keep maxAllowedContentLength and maxRequestLength are in Synch-->
        <!--This is for ASP.NET and is in KBytes-->
        <httpRuntime maxRequestLength="50000" maxUrlLength="3000" maxQueryStringLength="3000"/>
    </system.web>
...
  <system.webServer>
    <security>
      <requestFiltering>
        <!--This is for IIS7+ and is in Bytes (Equivalent to 50MB)-->
        <requestLimits maxAllowedContentLength="52428800" maxQueryString="3000" />
      </requestFiltering>
    </security>
  </system.webServer>
...

答案 4 :(得分:0)

以上解决方案适用于我:

maxQueryStringLength =“3000”maxUrlLength =“3000”

上面的注册表修复。