C 我的UDP客户端服务器有什么问题?
我有一个UDP服务器,它应该坐在那里等待客户端连接到它,然后向它发送一个文件名字符串。现在我只希望它将文件名回显到客户端。这是我的密码 服务器C 我的UDP客户端服务器有什么问题?,c,sockets,udp,C,Sockets,Udp,我有一个UDP服务器,它应该坐在那里等待客户端连接到它,然后向它发送一个文件名字符串。现在我只希望它将文件名回显到客户端。这是我的密码 服务器 #include <stdio.h> #include <stdlib.h> #include <unistd.h> #include <errno.h> #include <string.h> #include <sys/types.h> #include <sys/sock
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <errno.h>
#include <string.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <netdb.h>
#define MAXBUFLEN 1024
// Usage: ./server PORT
int main(int argc, char *argv[])
{
int sockfd;
struct sockaddr_in server;
size_t clientSize;
struct sockaddr_storage client;
char buf[MAXBUFLEN];
int portno = atoi(argv[1]);
int numbytes;
printf("Port: %d\n", portno);
// Create UDP Socket
if ((sockfd = socket(AF_INET, SOCK_DGRAM, 0)) == -1) {
perror("Can't create socket");
exit(-1);
}
// Configure socket
memset(&server, 0, sizeof server);
server.sin_family = AF_INET; // Use IPv4
server.sin_addr.s_addr = INADDR_ANY; // My IP
server.sin_port = htons(portno); // Server Port
// Bind socket
if ((bind(sockfd, (struct sockaddr *) &server, sizeof(server))) == -1) {
close(sockfd);
perror("Can't bind");
}
while (1) {
printf("Waiting for data...\n");
// Receive data from Client
clientSize = sizeof(client);
numbytes = recvfrom(sockfd, buf, MAXBUFLEN-1,0,
(struct sockaddr *) &client, &clientSize);
buf[numbytes] = '\0';
printf("client sent: %s\n", buf);
// Rely to client
sendto(sockfd, buf, MAXBUFLEN-1, 0,
(struct sockaddr *) &client, &clientSize);
}
printf("Closing");
close(sockfd);
return 0;
}
只有一次。。。所以它永远不会收到请求
客户端打印出:
./client 8083 127.0.0.1 hello
Port: 8083, IP:127.0.0.1, File:hello
Sent hello
Waiting for reply
server sent:
请帮忙,我对C和UDP套接字的世界还不熟悉
哦,是的,我已经读过比吉的指南了。。。请不要只是将此作为答案发布。愚蠢的问题,但您的防火墙是否阻止了8083端口
鲍勃 愚蠢的问题,但防火墙是否阻止了8083端口
鲍勃 客户端中的numbytes未初始化,也未使用!请再次检查您的代码 希望这有帮助, 顺致敬意,
Tom。您的客户机中的numbytes未初始化,也未使用!请再次检查您的代码 希望这有帮助, 顺致敬意,
Tom。首先,在服务器对sendto的调用中有一个错误。clientSize应该是一个值,而不是指针。此外,正如Tom所说,numbytes应该设置为recvfrom的结果 最大的问题可能是您正在将hp->h_名称复制到服务器的sin_addr元素中。h_name是主机名,而不是IP地址。试着替换
memcpy((char*)&server.sin_addr, (char*)hp->h_name, hp->h_length);
与
在您的客户端中。首先,您的服务器对sendto的调用中有一个错误。clientSize应该是一个值,而不是指针。此外,正如Tom所说,numbytes应该设置为recvfrom的结果 最大的问题可能是您正在将hp->h_名称复制到服务器的sin_addr元素中。h_name是主机名,而不是IP地址。试着替换
memcpy((char*)&server.sin_addr, (char*)hp->h_name, hp->h_length);
与
在您的客户端中。修复了该错误!谢谢你,汤米。这是我现在正在运行的 服务器:
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <netdb.h>
#include <stdio.h>
#define MAXBUFLEN 1024
void error(char *msg) {
perror(msg);
exit(0);
}
int main(int argc, char *argv[]) {
int sockfd;
struct sockaddr_in server, client;
int serverSize, clientSize, numbytes;
char buf[MAXBUFLEN];
int portno = atoi(argv[1]);
if (argc < 2) {
fprintf(stderr, "ERROR, no port provided\n");
exit(0);
}
printf("Running on Port: %d\n", portno);
// Create UDP Socket
sockfd = socket(AF_INET, SOCK_DGRAM, 0);
if (sockfd < 0) {
error("Can't create socket");
}
// Configure Server Info
serverSize = sizeof(server);
bzero(&server, serverSize);
server.sin_family = AF_INET;
server.sin_addr.s_addr = INADDR_ANY;
server.sin_port = htons(portno);
// Bind
if (bind(sockfd, (struct sockaddr *) &server, serverSize) < 0) {
error("binding");
}
clientSize = sizeof(struct sockaddr_in);
while (1) {
printf("Waiting for Client Request...\n");
numbytes = recvfrom(sockfd, buf, MAXBUFLEN, 0,
(struct sockaddr *) &client, &clientSize);
if (numbytes < 0) {
error("recvfrom");
}
buf[numbytes] = '\0';
printf("Received request for File: %s\n", buf);
numbytes = sendto(sockfd, buf, sizeof(buf), 0,
(struct sockaddr *) &client, clientSize);
if (numbytes < 0) {
error("sendto");
}
sendFile(sockfd, client);
}
}
sendFile(int sockfd, struct sockaddr_in client) {
}
#包括
#包括
#包括
#包括
#包括
#定义MAXBUFLEN 1024
无效错误(字符*消息){
佩罗尔(味精);
出口(0);
}
int main(int argc,char*argv[]){
int-sockfd;
服务器、客户端中的结构sockaddr_;
int serverSize、clientSize、numbytes;
char-buf[MAXBUFLEN];
int-portno=atoi(argv[1]);
如果(argc<2){
fprintf(stderr,“错误,未提供端口\n”);
出口(0);
}
printf(“在端口%d上运行”,端口号);
//创建UDP套接字
sockfd=插座(AF_INET,SOCK_DGRAM,0);
if(sockfd<0){
错误(“无法创建套接字”);
}
//配置服务器信息
serverSize=sizeof(服务器);
bzero(服务器和服务器大小);
server.sinu family=AF\u INET;
server.sin\u addr.s\u addr=INADDR\u ANY;
server.sin_port=htons(端口号);
//束缚
if(绑定(sockfd,(结构sockaddr*)&服务器,服务器大小)<0){
错误(“约束”);
}
clientSize=sizeof(结构sockaddr_in);
而(1){
printf(“等待客户端请求…\n”);
numbytes=recvfrom(sockfd,buf,MAXBUFLEN,0,
(struct sockaddr*)和clientSize);
如果(单位<0){
错误(“recvfrom”);
}
buf[numbytes]='\0';
printf(“收到文件请求:%s\n”,buf);
numbytes=sendto(sockfd,buf,sizeof(buf),0,
(struct sockaddr*)和客户端,clientSize);
如果(单位<0){
错误(“发送到”);
}
sendFile(sockfd,客户端);
}
}
sendFile(客户端中的int-sockfd、struct-sockaddr_){
}
客户:
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <netdb.h>
#include <stdio.h>
#define MAXBUFLEN 1024
void error(char *msg) {
perror(msg);
exit(0);
}
int main(int argc, char *argv[]) {
int sockfd;
struct sockaddr_in server, client;
int serverSize;
struct hostent *hp;
char buf[MAXBUFLEN];
int numbytes;
char *serverIP = argv[1];
int portno = atoi(argv[2]);
char *filename = argv[3];
int done = 1;
if (argc != 4) {
printf("Usage: SERVER PORT FILENAME\n");
exit(1);
}
// Create Socket
sockfd = socket(AF_INET, SOCK_DGRAM, 0);
if (sockfd < 0) {
error("Can't create socket");
}
// Configure Server Info
server.sin_family = AF_INET;
hp = gethostbyname(serverIP);
if (hp == 0)
error("Unknown host");
bcopy((char *) hp->h_addr, (char *) &server.sin_addr, hp->h_length);
server.sin_port = htons(portno);
serverSize = sizeof(struct sockaddr_in);
// Send Message
strcat(buf, filename);
numbytes = sendto(sockfd, buf, strlen(buf), 0, &server, serverSize);
if (numbytes < 0)
error("Sendto");
bzero(buf, MAXBUFLEN);
// Build file then set Done = 0
while (done) {
numbytes = recvfrom(sockfd, buf, MAXBUFLEN, 0, &client, &serverSize);
if (numbytes < 0)
error("recvfrom");
done = 0;
}
printf("Received the packet: %s\n", buf);
}
#包括
#包括
#包括
#包括
谢谢大家的帮助 修复了这个错误!谢谢你,汤米。这是我现在正在运行的
服务器:
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <netdb.h>
#include <stdio.h>
#define MAXBUFLEN 1024
void error(char *msg) {
perror(msg);
exit(0);
}
int main(int argc, char *argv[]) {
int sockfd;
struct sockaddr_in server, client;
int serverSize, clientSize, numbytes;
char buf[MAXBUFLEN];
int portno = atoi(argv[1]);
if (argc < 2) {
fprintf(stderr, "ERROR, no port provided\n");
exit(0);
}
printf("Running on Port: %d\n", portno);
// Create UDP Socket
sockfd = socket(AF_INET, SOCK_DGRAM, 0);
if (sockfd < 0) {
error("Can't create socket");
}
// Configure Server Info
serverSize = sizeof(server);
bzero(&server, serverSize);
server.sin_family = AF_INET;
server.sin_addr.s_addr = INADDR_ANY;
server.sin_port = htons(portno);
// Bind
if (bind(sockfd, (struct sockaddr *) &server, serverSize) < 0) {
error("binding");
}
clientSize = sizeof(struct sockaddr_in);
while (1) {
printf("Waiting for Client Request...\n");
numbytes = recvfrom(sockfd, buf, MAXBUFLEN, 0,
(struct sockaddr *) &client, &clientSize);
if (numbytes < 0) {
error("recvfrom");
}
buf[numbytes] = '\0';
printf("Received request for File: %s\n", buf);
numbytes = sendto(sockfd, buf, sizeof(buf), 0,
(struct sockaddr *) &client, clientSize);
if (numbytes < 0) {
error("sendto");
}
sendFile(sockfd, client);
}
}
sendFile(int sockfd, struct sockaddr_in client) {
}
#包括
#包括
#包括
#包括
#包括
#定义MAXBUFLEN 1024
无效错误(字符*消息){
佩罗尔(味精);
出口(0);
}
int main(int argc,char*argv[]){
int-sockfd;
服务器、客户端中的结构sockaddr_;
int serverSize、clientSize、numbytes;
char-buf[MAXBUFLEN];
int-portno=atoi(argv[1]);
如果(argc<2){
fprintf(stderr,“错误,未提供端口\n”);
出口(0);
}
printf(“在端口%d上运行”,端口号);
//创建UDP套接字
sockfd=插座(AF_INET,SOCK_DGRAM,0);
if(sockfd<0){
错误(“无法创建套接字”);
}
//配置服务器信息
serverSize=sizeof(服务器);
bzero(服务器和服务器大小);
server.sinu family=AF\u INET;
server.sin\u addr.s\u addr=INADDR\u ANY;
server.sin_port=htons(端口号);
//束缚
if(绑定(sockfd,(结构sockaddr*)&服务器,服务器大小)<0){
错误(“约束”);
}
clientSize=sizeof(结构sockaddr_in);
而(1){
printf(“等待客户端请求…\n”);
numbytes=recvfrom(sockfd,buf,MAXBUFLEN,0,
(struct sockaddr*)和clientSize);
如果(单位<0){
错误(“recvfrom”);
}
buf[numbytes]='\0';
printf(“收到文件请求:%s\n”,buf);
numbytes=sendto(sockfd,buf,sizeof(buf),0,
(struct sockaddr*)和客户端,clientSize);
如果(单位<0){
错误(“发送到”);
}
sendFile(sockfd,客户端);
}
}
sendFile(客户端中的int-sockfd、struct-sockaddr_){
}
客户:
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <netdb.h>
#include <stdio.h>
#define MAXBUFLEN 1024
void error(char *msg) {
perror(msg);
exit(0);
}
int main(int argc, char *argv[]) {
int sockfd;
struct sockaddr_in server, client;
int serverSize;
struct hostent *hp;
char buf[MAXBUFLEN];
int numbytes;
char *serverIP = argv[1];
int portno = atoi(argv[2]);
char *filename = argv[3];
int done = 1;
if (argc != 4) {
printf("Usage: SERVER PORT FILENAME\n");
exit(1);
}
// Create Socket
sockfd = socket(AF_INET, SOCK_DGRAM, 0);
if (sockfd < 0) {
error("Can't create socket");
}
// Configure Server Info
server.sin_family = AF_INET;
hp = gethostbyname(serverIP);
if (hp == 0)
error("Unknown host");
bcopy((char *) hp->h_addr, (char *) &server.sin_addr, hp->h_length);
server.sin_port = htons(portno);
serverSize = sizeof(struct sockaddr_in);
// Send Message
strcat(buf, filename);
numbytes = sendto(sockfd, buf, strlen(buf), 0, &server, serverSize);
if (numbytes < 0)
error("Sendto");
bzero(buf, MAXBUFLEN);
// Build file then set Done = 0
while (done) {
numbytes = recvfrom(sockfd, buf, MAXBUFLEN, 0, &client, &serverSize);
if (numbytes < 0)
error("recvfrom");
done = 0;
}
printf("Received the packet: %s\n", buf);
}
#包括
#包括
#包括
#包括
谢谢大家的帮助 太棒了!非常感谢。我最终改变了我的代码。我将发布一个我现在正在运行的答案。太棒了!非常感谢。我最终改变了我的代码。我将发布一个我现在正在运行的答案;C标准喜欢mem*版本。哦,struct hostent中的h_addr元素实际上是h_addr_test[0]的宏,以防将来出现混淆;C标准喜欢mem*版本。哦,struct hostent中的h_addr元素实际上是h_addr_test[0]的宏,以防将来出现混淆