Мне нужно было сделать это сегодня для сайта SharePoint, который использует проверку подлинности на основе форм (FBA). Если вы попытаетесь вызвать страницу приложения без клонирования файлов cookie и назначения объекта CookieContainer, запрос будет отклонен.
Я решил абстрагировать работу от этого удобного метода расширения:
public static CookieContainer GetCookieContainer(this System.Web.HttpRequest SourceHttpRequest, System.Net.HttpWebRequest TargetHttpWebRequest)
{
System.Web.HttpCookieCollection sourceCookies = SourceHttpRequest.Cookies;
if (sourceCookies.Count == 0)
return null;
else
{
CookieContainer cookieContainer = new CookieContainer();
for (int i = 0; i < sourceCookies.Count; i++)
{
System.Web.HttpCookie cSource = sourceCookies[i];
Cookie cookieTarget = new Cookie() { Domain = TargetHttpWebRequest.RequestUri.Host,
Name = cSource.Name,
Path = cSource.Path,
Secure = cSource.Secure,
Value = cSource.Value };
cookieContainer.Add(cookieTarget);
}
return cookieContainer;
}
}
Затем вы можете просто вызвать его из любого объекта HttpRequest с целевым объектом HttpWebRequest в качестве параметра, например:
HttpWebRequest request;
request = (HttpWebRequest)WebRequest.Create(TargetUrl);
request.Method = "GET";
request.Credentials = CredentialCache.DefaultCredentials;
request.CookieContainer = SourceRequest.GetCookieContainer(request);
request.BeginGetResponse(null, null);
где TargetUrl - это URL-адрес страницы, за которой я следую, а SourceRequest - это запрос HttpRequest страницы, на которой я сейчас нахожусь, полученный через Page.Request.