WCF GET URL长度限制问题:错误的请求
我试图通过使用GET方法的jQuery AJAX调用来访问WCF服务。 所以,有时候这个URL很长,带有参数。
当参数变得如此冗长时,jQuery AJAX调用失败,并且不返回任何内容。 所以我放了一个断点,并拿出了URL来测试。 当我在浏览器中尝试相同的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
未编码版本的网址:
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_MACHINESYSTEMCurrentControlSetservicesHTTPParameters
值名称是UrlSegmentMaxLength
。 如果不存在,请使用REG_DWORD
类型创建一个。 并为value data
指定较高的值,如十六进制为1000或十进制为4096。
这是一个http.sys设置。 有关http.sys设置的更多信息:http://support.microsoft.com/kb/820129
确保您重新启动服务器/机器以应用注册表更改。 就是这样。
将更新重新发布为答案,因为有些人可能会直接跳入Answers部分。
当我对此进行进一步研究时,我找到了一个适合我的解决方案。 我在这里更新,因为它可能对遇到此问题的其他人有用。
这是一个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
确保您重新启动服务器/机器以应用注册表更改。 就是这样。
有几件事要考虑:
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个字符的路径字符串”,其中“”表示当前系统代码页的不可见的终止空字符。 (字符<>在这里用于视觉清晰,不能是有效路径字符串的一部分。)
通过编辑regestry它解决了我的请求400的问题,但stil不适用于我,直到我添加,
<httpRuntime maxUrlLength="6144" relaxedUrlToFileSystemMapping="true" />
为了说明我试着在编辑我的regestry之前添加这个配置,但它没有工作,所以我想在编辑Regestry和这个配置后我设置好了。 它可以帮助别人吗?
链接地址: http://www.djcxy.com/p/42169.html