gpt4 book ai didi

c# - 在 HttpWebResponse C# 上访问 ASP.NET_SessionId

转载 作者:太空宇宙 更新时间:2023-11-03 23:07:38 25 4
gpt4 key购买 nike

我正在尝试从 HttpWebResponse 获取 ASP.NET_SessionId,但响应中似乎没有此类数据。基本上,我试图在某些需要身份验证的页面上模拟一些步骤。问题不在身份验证中,我的问题是在身份验证后获取 ASP.NET_SessionId,以便我可以在以后的请求/步骤中使用它。

在开发人员工具 > 网络上的 Chrome 中,我可以在 header 上看到 ASP.NET_SessionId,但它没有出现在我的 HttpWebResponse 中。知道为什么会这样吗?这是我的代码:

 var httpWebRequest              = (HttpWebRequest) WebRequest.Create(url);
httpWebRequest.UserAgent = "Mozilla/5.0 (Windows NT 10.0) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/40.0.2214.93 Safari/537.36"; httpWebRequest.Method = "POST";
httpWebRequest.ContentType = "application/x-www-form-urlencoded";
httpWebRequest.ContentLength = 0;
var httpWebResponse = (HttpWebResponse) httpWebRequest.GetResponse();

根据我的请求,我应该会看到一个 ASP.NET_SessionId header Set-Cookie,但没有成功。有什么想法吗?

我看到有人这么说

httpWebResponse.Headers["ASP.NET_SessionId"]

httpWebResponse.Headers["SESSION_ID"]

应该可以,但不行,没有设置 session ID header ,也没有任何 Cookie。

最佳答案

经过多次研究,答案是here

基本上,我们必须在所有请求中保持相同的 CookieContainer 对象引用。我从响应中提取了一些 Set-Cookie 并将它们添加到我的请求中,但现在我不需要做任何事情,CookieContainer 透明地管理所有这些。

响应中的 Set-Cookie 在您的请求 的 CookieContainer 上设置。这是他们发现的解决可能的安全问题的方法,所以不要浪费更多时间,只需保留对您的 CookieContainer 的引用,因为您将无法访问 session ID(并且您不需要它)。

现在有我的代码示例。

var cookieContainer = new CookieContainer();

var httpWebRequest1 = (HttpWebRequest) WebRequest.Create(url);
httpWebRequest1.CookieContainer = cookieContainer;

// do the request and some logic

var httpWebRequest2 = (HttpWebRequest) WebRequest.Create(anotherUrl);
httpWebRequest2.CookieContainer = cookieContainer; // same cookieContainer reference

现在一切正常,希望对某人有所帮助。

关于c# - 在 HttpWebResponse C# 上访问 ASP.NET_SessionId,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40617203/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com