- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
更新:我刚刚初始化了有问题的函数中硬编码的结构,但仍然收到错误!
void sendjoin(unsigned int ipaddress, unsigned short port, unsigned short preferredID){
printf("Sending join-request...\n");
char msg[9];
memset(msg, 0, 9);
msg[0] = JOIN_MASK | INTERN_MASK;
ipaddress = ipaddress;
port = port;
preferredID = htons(preferredID);
memcpy(&msg[1], &ipaddress, 4);
memcpy(&msg[5], &port, 2);
memcpy(&msg[7], &preferredID, 2);
errno = 0;
//printMSG((void *)&succAddr, sizeof(succAddr), 0);
socklen_t addrlen = sizeof(struct sockaddr_in);
struct sockaddr_in *temp = (struct sockaddr_in *) malloc(sizeof(struct sockaddr_in));
temp->sin_family = AF_INET;
temp->sin_port = htons((short)8888);
temp->sin_addr.s_addr = htonl(16777343);
if(0 > sendto(sock, msg, 9, 0, (struct sockaddr *)temp, addrlen)){
perror("Error while sending a packet.\n");
switch(errno){
case EFAULT:
printf("Invalid user space address.\n");
break;
case EAGAIN:
printf("Something with blocking.\n");
break;
case EBADF:
printf("Invalid descriptor.\n");
break;
case EINVAL:
printf("Invalid argument.\n");
break;
case EDESTADDRREQ:
printf("No Peer address.\n");
break;
case EISCONN:
printf("Connection mode socket.\n");
break;
case ENOTSOCK:
printf("The given socket is not a socket.\n");
break;
case ENOTCONN:
printf("No Target.\n");
break;
case ENOBUFS:
printf("Network output is full.\n");
break;
default:
printf("No spezific error.\n");
}
exit(1);
}
printf("Send to: %u %u\n", ntohl(succAddr.sin_addr.s_addr), ntohs(succAddr.sin_port));
}
我正在编写这个分布式哈希表服务器。这是一个 super 简单的版本。我刚刚开始,有一个服务器只是监听包。另一个尝试加入第一个的 dht 网络。因此,我用端口号、系列 AF_INET 和 IP 地址填充全局结构 sockaddr_in。
我使用函数 inet_ntop() 将“localhost”字符串转换为我的结构。后来我使用 sendto() 开始与 dht 网络通信。但它只是给出“无效的用户空间地址”错误。
sendto() 获取一个打开的套接字(自己打开的服务器套接字!)、一个初始化的缓冲区、其长度、sockaddr_in 结构作为地址及其长度。
这是相当多的代码。我删除了一些未使用的函数,并尝试仅包含使用变量的函数。在 main() 中你可以看到三个函数。一个是 checkarguments() ,它并不是很有趣。然后你有setsocket()函数,它可以让我使用一个服务器套接字。在此函数的最后,我将填写该服务器的前任服务器和后继服务器的 IP 地址、端口和 ID。然后你可以使用 Letsgo() 函数来尝试加入 dht 网络。它用已知的dht节点的地址填充全局struct sockaddr_in succAddr,因为对sendjoin()函数的调用总是发送到succAddr。在 sendjoin() 中,它尝试发送到 succAddr 但失败。我不知道为什么。我的 succAddr 已初始化,不应指向无效的用户空间?!
请帮忙:)
这是我的代码:
//=================================
//=Variablen=======================
//=================================
unsigned short myID = 0;
char *myIP= NULL;
char *myPORT = NULL;
char *nodeIP = NULL;
char *nodePORT = NULL;
int sock = 0;
struct sockaddr_in preAddr;
unsigned short preID = 0;
int preknown = 1;
struct sockaddr_in succAddr;
unsigned short succID = 0;
char packet[PACKETSIZE];
struct sockaddr_storage sender;
socklen_t sendersize = sizeof sender;
int tablefunctionstarted = 0;
char INTERN_MASK = 0b10000000;
char STABILIZE_MASK = 0b00000100;
char NOTIFY_MASK = 0b00000010;
char JOIN_MASK = 0b00000001;
char SNJ_MASK = 0b00000111;
//=================================
//=Functions=======================
//=================================
void setSocket();
int checkarguments(int argc, char **argv);
int letsgo();
void printMSG(char *msg, int msglength, int plain);
void handleintern(unsigned long msglength);
void handleoutside(unsigned long msglength);
void sendjoin(unsigned int ipaddress,unsigned short port, unsigned short preferredID);
void sendnotify(unsigned int ipaddress,unsigned short port, unsigned short preferredID);
void sendstabilize();
int main(int argc, char **argv){
printf("Starting server...\n");
int einklinken = checkarguments(argc, argv);
setSocket();
if(einklinken) if(letsgo()){ perror("Problem while joining DHT network!\n"); exit(2);};
/*
//Hauptpacketannahmeverarbeitungsschleife
long check = 0;
while(1){
printf("Server is waiting for packets... \n");
if(-1 == (check = recvfrom(sock, packet, PACKETSIZE, 0, (struct sockaddr *)&sender, &sendersize))){
perror("Error with new packet!\n");
exit(2);
}
printf("Found packet... \n");
//printMSG(packet, check, 1);
if(0 != (packet[0] & INTERN_MASK)) handleintern(check);
else handleoutside(check);
}
*/
}
int checkarguments(int argc, char **argv){
if(argc < 3){ fprintf( stderr,"Too few arguments! \nUsage: %s myip myport\nOptions:\n-id preferredID (Your preferred id in the DHT network.)\n-new ip port (IP address and port of a DHT network node.)", argv[0]); exit(1);}
if(argc > 8){ fprintf( stderr,"Too many arguments! \nUsage: %s myip myport\nOptions:\n-id preferredID (Your preferred id in the DHT network.)\n-new ip port (IP address and port of a DHT network node.)", argv[0]); exit(1);}
/* printf("Arguments:\n");
for(int i = 0; i < argc; ++i){
printf("%s\n", argv[i]);
} */
printf("Parsing arguments...\n");
myIP = argv[1];
myPORT = argv[2];
printf("My ip: %s\n", myIP);
printf("My port: %s\n", myPORT);
int newNode = 0;
int count = 3;
while(argc > count){
if(argv[count][0]!='-'){fprintf( stderr,"Wrong usage! \nUsage: %s myip myport\nOptions:\n-id preferredID (Your preferred id in the DHT network.)\n-new ip port (IP address and port of a DHT network node.)", argv[0]); exit(1);}
if(argv[count][1]=='i'){
++count;
errno = 0;
long value = 0;
value = strtol(argv[count++], NULL, 10);
switch(errno){
case ERANGE:
printf("The ID could not be represented.\n");
exit(1);
case EINVAL:
printf("Unsupported base / radix.\n");
exit(1);
}
if(value > 65536){ perror("Your desired ID is over the max value of 65536!\n"); exit(1);}
myID = (short) value;
printf("My id: %u\n", myID);
}
else if(argv[count][1]=='n'){
++count;
nodeIP = argv[count++];
nodePORT = argv[count++];
printf("The nodes ip: %s\n", nodeIP);
printf("The nodes port: %s\n", nodePORT);
newNode = 1;
}
}
printf("Finished parsing arguments.\n");
return newNode;
}
void setSocket(){
printf("Configuring the socket...\n");
struct addrinfo hints, *locations, *p;
int yes=1;
memset(&hints, 0, sizeof hints);
hints.ai_family = AF_UNSPEC;
hints.ai_socktype = SOCK_DGRAM;
hints.ai_flags = AI_PASSIVE;
int rv = getaddrinfo(NULL, myPORT, &hints, &locations);
if(rv != 0){
fprintf(stderr, "getaddrinfo threw an error! Maybe your port is used?\n");
exit(1);
}
for(p = locations; p!=NULL; p=p->ai_next){
sock = socket(p->ai_family, p->ai_socktype, p->ai_protocol);
if(sock == -1){perror("SocketError");continue;}
if(setsockopt(sock, SOL_SOCKET, SO_REUSEADDR, &yes, sizeof(int)) == -1){perror("Can't clean socket!\n"); exit(1);}
if(bind(sock, p->ai_addr, p->ai_addrlen) == -1){perror("BindError");close(sock);continue;}
break;
}
if(p==NULL){
perror("Failed to bind!\n");
exit(2);
}
int check = 0;
if(-1 == (check = inet_pton(AF_INET, myIP, &(preAddr.sin_addr)))){ perror("Wrong ip format!\n"); exit(1);}
if(-1 == (check = inet_pton(AF_INET, myIP, &(succAddr.sin_addr)))){ perror("Wrong ip format!\n"); exit(1);}
memcpy(&(succAddr.sin_port), &(((struct sockaddr_in *)p->ai_addr)->sin_port), 2);
memcpy(&(preAddr.sin_port), &(((struct sockaddr_in *)p->ai_addr)->sin_port), 2);
memset(preAddr.sin_zero, 0, 8);
memset(succAddr.sin_zero, 0, 8);
preID = myID;
succID = myID;
printf("Finished configuring the socket.\n");
freeaddrinfo(locations);
}
int letsgo(){
printf("Trying to join an existent DHT network...\n");
preknown = 0;
int check = 0;
succAddr.sin_family = AF_INET;
if(-1 == (check = inet_pton(AF_INET, nodeIP, &(succAddr.sin_addr)))){ perror("Wrong ip format!\n"); exit(1);}
errno = 0;
long value = 0;
value = strtol(nodePORT, NULL, 10);
switch(errno){
case ERANGE:
printf("The node port could not be represented.\n");
exit(1);
case EINVAL:
printf("Unsupported base / radix.\n");
exit(1);
}
if(value > 65536){ perror("Your node port is over the max value of 65536!\n"); exit(1);}
succAddr.sin_port = htons((short) value);
unsigned int ipaddress = preAddr.sin_addr.s_addr;
unsigned short port = preAddr.sin_port;
unsigned short preferredID = 0;
sendjoin(ipaddress, port, myID);
while(1){
printf("Wait for notify answer... \n");
if(-1 == (check = recvfrom(sock, packet, PACKETSIZE, 0, (struct sockaddr *)&sender, &sendersize))){
perror("Error with new packet!\n");
exit(2);
}
printf("Got answer... \n");
if(0 == (packet[0] & INTERN_MASK)){ printf("Can't understand the packet.\n"); continue;}
if(0 == (packet[0] & NOTIFY_MASK || check < 8)){ printf("Not a notify packet.\n"); continue;}
memcpy(&preferredID, &packet[7], 2);
preferredID = ntohs(preferredID);
if(preferredID > TABLE_LENGTH){ perror("Preferred id is too big!\n"); continue;}
memcpy(&ipaddress, &packet[1], 4);
memcpy(&port, &packet[5], 2);
succAddr.sin_addr.s_addr = ipaddress;
succAddr.sin_port = port;
succID = preferredID;
break;
}
return 0;
}
void sendjoin(unsigned int ipaddress, unsigned short port, unsigned short preferredID){
printf("Sending join-request...\n");
char msg[9];
memset(&msg, 0, 9);
msg[0] = JOIN_MASK | INTERN_MASK;
ipaddress = ipaddress;
port = port;
preferredID = htons(preferredID);
memcpy(&msg[1], &ipaddress, 4);
memcpy(&msg[5], &port, 2);
memcpy(&msg[7], &preferredID, 2);
errno = 0;
//printMSG((void *)&succAddr, sizeof(succAddr), 0);
socklen_t addrlen = sizeof(struct sockaddr_in);
if(0 > sendto(sock, msg, 9, 0, (struct sockaddr *)&succAddr, addrlen)){
perror("Error while sending a packet.\n");
switch(errno){
case EFAULT:
printf("Invalid user space address.\n");
break;
case EAGAIN:
printf("Something with blocking.\n");
break;
case EBADF:
printf("Invalid descriptor.\n");
break;
case EINVAL:
printf("Invalid argument.\n");
break;
case EDESTADDRREQ:
printf("No Peer address.\n");
break;
case EISCONN:
printf("Connection mode socket.\n");
break;
case ENOTSOCK:
printf("The given socket is not a socket.\n");
break;
case ENOTCONN:
printf("No Target.\n");
break;
case ENOBUFS:
printf("Network output is full.\n");
break;
default:
printf("No spezific error.\n");
}
exit(1);
}
printf("Send to: %u %u\n", ntohl(succAddr.sin_addr.s_addr), ntohs(succAddr.sin_port));
}
最佳答案
这一行:
socklen_t addrlen = sizeof(struct sockaddr);
需要:
socklen_t addrlen = sizeof(struct sockaddr_in);
关于c - UDP sendto() 给出 "invalid user space address"错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40962063/
我刚刚了解了 udp 校验和计算。 但我很困惑算法是否检测到所有错误。 最佳答案 当然不是。没有校验和可以检测到所有错误。 关于udp - UDP 校验和是否检测到所有错误?,我们在Stack Ove
下面这个函数有什么问题?? 它应该抛出错误,因为我没有在本地主机上运行 UDP 服务器。 int openUdpSocket(int port) { int sock,sin_size;
我正在尝试修改这两个程序。我想让 udpclient.c 能够接收消息并让 udpserver.c 将消息回显给客户端。我还想在 udpclient 发送消息之前先获取它们的时间标记消息。收到的消息应
我有相当简单的 UDP 服务器写在 c 上。 有时我需要知道在套接字中排队的所有 udp 数据包(字节)的当前长度。 据我了解,getsockopt 没有得到这样的信息。 欢迎使用 Linux 和 F
除了直播音乐/视频外,谁能告诉在哪里使用 UDP 协议(protocol)? UDP 的默认用例是什么? 最佳答案 其他任何您需要性能但如果数据包在途中丢失时可以生存的东西。例如,多人游戏浮现在脑海中
与 TCP 的监视方法相反,UDP 是否会在所有数据包可用时立即发送它们? 谢谢。 最佳答案 TCP 有拥塞控制,UDP 没有,因为它是无连接的。 但是您的问题涉及多个问题:发送消息是否会导致立即发送
我知道 UDP 本质上是不可靠的,但是当连接到 localhost 时,我希望内核以不同的方式处理连接,因为一切都可以在内部处理。那么在这种特殊情况下,UDP 是否被认为是一种可靠的协议(protoc
我正在尝试使用 flash 和 rtmfp 协议(protocol)开发一个实时视频聊天应用程序,但我有疑问rtmfp 如何保证连接对等点,尤其是当对等点位于不同网络时。 最佳答案 RTMFP 依靠中
我发现所有使用 Netty 4.0 的 TCP 服务器实现都使用了 ServerBootstrap 实例。 The biggest and only difference between a serv
对于个人 MMO 游戏项目,我正在 java 中实现一个自制的可靠的基于 UDP 的协议(protocol)。鉴于我当前的设置,我相信窥探者劫持 session 相对简单,因此为了防止这种情况,我借此
我正在尝试手动计算各种 UDP 数据包的校验和,但与 Wireshark 中显示的结果相比,我总是得到错误的结果。下面是我如何做到这一点的示例: Source Address: 192.168.0.1
我正在尝试手动计算各种 UDP 数据包的校验和,但与 Wireshark 中显示的结果相比,我总是得到错误的结果。下面是我如何做到这一点的示例: Source Address: 192.168.0.1
我有一个奇怪的问题。我有一个成功运行的 C++ (boost asio) P2P 应用程序,它可以在大多数 NAT 上运行。问题是,当我将初始启动端口号指定为 1000 时,它会检查 1000 是否空
带有数据源的短 radio 链路,需要通过 IPv6 的 1280 Kbps 吞吐量,使用 UDP 停止和等待协议(protocol),该区域内没有其他客户端或明显的噪声源。我到底如何才能计算出最佳数
似乎可以在没有有效负载的情况下发送 UDP 数据包。 我能想到的唯一不需要有效载荷的就是用于 NAT 打洞。 这还能用来做什么? 这与我之前的问题有关Under Linux, can recv eve
我有一个客户端,我无法更改其代码 - 但我想(重新)使用 编写代码ZeroMQ socket 。 客户端同时使用原始 TCP 和原始 UDP socket 。 我知道我可以使用 ZMQ_ROUTER_
网络 4.0.24 我通过 UDP 传递 XML。收到 UPD 数据包时,数据包的长度始终为 2048,截断消息。尽管如此,我尝试将接收缓冲区大小设置为更大的值(4096、8192、65536),但它
我正在尝试编写一个有关 UDP 连接的简单程序来了解它们。我已经实现了一些基本的事情,但是当我尝试发送并取回我发送的内容时,我遇到了一些问题,例如, 当我这样做时;发送一个字符串 “asd”到服务器我
当我检查时,我在 UDP 客户端每 100 毫秒从服务器发送 UDP 数据包 接收频率不等于 100 毫秒,有时它要少得多,例如 3 毫秒…10 毫秒。 我知道UDP client server是异步
海友我是一个学习winsock2的新手。以下是我的udp服务器和客户端程序。 我这个程序客户端不知道服务器的IP地址,只知道端口。但是服务器会在整个网络中广播一条消息。 当客户端收到消息时,它会回溯服
我是一名优秀的程序员,十分优秀!