我试图通过带有GET方法的jQuery AJAX调用来访问WCF服务。所以,有时URL的参数会很长。
当参数变得如此冗长时,jQuery AJAX调用将失败,并且不返回任何内容。因此,我设置了一个断点并将URL拿出来进行测试。当我在浏览器中尝试相同的网址时(我尝试了FireFox和Chrome),当网址长度太长时,它返回以下信息。
错误请求-无效的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对象。我不认为任何字符会导致问题,因为如果我只是将几个字母数字字符减少到小于限制,它就可以工作。
我在Windows8专业版的Visual Studio2012高级版中运行我的应用程序,所以它是.NET 4.5和IIS Express附带的。
进一步研究
当我试图进一步研究这一点时,这并不是我已经提到的限制,即完整url的长度。但是,每个参数都有长度限制,最多不能超过260个字符。
所以,我不确定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个字符,它就可以工作。
是浏览器限制吗?操作系统限制?
更新: SOLUTION
当我进一步研究这一点时,我找到了一个对我有效的解决方案。我在这里更新,因为它可能对遇到这个问题的其他人有用。
这是一个设置
问题是,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
确保重新启动服务器/计算机以应用注册表更改。就是这样。
发布于 2015-09-08 20:09:40
将更新重新发布为答案,因为你们中的一些人可能会直接跳到答案部分。
当我进一步研究这一点时,我找到了一个对我有效的解决方案。我在这里更新,因为它可能对遇到这个问题的其他人有用。
这是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
确保重新启动服务器/计算机以应用注册表更改。就是这样。
发布于 2013-02-21 23:22:10
需要考虑的几件事:
1)你不应该使用GET来保存数据,尽可能使用POST。主要原因与安全性有关。使用GET会使您面临更多潜在的CSRF攻击。请记住,POST不能幸免于CSRF,但使用它可以减少一些漏洞。
2)查看URL,逗号看起来不合适,这可能是您收到无效URL错误的原因。
3)您在什么版本的IIS下运行?这可能决定了您必须执行哪些操作才能增加最大URL长度。
对于IIS7,您可以在配置文件中添加到System.Web:
<httpRuntime maxUrlLength="2000" />
编辑:
您应该再次尝试将其更改为POST,因为它不会尝试将其映射到文件系统。
来自MSDN的windows api只允许260。
在Windows API中(以下段落讨论的一些例外情况除外),路径的最大长度为MAX_PATH,定义为260个字符。本地路径按以下顺序构成:驱动器号、冒号、反斜杠、由反斜杠分隔的名称组件和终止空字符。例如,驱动器D上的最大路径是“D:\某个256个字符的路径字符串”,其中"“表示当前系统代码页的不可见的终止空字符。(这里使用的字符<>是为了清晰起见,不能是有效路径字符串的一部分。)
发布于 2014-10-14 15:57:33
通过编辑regestry,它解决了我的坏请求400的问题,但在我添加之前,
<httpRuntime maxUrlLength="6144" relaxedUrlToFileSystemMapping="true" />
注意,我试图在编辑regestry之前添加此配置,但它不起作用,所以我猜在编辑Regestry并使用此配置之后,我对其进行了很好的设置。希望它能帮助其他人。
https://stackoverflow.com/questions/15004232
复制相似问题