- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
为什么 recvfrom
创建额外的 IP header ?
我要发送:
-------------
- IP header -
-------------
- Data -
-------------
但是当我尝试接收数据时,看起来好像有
-------------
- IP header -
-------------
- IP header -
-------------
- Data -
-------------
客户端代码:
#include <sys/socket.h>
#include <netinet/in.h>
#include <stdio.h>
#include <stdlib.h>
#include <arpa/inet.h>
#include <unistd.h>
#include <string.h>
#include <netinet/ip.h>
#define DEBUG 1
int main(void) {
// Create File descrptor for socket
int socket_fd;
if ((socket_fd = socket(AF_INET, SOCK_RAW, IPPROTO_IPV6)) < 0) {
perror("ERROR Socket");
exit(2);
}
char *srcIP = "127.0.0.1";
char *dstIP = "127.0.0.1";
// Create address structure
struct sockaddr_in daddr;
daddr.sin_family = AF_INET;
daddr.sin_port = 0; // Raw sockets can't use ports
inet_pton(AF_INET, "127.0.0.1", &daddr.sin_addr);
memset(daddr.sin_zero, 0, sizeof(daddr.sin_zero));
// Create a Packet
char packet[50];
memset(packet, 0, sizeof(packet));
// Structure packet
struct iphdr *ip_header = (struct iphdr *) packet;
// Data to be appended at the end of the ip header
char *data = (char *) (packet + (sizeof(struct iphdr)));
ip_header->version = 4; // IPv4
ip_header->tos = 0; // Type of service
ip_header->ihl = 5; // 5 x 32-bit words
// ip_header->tot_len = htons(sizeof(struct iphdr) + strlen(data)); // Total IP packet length
ip_header->tot_len = sizeof(packet); // Total IP packet length
ip_header->protocol = IPPROTO_IPV6; // 6in4 protocol
ip_header->frag_off = 0x00; //16 bit field = [0:2] flags + [3:15] offset = 0x0
ip_header->ttl = 0xFF; // Max number of hops 16bit
// ip_header->id = htons(54321); // 0x00; //16 bit id
ip_header->check = 0; //16 bit checksum of IP header. Can't calculate at this point
ip_header->saddr = inet_addr(srcIP);
ip_header->daddr = inet_addr(dstIP);
data[0] = 'T';
data[1] = 'E';
data[2] = 'S';
data[3] = 'T';
data[4] = '7';
data[5] = '\0';
// ip_header->check = csum((unsigned short *) packet, ip_header->tot_len);
#if DEBUG
printf("\nIP header checksum: %d\n", ip_header->check);
#endif
while (1) {
sleep(1);
if (sendto(socket_fd, (char *) packet, sizeof(packet), 0,
(struct sockaddr *) &daddr, (socklen_t) sizeof(daddr)) < 0)
perror("Packet send error");
}
return 0;
}
服务器代码:
/*** IPPROTO_RAW receiver ***/
#include <sys/socket.h>
#include <sys/types.h>
#include <netinet/ip.h>
#include <arpa/inet.h>
#include <string.h>
#include <stdio.h>
#include <stdlib.h>
int main(void)
{
int socket_fd;
struct sockaddr_in saddr;
char packet[50];
if ((socket_fd = socket(AF_INET, SOCK_RAW, IPPROTO_IPV6)) < 0) {
perror("socket_fd");
exit(EXIT_FAILURE);
}
memset(packet, 0, sizeof(packet));
socklen_t len = (socklen_t) sizeof(saddr);
while(1) {
if (recvfrom(socket_fd, packet, sizeof(packet), 0,
(struct sockaddr *)&saddr, &len) < 0)
perror("recvfrom");
int i = sizeof(struct iphdr); ////// WHY IS DATA PAYLOAD ON packet[sizeof(struct iphdr) * 2]
while (i < sizeof(packet)) {
fprintf(stderr, "%c", packet[i]);
i++;
}
printf("\n");
}
exit(EXIT_SUCCESS);
}
最佳答案
在您的发件人中,您需要设置IP_HDRINCL
套接字选项。这告诉 API 您正在手动提供 IP header 。因为您没有设置此选项,所以您实际上是在系统添加的 IP header 之后放置了您自己的 IP header 副本。
关于c - 为什么 recvfrom 创建额外的 IP header ?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33288379/
伙计们, 这个问题困扰我好久了,求大神指点!我在一台笔记本电脑上有服务器,它正在将数据发送到另一台笔记本电脑上的客户端,同一个局域网。我可以在服务器端和客户端的 wireshark 上看到 udp 数
这是我的 udp 服务器端代码 #include"headers.h" int main(int argc,char **argv) { //------------udp server so
给定len参数设置为10240,我必须反复调用该函数以获取所有数据。但这最终导致阻塞。如何获得所有数据并以独立于平台的方式安全返回? 顺便说一句,我在发送方使用netcat: cat ocr_pi.p
我正在使用 recvfrom 从网络接收多播消息。 系统上有两个网络接口(interface),recvfrom 只从第一个接口(interface)接收。 当第 2 个接口(interface)正常
我想处理 SIGUSR1 信号,所以我做了它需要的一切并且它工作了。但是在我的程序中,我在 recvfrom 等待,当我处理信号然后返回到 recvfrom 时,我从这个函数中得到了 -1。是否可以返
这是一个多客户端套接字程序。 当我尝试运行我的程序时,最后几个recvfrom() 不返回任何数据。但之前的recvfrom有多余的数据。有人可以帮我解决这个问题吗? 客户: while (1) {
我有一个 UDP 服务器实现,我在 recvfrom 调用中遇到段错误。 #define SIZEOF sizeof #define PKTSIZE 65535 char tmp_bu
在基于客户端-服务器架构的设置中,我的客户端通过大小为 116 字节的 UDP 套接字发送数据。但在服务器端,程序只接收24个字节。如有任何帮助,我们将不胜感激。 我尝试使用wireshark捕获数据
我正在编写一个简单的 udp 服务器应用程序,当我尝试获取远程连接用户的地址时遇到错误。 while(run == 1) { struct sockaddr_in client_addr;
我最近用 C 语言编写了一个 netflow 接收器,它通过 UDP 监听 netflow。一旦处理完流数据报,它就会将其写入系统日志。我的问题是,一旦我收到带有标准 recvfrom 函数的数据报包
我有一个简单的代码来发送和接收 ICMP 数据包,例如 ping,一切正常:我的数据包已发送并且收到了结果。我的recvfrom结果有问题,缓冲区中的ip dest/src不是服务器dest ip。
我有开源 cod(这是它的链接) 访问https://github.com/jtRIPper/dns-tcp-socks-proxy/blob/master/dns_proxy.c在鳕鱼的这一部分
在准备第一次编码 UDP 时,我正在尝试一些从 here 复制并稍微修改过的示例客户端和服务器代码。 。一切似乎都正常,除了由 recvfrom() 返回的值始终是缓冲区的大小而不是读取的字节数(如果
我正在用 C 语言编写一个简单的多线程客户端-服务器 UDP 程序,其中我一次向服务器发送多条消息,并在接收线程中等待回复。我这样做是为了测试发送和接收数据包的时间。 我已经用我的服务器在本地测试了
我需要实现以下行为:当服务器启动时,它应该使用广播检查现有服务器。然后它等待回答。 但是,如何设置等待超时? int optval = 1; char buff[BUFF_SIZE]; SOCKADD
您好,我是 Socket 编程的新手,我尝试创建一个客户端服务器应用程序,其中我的服务器是相机,我的 C++ 应用程序中是客户端。当我看到计算机和相机之间的数据包传输时,它显示相机在停止后发送了超过
我在使用 recvfrom() 时遇到一些问题,无法在 C++ 中获取所有数据包。 (然后阻塞不返回) 我发送了 1 个查询数据包,然后发送了一个响应。 它被分成多个805字节的数据包,然后以一个~2
我不明白 recvfrom 在以下情况下的行为:我有一个发送和接收 udp 数据包并休眠的循环;根据该位接收 (recvfrom) 延迟会有所不同。如果我睡了 22 毫秒或更长时间,则延迟约为 170
我在编写小型 DNS 服务器并将其 strip 化到最低限度时偶然发现了一个奇怪的行为。该程序应在 127.0.0.1:1337 上监听 DNS 查询并以拒绝回复。我通过发出 dig @localho
我正在尝试通过 udp 实现距离 vector 路由。我有以下结构: struct cost_info { uint8_t id; uint8_t pad; uint16_t
我是一名优秀的程序员,十分优秀!