ANTICHAT — форум по информационной безопасности, OSINT и технологиям
ANTICHAT — русскоязычное сообщество по безопасности, OSINT и программированию.
Форум ранее работал на доменах antichat.ru, antichat.com и antichat.club,
и теперь снова доступен на новом адресе —
forum.antichat.xyz.
Форум восстановлен и продолжает развитие: доступны архивные темы, добавляются новые обсуждения и материалы.
⚠️ Старые аккаунты восстановить невозможно — необходимо зарегистрироваться заново.
 |
|

19.02.2009, 18:22
|
|
Новичок
Регистрация: 04.02.2009
Сообщений: 12
Провел на форуме: 18348
Репутация:
0
|
|
C# HTTP POST
Всем привет, помогите тут разобраться кое в чем, пытаюсь заставить сервер прислать мне страницу методом POST, вот что имеется:
Код:
public static string Login()
{
IPHostEntry hostEntry = Dns.GetHostEntry("сайт");
IPAddress address = hostEntry.AddressList[0];
IPEndPoint ipe = new IPEndPoint(address, 80);
Socket socket = new Socket(ipe.AddressFamily, SocketType.Stream, ProtocolType.Tcp);
try
{
socket.Connect(ipe);
if (socket.Connected)
{
Console.WriteLine("Connected to " + ipe.ToString());
}
else
{
Console.WriteLine("Can not connect...");
}
}
catch (SocketException ex)
{
Console.WriteLine(ex.Message);
}
string request =
"POST сайт HTTP/1.1\r\n" +
"Accept: text/html\r\n" +
"Host: сайт\r\n" +
"Cookie: income=1\r\n" +
"Referer: сайт\r\n"+
"Content-Length: " + "142" + "\r\n" +
"Content-Type: application/x-www-form-urlencoded\r\n\r\n"
+"параметры";
Byte[] bytesSent = Encoding.ASCII.GetBytes(request);
Byte[] bytesReceived = new Byte[1024];
socket.Send(bytesSent, bytesSent.Length, 0);
string page = "";
int bytes = 0;
do
{
bytes = socket.Receive(bytesReceived, bytesReceived.Length, 0);
page = page + Encoding.ASCII.GetString(bytesReceived, 0, bytes);
}
while (bytes > 0);
return page;
}
Получаю вместо страницы это:
Код:
HTTP/1.1 302 Moved Temporarily
X-Powered-By: Servlet/2.5
Server: Sun Java System Application Server 9.1_02
Set-Cookie: JSESSIONID=ac85e657399e7058ae4fd3fe2505; Path=/
Pragma: no-cache
Expires: Thu, 01 Jan 1970 00:00:00 GMT
Cache-Control: no-cache
Cache-Control: no-store
X-Powered-By: JSF/1.2
Location: сайт
Content-Type: text/html; charset=iso-8859-1
Content-Length: 0
Date: Wed, 18 Feb 2009 19:06:40 GMT
Connection: close
Чего не хватает?
Последний раз редактировалось Maxidrom; 19.02.2009 в 18:25..
|
|
|

19.02.2009, 18:34
|
|
Познавший АНТИЧАТ
Регистрация: 12.05.2007
Сообщений: 1,235
Провел на форуме: 2238549
Репутация:
1318
|
|
Если ты всё правильно послал, и это действительно тот результат, который предусмотрен логикой сайта, то при получении HTTP-кода 302 ты должен проследовать туда, куда тебе указывает Location в ответе. Такая схема вполне нормальна при авторизации, например. Ты отправляешь постом необходимые данные, а в ответ скрипт посылает тебе 302 Moved Temporarily и указание того, что ты должен открыть далее. Это называется "редирект".
|
|
|

19.02.2009, 18:38
|
|
Познавший АНТИЧАТ
Регистрация: 12.05.2007
Сообщений: 1,235
Провел на форуме: 2238549
Репутация:
1318
|
|
Ах да... Забыл добавить, не забывай анализировать строки установки кук, у тебя это:
Set-Cookie: JSESSIONID=ac85e657399e7058ae4fd3fe2505; Path=/
То есть при переходе на страницу куда тебя послали в 302 ответе ты должен будешь указать:
Cookie: JSESSIONID=ac85e657399e7058ae4fd3fe2505; Path=/
Иначе сайт не подхватит твою сессию.
|
|
|

