【问题标题】:CookieContainer does not store cookies for internationalized domain namesCookieContainer 不存储国际化域名的 cookie
【发布时间】:2015-06-07 21:41:40
【问题描述】:

我正在尝试使用 WebClient 对西里尔文域执行授权。授权经历了几个阶段,在普通域和 punicode 域之间进行重定向。问题是 HttpWebRequest 无法将 cookie 存储在分配的 CookieContaier 中,如果它是由 punycode 域设置的。 例如,这段代码会抛出 CookieException。

var cookie = new Cookie("test_cookie", "test_value", "/", ".xn----7sbcca6bi0ak9b0a6f.xn--p1ai");
var container = new CookieContainer().Add(cookie);

设置 cookie 的响应会重定向到另一个页面,即在执行 WebClient.UploadValues(...) 之后,WebClient.ResponseHeaders 中没有 cookie 信息这一事实加剧了问题。

以下是正常的授权流程(使用浏览器)

Method  Result  Received  Type       URL                                                        RedirectURL                                                Set-Cookie                                                                                                                                 
POST    302     1,18 K    text/html  http://xn----7sbcca6bi0ak9b0a6f.xn--p1ai/admin/login       http://xn----7sbcca6bi0ak9b0a6f.xn--p1ai/admin             sess_id=.......; expires=Mon, 06-Jun-2016 07:20:57 GMT; Max-Age=31536000; path=/; domain=.xn----7sbcca6bi0ak9b0a6f.xn--p1ai; httponly     
GET     302     722       text/html  http://xn----7sbcca6bi0ak9b0a6f.xn--p1ai/admin             /admin/orders                                                                                                                                                                                        
GET     200     200,00 K  text/html  http://xn----7sbcca6bi0ak9b0a6f.xn--p1ai/admin/orders                                                                                                                                                                                                            

有什么解决办法吗?

【问题讨论】:

  • 谁能确认这是一个错误?也许我应该向connect.microsoft.com/VisualStudio 报告?
  • 更新:1. 必须在配置中启用 IDN 和 IRI 处理才能重现上述行为。 2.很明显,System.Net.Cookie类的内部方法VerifySetDefaults是问题的原因。我试图找出原因,但VerifySetDefaults 对我来说相当复杂。
  • 更新:似乎VerifySetDefaults 正在尝试将 IDN 与其 punycode 表示进行比较,当它失败时抛出异常。

标签: c# .net cookies idn punycode


【解决方案1】:

您确定 IDN 是问题所在吗?

下面的代码sn-p(和你的一样,但是把第二行分开编译)

var cookie = new Cookie("test_cookie", "test_value", "/", ".xn----7sbcca6bi0ak9b0a6f.xn--p1ai");
var container = new CookieContainer();
container.Add(cookie);

container.GetCookies(new Uri("http://test.xn----7sbcca6bi0ak9b0a6f.xn--p1ai")).Dump();

根本不抛出 CookieException(从 LINQPad 运行)。问题可能出在您尝试为 cookie 设置的名称和/或值中吗?您从 CookieException 中得到的确切消息是什么?

【讨论】:

  • 这肯定是IDN问题,因为常规的域cookie保存得很好。您的代码 sn-p 在 .net fw 4.5.1 上引发异常。你用什么版本测试过?
  • 运行 4.0.30319.34014,即 .NET 4.5.1 on Windows 8.1 64-bit 。
  • 我找到了为什么你没有例外。必须在配置文件中设置<idn enabled="All"/> 部分,以进行正常的 IDN 处理。如果未设置,则任何类型的 WebRequest 都无法解析国际化域名,尽管 CookieContainer 会按应有的方式存储 IDN c​​ookie。非常奇怪的行为。
  • 感谢分享!我现在确实可以重现该问题。试图弄清楚这个设置对 VerifySetDefaults 行为的影响(我认为它应该只影响 Uri 实现),但到目前为止失败了。
  • VerifySetDefaults 在 Set-Cookie 域(即 punycode)和它的 System.Net.Uri 表示(如果启用 IDN 支持时是 unicode IDN)之间进行比较。当然,在 IDN 的情况下它们是不同的。顺便说一句,有一种方法可以使用 CookieContainer.Add(Uri uri, Cookie cookie) 方法存储 punicode 域 cookie,其中 Cookie.Domain 字段为空。但是 WebRequest 使用 CookieContainer.Add(CookieCollection cookies) 方法,该方法对 IDN 失败。
猜你喜欢
  • 2011-06-26
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2011-04-09
  • 2019-01-09
  • 2015-08-17
  • 1970-01-01
  • 2015-07-07
相关资源
最近更新 更多