1

我正在将 HttpWebRequest 用于 REST 服务,该服务使用一些依赖于 JSESSIONID cookie 的基本身份验证。我需要将该 cookie 传递给 WebBrowser 控件以重用该会话,但没有找到任何可用的解决方案允许我在浏览器的 cookie 存储中传递该 cookie。

有什么办法吗?我现在能想到的唯一方法是使用 Naviagate(url, null, MANUALLY_CONSTRUCTED_HEADER),这是一种蛮力。

是的,并且确实必须使用 WebBrowser 进行此类操作。

有什么建议么?

4

3 回答 3

5

另一个想法是您可以通过 JavaScript 添加 cookie。您应该能够做到这一点(假设 IsScriptEnabled 在您的浏览器控件上为 true):

private void setCookie(string name, string value, string path = "", string domain = "", bool isSecure=false, string expires = "")
{
        var sb = new StringBuilder();
        sb.AppendFormat("document.cookie = '{0}=\" + escape(\"{1}\")", name, value);
        if (!String.IsNullOrEmpty(expires))
            sb.AppendFormat(";expires=\"{0}\"", expires); // should be a GMTString
        if (!String.IsNullOrEmpty(path))
            sb.AppendFormat(";path=\"{0}\"", path); 
        if (!String.IsNullOrEmpty(domain))
            sb.AppendFormat(";domain=\"{0}\"", domain);
        if (isSecure)
            sb.Append(";secure'");
        var cookieJs = sb.ToString();
        Debug.WriteLine(cookieJs);
        webBrowser.InvokeScript(cookieJs);
}
于 2012-11-13T19:54:45.400 回答
1

我通过第一次在 URL 中发送 JSESSIONID 解决了我的问题,然后获得了有效的 JSESSIONID cookie。但这不是一个普遍的方法。

我认为有一种解决方案可以导航到简单的网页,该网页嵌套在应用程序资源中。然后浏览器可以调用javascript函数,该函数将设置参数传递的cookie。如果 Microsoft 不干预这种方法(通过禁用 document.cookie),这可能是一个解决方案(我还没有测试过)。

于 2012-11-08T13:26:34.290 回答
0

对于那些即使在 LoadCompleted 事件中调用脚本也遇到异常的人,试试这个:

webBrowser.InvokeScript("eval", "document.cookie = \"COOKIE_NAME=" + COOKIE_VALUE + "; Path=/; Domain=" + WEB_URL.DnsSafeHost + " ;\";");

这个在 LoadCompleted 事件中为我工作。请记住,您必须加载两次才能使 cookie 正常工作。在 LoadCompleted 时,cookie 将被注入但不显示,但在第二次加载时,它会正常工作。

于 2015-09-16T06:56:52.230 回答