19.02.2009, 19:48
|
|
Новичок
Регистрация: 04.02.2009
Сообщений: 12
Провел на форуме: 18348
Репутация:
0
|
|
groundhog ок сделал как ты посоветовал, но ответа нет и вовсе, вобщем в своем коде сразу после цикла добавил:
Код:
string[] get =
{"GET адрес из Location HTTP/1.1",
"Accept: text/html" ,
"Host: сайт" ,
"Referer: откуда",
""
};
// В temp загнал куки
get[get.Length-1] = "Cookie:" + temp;
// Шлю серверу
socket.Send(bytesSent, bytesSent.Length, 0);
В ответ ничего не получаю, и еще вопрос, возможно я щас попробую еще, ответ что из себя представлять будет, допустим HTTP/1.1 200 OK, там что-то еще и дальше сама страница?
|
|
|

19.02.2009, 19:52
|
|
Познавший АНТИЧАТ
Регистрация: 12.05.2007
Сообщений: 1,235
Провел на форуме: 2238549
Репутация:
1318
|
|
Если 200 OK то следом после хидеров ты получаешь контент запрошенного ресурса, то есть содержимое страницы в твоём случае. Если у тебя запрос "повис" то ты скорее всего не правильно сормировал пакет. В GET запросах такое бывает сплошь и рядом, если ты после хидеров не указал пустую строку. После последнего хидера обязательно должно быть \r\n\r\n.
|
|
|

19.02.2009, 20:05
|
|
Новичок
Регистрация: 04.02.2009
Сообщений: 12
Провел на форуме: 18348
Репутация:
0
|
|
Спасибо groundhog буду сейчас пробовать.
|
|
|

19.02.2009, 21:42
|
|
Новичок
Регистрация: 04.02.2009
Сообщений: 12
Провел на форуме: 18348
Репутация:
0
|
|
Ребят а что делать если возникает ошибка 505 HTTP Version Not Supported, я юзаю HTTP/1.1, снифером смотрел браузер тоже HTTP/1.1 юзает, где косяк может быть? Опять неправильно составил запросы?
Отбой ребят, пробел лишний поставил))) все работает, спасибо за помощь
Последний раз редактировалось Maxidrom; 19.02.2009 в 21:47..
|
|
|

19.02.2009, 22:46
|
|
Новичок
Регистрация: 04.02.2009
Сообщений: 12
Провел на форуме: 18348
Репутация:
0
|
|
Работает но что-то не так как нужно, не ту страницу грузит, вот когда я делаю редирект, правильно ли делать это методом GET, в принципе так делает и браузер, снифер показывает сначала POST потом GET, Location взял, куки взял, чего-то может быть не хватает?
|
|
|

20.02.2009, 00:21
|
|
Познавший АНТИЧАТ
Регистрация: 12.05.2007
Сообщений: 1,235
Провел на форуме: 2238549
Репутация:
1318
|
|
Всё правильно, по редиректу идёшь методом GET. Проверь ещё раз кукисы, любая неточность может приводить к непредсказуемому результату. Ну и, конечно, когда идёшь на страницу после редиректа - передавай referer с той страницей которая послала этот редирект. Реферер может анализироваться скриптами и перебрасывать куда-нибудь ещё если не удовлетворяет требованиям.
|
|
|

20.02.2009, 01:18
|
|
Новичок
Регистрация: 04.02.2009
Сообщений: 12
Провел на форуме: 18348
Репутация:
0
|
|
ээээх groundhog вот так я тупанул, я смотрел снифером что делает браузер когда у него уже были куки и он сразу юзал POST, только вот до меня доперло удалить куки и посмотреть что он делает, он вначале шлет GET а потом за ним POST, 2 часа убил зря( сейчас буду исправлять...
|
|
|
|
 |
|
|
Здесь присутствуют: 1 (пользователей: 0 , гостей: 1)
|
|
|
|