Вопрос

Я хочу перейти на страницу в веб-приложении из приложения для рабочего стола. «Нет проблем», я слышу, как вы говорите: «Просто уверните браузер по умолчанию с помощью правильного URL». Однако веб-приложение использует аутентификацию ASP.NET Forms, и пользователи не хотят видеть страницу входа в систему, потому что они уже аутентифицированы с теми же учетными данными в приложении на рабочем столе.

Это звучит достаточно просто, все, что мне нужно сделать, это выделять http-сообщение из приложения на рабочем столе с тем, что подделывает обратную ответ с страницы входа в систему веб-приложения. Затем веб-приложение установит свой билет аутентификации и заседание заседания, вернуть их мне, и я буду хранить их в магазине Cookie. Затем я могу перейти на нужную страницу, и веб-приложение подумает, что он уже аутентифицирован.

У меня есть какой-то рабочий код, который создает пост HTTP, отправляет его и получает действительный ответ, содержащий правильное cookie. Однако я не вижу, как написать их в магазин Cookie Cookie. Может кто-то указать мне верное направление?

Образец кода:

var requestUrl = Properties.Settings.Default.WebsiteLoginPageUrl;

var requestEncoding = Encoding.GetEncoding(1252);

// Simulated login postdata
var requestText = string.Format(
    "__VIEWSTATE={2}&__EVENTTARGET={3}&__EVENTARGUMENT={4}&__EVENTVALIDATION={5}&userNameText={0}&passwordText={1}&submitButton=Log+In",
    HttpUtility.UrlEncode(Properties.Settings.Default.UserName),
    HttpUtility.UrlEncode(Properties.Settings.Default.Password),
    Properties.Settings.Default.FakeViewState,
    Properties.Settings.Default.FakeEventTarget,
    Properties.Settings.Default.FakeEventArgument,
    Properties.Settings.Default.FakeEventValidation);

var request = (HttpWebRequest) WebRequest.Create(requestUrl);
request.Method = "POST";
request.Accept = "*/*";
request.ContentType = "application/x-www-form-urlencoded";
request.ContentLength = requestEncoding.GetByteCount(requestText);
request.Headers.Add(HttpRequestHeader.CacheControl, "no-cache");
request.AllowAutoRedirect = false;
request.KeepAlive = false;
request.CookieContainer = new CookieContainer();

using(var writer = new StreamWriter(request.GetRequestStream(), requestEncoding)) {
    writer.Write(requestText);
}

var response = (HttpWebResponse) request.GetResponse();

// TODO: Grab the response cookies and save them to the interactive desktop user's cookie store.

Process.Start(new ProcessStartInfo {
    FileName = Properties.Settings.Default.WebsiteTargetPageUrl,
    UseShellExecute = true,
});
Это было полезно?

Решение

Вам нужно позвонить в неуправляемый InternetSetCookie () функция. И посмотри! Кто-то написал взаимодействие для тебя уже. Вы должны проверить его правильность, хотя.

Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top