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

bvpmtnay  于 2023-02-08  发布在  jQuery
关注(0)|答案(5)|浏览(188)

我尝试通过jQuery AJAX调用GET方法访问WCF服务。所以,有时URL是冗长的参数。
当参数变得太长时,jQuery AJAX调用失败,并且什么也不返回。所以我放置了一个断点,并取出URL进行测试。当我在浏览器中尝试相同的URL时(我尝试了FireFox和Chrome),当URL长度太长时,它返回以下内容。

    • 错误请求-无效URL**

HTTP错误400。请求的URL无效。
我也检查了长度限制。当URL中的字符数(编码格式)超过1011个字符(包括http://)时,只有我得到错误。
有没有人有同样的情况,并找到了任何解决方案?是windows限制还是可以通过任何设置编程管理?
我试过POST方法,但我不知道我不能使它工作。因为它需要一些web.config的变化。

    • 编辑**

我已测试生成错误的URL

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

URL的未编码版本:

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专业版的Visual Studio 2012高级版中运行我的应用程序,所以它是. NET 4.5和IIS Express附带的。

    • 进一步研究**

当我试图进一步研究这个问题时,这不是我已经提到的完整url的长度限制,而是每个参数的长度限制,即260个字符。
所以,我不知道网址的总长度,但每个参数(由"/"分隔)有限制。与上述网址的问题,我已经张贴是电子邮件地址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"}]

如果我删除一个字符,它的工作.
是浏览器限制还是操作系统限制?

    • 更新:解决方案**

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

    • 这是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
确保重新启动服务器/机器以应用注册表更改。

9nvpjoqh

9nvpjoqh1#

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

当我进一步研究这个问题时,我发现了一个对我有效的解决方案。我在这里更新,因为它可能对遇到这个问题的其他人有用。
这是IIS设置
问题是因为REST url中每个参数的默认字符数限制是260,这是在注册表中定义的。
因此,您必须更新注册表以增加IIS服务器/ IIS Express运行时的大小限制。
以下是登记处的地址:
HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\services\HTTP\Parameters值名称为UrlSegmentMaxLength。如果不存在,请创建一个类型为REG_DWORD的值。并为值数据指定一个更大的值,如十六进制的1000或十进制的4096。
这是http.sys设置。有关http.sys设置的详细信息:http://support.microsoft.com/kb/820129
确保重新启动服务器/机器以应用注册表更改。

qxsslcnc

qxsslcnc2#

需要考虑的几件事:
1)你不应该使用GET来保存数据,尽可能使用POST。主要原因是安全性。使用GET会让你暴露在更多潜在的CSRF攻击中。记住POST并不能对CSRF免疫,但是使用它可以稍微减少漏洞。
2)查看URL,逗号看起来不合适,这可能是您收到无效URL错误的原因。
3)您运行的IIS版本是什么?这可能会决定您必须做什么来增加最大URL长度。
对于IIS7,您可以在配置文件中添加到System.web:

<httpRuntime maxUrlLength="2000" />
    • 编辑:**

您应该尝试再次将其更改为POST,因为它不会尝试将其Map到文件系统。
MSDN开始,windows api只允许260。
在Windows API中(以下段落中讨论了一些例外情况),路径的最大长度为MAX_PATH,定义为260个字符。本地路径的结构如下:驱动器号、冒号、反斜杠、用反斜杠分隔的名称组成部分和终止空字符。例如,驱动器D上的最大路径为"D:\some 256-characters path string",其中""表示当前系统代码页不可见的终止空字符。(此处使用字符〈〉是为了直观起见,不能作为有效路径字符串的一部分。)

avkwfej4

avkwfej43#

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

<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>
...

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

...
[RequestLimits]
MaxAllowedContentLength=104857600
MaxUrl=3000
MaxQueryString=3000
jtw3ybtb

jtw3ybtb4#

通过编辑注册表,它解决了我的问题,坏请求400,但仍然不为我工作,直到我补充说,

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

注意,我试图在编辑注册表之前添加此配置,但它不起作用,所以我猜在编辑注册表后,我用此配置设置了它。可能它会帮助其他人。

mlnl4t2r

mlnl4t2r5#

上述解决方案对我很有效:

maxQueryStringLength="3000" maxUrlLength="3000"

和上面的注册表修复。

相关问题