- This topic has 4 replies, 2 voices, and was last updated 18 years, 11 months ago by
VK.
-
AuthorPosts
-
November 27, 2006 at 7:18 pm #5075
Использую WinpkFilter 3.0 и VC++ 2005
Перехватив пакет, получаю, что значения некоторых полей IP заголовка неверные, а некоторые верные. Вот значения переменных для перехваченного ICMP эхо-пакета, пингующего ntoskrnl.com.
http://img314.imageshack.us/img314/8563/strbagzu6.jpg

Структура, описывающая IP заголовок:
typedef struct iphdr
{
u_char ip_hl:4, /* header length */
ip_v:4; /* version */
u_char ip_tos; /* type of service */
u_short ip_len; /* total length */
u_short ip_id; /* identification */
short ip_off; /* fragment offset field */
#define IP_DF 0x4000 /* dont fragment flag */
#define IP_MF 0x2000 /* more fragments flag */
u_char ip_ttl; /* time to live */
u_char ip_p; /* protocol */
u_short ip_sum; /* checksum */
struct in_addr ip_src,ip_dst; /* source and dest address */
} iphdr, *iphdr_ptr;
Думал, может в ней ошибка, но IP адреса, которые находятся в самом конце заголовка, верные!
Подскажите, в чем может быть моя ошибка?November 27, 2006 at 7:28 pm #6183А какие поля неправильные то?
November 27, 2006 at 7:49 pm #6184@SerpentFly wrote:
А какие поля неправильные то?
сразу можно сказать, что неправильные ip_len (т.к. пинг-пакет – 32 байта данных) ip_hl (должен быть равен 20) и ip_p (должен быть равен 1 – протокол ICMP).
November 27, 2006 at 8:21 pm #6185сразу можно сказать, что неправильные ip_len (т.к. пинг-пакет – 32 байта данных) ip_hl (должен быть равен 20) и ip_p (должен быть равен 1 – протокол ICMP).
ip_len у вас показан как 12288, в 16-ричном представлении это 0х3000, учитывая сетевой порядок байт в пакете получаем 0x0030 = 48 байт. ip_hl измеряется в двойных словах, тут все верно 5 двойных слов (DWORD) это как раз 20 байт. Ну а протокол (ip_p) определен как TCP (6), из картинки не следует что это ICMP пакет, так что осмелюсь предположить что вы ошиблись приняв этот пакет за ICMP.
November 27, 2006 at 8:42 pm #6186Большое спасибо за разъяснение.
Действительно, сетевой порядок байт и то, что длинна заголовка измеряется DWORD’ами я не учел. RFC не читал, а большинство снифферов длину заголовка выдают в байтах, вот я подумал, что так и в самом пакете. И насчет ICMP пакета я тоже ошибся, видимо это был TCP HTTP пакет.
-
AuthorPosts
- You must be logged in to reply to this topic.
