首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >网址编码问题- HttpWebRequest不工作,火狐工作

网址编码问题- HttpWebRequest不工作,火狐工作
EN

Stack Overflow用户
提问于 2009-11-16 04:28:20
回答 2查看 3.9K关注 0票数 3

我正在尝试调用一个由lims系统提供的rest webservice (基本上是一个化学实验室数据库+接口)。它一直工作得很好,直到出现了一些> ascii字符(特别是带有抑扬符、变音等字符)。

在调用webservice时,我有以下参数:

代码语言:javascript
复制
&componentValue=àèïõû

不带任何预转义或在值上调用Uri.EscapeDataString()的HttpWebRequest给出:

代码语言:javascript
复制
à èïõû

火狐,与传递给HttpWebRequest的网站相同,给出了正确的值:

代码语言:javascript
复制
àèïõû

现在转义本身: Uri.EscapeDataString()似乎转义为:

代码语言:javascript
复制
%C3%A0%C3%A8%C3%AF%C3%B5%C3%BB

Firefox转义为“àèaiáu”为:

代码语言:javascript
复制
%E0%E8%EF%F5%FB

作为后者的工作,我当然更喜欢使用它作为我的转义方法,但我真的不知道从哪里开始。我发现了大量关于在响应数据上处理编码的不同方法的信息,但在请求上找不到。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2009-11-16 04:33:42

来自MSDN

Uri.EscapeDataString方法

..。所有Unicode字符在转义之前都会转换为UTF-8格式。

因此,您看到的是àèïõû的UTF8编码版本。

Uri.EscapeDataString不同,HttpUtility.UrlEncode允许您显式指定编码:

代码语言:javascript
复制
HttpUtility.UrlEncode("àèïõû", Encoding.GetEncoding("latin1"));

或者,您可以编写自己的版本;例如:

代码语言:javascript
复制
string.Concat(Encoding
   .GetEncoding("latin1")
   .GetBytes("àèïõû")
   .Select(x => "%" + x.ToString("x2"))
   .ToArray());

这两种方法都会产生"%e0%e8%ef%f5%fb"

更好的解决方案可能是在the服务中接受UTF-8编码的查询字符串。

票数 3
EN

Stack Overflow用户

发布于 2009-11-16 04:42:52

看起来Uri.HexEscape()会做你想做的事情,但是一次只有一个角色。我将使用您自己的转义函数,并希望您的代码页始终与webservice使用的代码页相同,因为webservice似乎不支持Unicode。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/1738711

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档