【发布时间】: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