我正在使用HttpWebRequest进行REST服务,该服务使用一些依赖于JSESSIONID cookie的基本身份验证。我需要将该cookie传递给WebBrowser控件以重用该会话,但没有找到任何可用的解决方案,允许我在浏览器的cookie存储区中传递该cookie。
有什么办法吗?我现在能想到的唯一方法是使用Naviagate(url,null,MANUALLY_CONSTRUCTED_HEADER),这是一种蛮力。
是的,并且必须使用WebBrowser进行此类操作。
有什么建议吗?
答案 0 :(得分: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);
}
答案 1 :(得分:1)
我通过首次在URL中发送JSESSIONID解决了我的问题,然后获取了有效的JSESSIONID cookie。但这不是一种普遍的做法。
我认为有一个解决方案可以导航到简单的网页,它嵌套在应用程序资源中。然后浏览器可以调用javascript函数,该函数将设置参数传递的cookie。如果微软不干涉这种方法(通过disablink document.cookie),这可能是一个解决方案(我还没有测试过)。
答案 2 :(得分:0)
对于那些即使在LoadCompleted事件上调用脚本异常的人,请试试这个:
webBrowser.InvokeScript("eval", "document.cookie = \"COOKIE_NAME=" + COOKIE_VALUE + "; Path=/; Domain=" + WEB_URL.DnsSafeHost + " ;\";");
这个在LoadCompleted事件上为我工作。请记住,您必须加载两次以获得cookie功能。在LoadCompleted上,cookie会在第二次加载时被注入但不会显示,但它可以正常工作。