Вопрос

Я уверен, что, должно быть, делаю что-то не так.Но ни за что на свете не могу понять, что происходит.

У меня проблема, из-за которой кажется, что класс HttpWebRequest в фреймворке некорректно анализирует файлы cookie из веб-ответа.

Я использую Fiddler, чтобы увидеть, что происходит, и после отправки запроса заголовки ответа выглядят как таковые:

HTTP/1.1 200 Ok
Connection: close
Date: Wed, 14 Jan 2009 18:20:31 GMT
Server: Microsoft-IIS/6.0
P3P: policyref="/w3c/p3p.xml", CP="CAO DSP IND COR ADM CONo CUR CUSi DEV PSA PSD DELi OUR COM NAV PHY ONL PUR UNI"
Set-Cookie: user=v.5,0,EX01E508801E$97$2E401000t$1BV6$A1$EC$104$A1$EC$104$A1$EC$104$21O001000$1E31!90$7CP$AE$3F$F3$D8$19o$BC$1Cd$23; Domain=.thedomain.com; path=/
Set-Cookie: minfo=v.4,EX019ECD28D6k$A3$CA$0C$CE$A2$D6$AD$D4!2$8A$EF$E8n$91$96$E1$D7$C8$0F$98$AA$ED$DC$40V$AB$9C$C1$9CF$C9$C1zIF$3A$93$C6$A7$DF$A1$7E$A7$A1$A8$BD$A6$94c$D5$E8$2F$F4$AF$A2$DF$80$89$BA$BBd$F6$2C$B6$A8; expires=Sunday, 31-Dec-2014 23:59:59 GMT; Domain=.thedomain.com; path=/
Set-Cookie: accttype=v.2,3,1,EX017E651B09k$A3$CA$0C$DB$A2$CB$AD$D9$8A$8C$EF$E8t$91$90$E1$DC$C89$98$AA$E0$DC$40O$A8$A4$C1$9C; expires=Sunday, 31-Dec-2014 23:59:59 GMT; Domain=.thedomain.com; path=/
Set-Cookie: tpid=v.1,20001; expires=Sunday, 31-Dec-2014 23:59:59 GMT; Domain=.thedomain.com; path=/
Set-Cookie: MC1=GUID=541977e04a341a2a4f4cdaaf49615487; expires=Sunday, 31-Dec-2014 23:59:59 GMT; Domain=.thedomain.com; path=/
Set-Cookie: linfo=v.4,EQC|0|0|255|1|0||||||||0|0|0||0|0|0|-1|-1; expires=Sunday, 31-Dec-2014 23:59:59 GMT; Domain=.thedomain.com; path=/
Set-Cookie: group=v.1,0; expires=Sunday, 31-Dec-2014 23:59:59 GMT; Domain=.thedomain.com; path=/
Content-Type: text/html

Но когда я смотрю на ответ.Файлы cookie, я вижу гораздо больше файлов cookie, чем я ожидал, причем значения разных файлов cookie разделяются на разные файлы cookie.

Получение заголовков вручную, по-видимому, приводит к большей странности

например:код

foreach(string cookie in response.Headers.GetValues("Set-Cookie"))
{
    Console.WriteLine("Cookie found: " + cookie);
}

производит вывод:

Cookie found: user=v.5
Cookie found: 0
Cookie found: EX01E508801E$97$2E401000t$1BV6$A1$EC$104$A1$EC$104$A1$EC$104$21O00
1000$1E31!90$7CP$AE$3F$F3$D8$19o$BC$1Cd$23; Domain=.thedomain.com; path=/
Cookie found: minfo=v.4
Cookie found: EX019ECD28D6k$A3$CA$0C$CE$A2$D6$AD$D4!2$8A$EF$E8n$91$96$E1$D7$C8$0
F$98$AA$ED$DC$40V$AB$9C$C1$9CF$C9$C1zIF$3A$93$C6$A7$DF$A1$7E$A7$A1$A8$BD$A6$94c$
D5$E8$2F$F4$AF$A2$DF$80$89$BA$BBd$F6$2C$B6$A8; expires=Sunday
Cookie found: 31-Dec-2014 23:59:59 GMT; Domain=.thedomain.com; path=/
Cookie found: accttype=v.2
Cookie found: 3
Cookie found: 1
Cookie found: EX017E651B09k$A3$CA$0C$DB$A2$CB$AD$D9$8A$8C$EF$E8t$91$90$E1$DC$C89
$98$AA$E0$DC$40O$A8$A4$C1$9C; expires=Sunday
Cookie found: 31-Dec-2014 23:59:59 GMT; Domain=.thedomain.com; path=/
Cookie found: tpid=v.1
Cookie found: 20001; expires=Sunday
Cookie found: 31-Dec-2014 23:59:59 GMT; Domain=.thedomain.com; path=/
Cookie found: MC1=GUID=541977e04a341a2a4f4cdaaf49615487; expires=Sunday
Cookie found: 31-Dec-2014 23:59:59 GMT; Domain=.thedomain.com; path=/
Cookie found: linfo=v.4
Cookie found: EQC|0|0|255|1|0||||||||0|0|0||0|0|0|-1|-1; expires=Sunday
Cookie found: 31-Dec-2014 23:59:59 GMT; Domain=.thedomain.com; path=/
Cookie found: group=v.1
Cookie found: 0; expires=Sunday
Cookie found: 31-Dec-2014 23:59:59 GMT; Domain=.thedomain.com; path=/

как вы можете видеть - первый файл cookie в списке raw response:

  1. Набор-Cookie:пользователь=v.5,0,EX01E508801

становится разделенным на:

  1. Найденное печенье:пользователь=v.5
  2. Найденное печенье:0
  3. Найденное печенье:ПРИМЕР 01E508801E$..........

Итак, что здесь происходит?

  • Я ошибаюсь?
  • Класс HttpWebRequest неправильно анализирует http-заголовки?
  • Является ли веб-сервер тем, что он выплевывает запросы, создающие недопустимые http-заголовки?
Это было полезно?

Решение

Следует избегать запятых в значениях файлов cookie - возможно, вам придется закодировать их по-другому.

Оригинал спецификация netscape for cookies был немного расплывчатым по этому вопросу, заявив

ИМЯ=ЗНАЧЕНИЕ :Эта строка представляет собой последовательность символов, исключая точку с запятой и пробел.Если есть необходимость поместить такие данные в имя или значение, рекомендуется использовать какой-либо метод кодирования, такой как стиль URL рекомендуется кодировка %XX, хотя никакая кодировка не определена и не требуется.

рекомендуется, но не требуемый!

Другие советы

Похоже, что сервер отправляет неправильные значения файлов cookie.ИМХО, запятые не допускаются в значениях файлов cookie.Они должны быть закодированы с помощью %2C.

возможно, вы захотите использовать целочисленную перегрузку getValues(i);тогда вы должны вернуть только 7 строк

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