Я пытаюсь понять, как работает функция Recvfrom() в Linux.
Я открыл необработанный сокет и прочитал пакеты ICMP на интерфейсе.
Я думал, что функция Recvfrom() копирует пакет из ядра в приложение.
Я попытался прочитать пакет запроса ICMP, очистить буфер и ожидать, что не смогу получить ответ ICMP.
Но, похоже, я все еще получаю ответ ICMP.
Я неправильно понимаю работу сети или что-то не так в коде?
Размер ICMP-пакета по умолчанию был 98.
Итак, я только что использовал длину пакета, чтобы проверить, является ли прочитанный пакет ICMP или нет. .
Что я хочу сделать, так это получить пакет ICMP от интерфейса и очистить или удалить буфер пакетов.
И это может фактически нарушить обмен пакетами ICMP или нет.
Я хочу получить пакет ICMP от интерфейса и очистить или удалить буфер пакетов.
Что я хочу сделать, так это получить пакет ICMP от интерфейса и очистить или удалить буфер пакетов.
И это может фактически нарушить обмен пакетами ICMP или нет.
p>
Я запустил эту программу на ПК2, как показано на схеме ниже.
И отправил ICMP-пакет с ПК1 на ПК3.
+-------+ +-------+ +-------+
| | | | | |
| PC 1 | ----- | PC 2 | ----- | PC 3 |
| | | | | |
+-------+ +-------+ +-------+
int main(int argc, char *argv[])
{
int32_t sock;
int8_t buf[1522];
int32_t ifindex;
int32_t ret;
int32_t bytes;
struct sockaddr_ll sll;
struct ifreq ifr;
time_t rawtime;
struct tm *info;
time(&rawtime);
info = localtime(&rawtime);
sock = socket(PF_PACKET, SOCK_RAW, htons(ETH_P_ALL));
if (sock == -1)
{
printf("socket open failed\n");
return 1;
}
strncpy(ifr.ifr_name, "eth1", sizeof(ifr.ifr_name));
ret = ioctl(sock, SIOCGIFINDEX, &ifr);
if (ret < 0)
{
printf("failed to get index\n");
return -1;
}
sll.sll_family = AF_PACKET;
sll.sll_ifindex = ifr.ifr_ifindex;
sll.sll_protocol = htons(ETH_P_ALL);
ret = bind(sock, (struct sockaddr *)&sll, sizeof(struct sockaddr_ll));
if (ret < 0)
{
close(sock);
printf("interface binding error\n");
return 1;
}
while(1)
{
bytes = recvfrom(sock, buf, 1522, 0, NULL, NULL);
if (bytes < 0)
{
printf("error in recvfrom\n");
exit;
}
if (bytes == 98)
{
memset(buf, 0x0, 1522);
}
printf("%s : received bytes = %d\n", bytes);
}
close(sock);
return 0;
}
Подробнее здесь: https://stackoverflow.com/questions/784 ... m-in-linux
Работа Recvfrom() в Linux ⇐ Linux
1714353361
Anonymous
Я пытаюсь понять, как работает функция Recvfrom() в Linux.
Я открыл необработанный сокет и прочитал пакеты ICMP на интерфейсе.
Я думал, что функция Recvfrom() копирует пакет из ядра в приложение.
Я попытался прочитать пакет запроса ICMP, очистить буфер и ожидать, что не смогу получить ответ ICMP.
Но, похоже, я все еще получаю ответ ICMP.
Я неправильно понимаю работу сети или что-то не так в коде?
Размер ICMP-пакета по умолчанию был 98.
Итак, я только что использовал длину пакета, чтобы проверить, является ли прочитанный пакет ICMP или нет. .
Что я хочу сделать, так это получить пакет ICMP от интерфейса и очистить или удалить буфер пакетов.
И это может фактически нарушить обмен пакетами ICMP или нет.
Я хочу получить пакет ICMP от интерфейса и очистить или удалить буфер пакетов.
Что я хочу сделать, так это получить пакет ICMP от интерфейса и очистить или удалить буфер пакетов.
И это может фактически нарушить обмен пакетами ICMP или нет.
p>
Я запустил эту программу на ПК2, как показано на схеме ниже.
И отправил ICMP-пакет с ПК1 на ПК3.
+-------+ +-------+ +-------+
| | | | | |
| PC 1 | ----- | PC 2 | ----- | PC 3 |
| | | | | |
+-------+ +-------+ +-------+
int main(int argc, char *argv[])
{
int32_t sock;
int8_t buf[1522];
int32_t ifindex;
int32_t ret;
int32_t bytes;
struct sockaddr_ll sll;
struct ifreq ifr;
time_t rawtime;
struct tm *info;
time(&rawtime);
info = localtime(&rawtime);
sock = socket(PF_PACKET, SOCK_RAW, htons(ETH_P_ALL));
if (sock == -1)
{
printf("socket open failed\n");
return 1;
}
strncpy(ifr.ifr_name, "eth1", sizeof(ifr.ifr_name));
ret = ioctl(sock, SIOCGIFINDEX, &ifr);
if (ret < 0)
{
printf("failed to get index\n");
return -1;
}
sll.sll_family = AF_PACKET;
sll.sll_ifindex = ifr.ifr_ifindex;
sll.sll_protocol = htons(ETH_P_ALL);
ret = bind(sock, (struct sockaddr *)&sll, sizeof(struct sockaddr_ll));
if (ret < 0)
{
close(sock);
printf("interface binding error\n");
return 1;
}
while(1)
{
bytes = recvfrom(sock, buf, 1522, 0, NULL, NULL);
if (bytes < 0)
{
printf("error in recvfrom\n");
exit;
}
if (bytes == 98)
{
memset(buf, 0x0, 1522);
}
printf("%s : received bytes = %d\n", bytes);
}
close(sock);
return 0;
}
Подробнее здесь: [url]https://stackoverflow.com/questions/78400103/operation-of-recvfrom-in-linux[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия