我有这个简单的 TCP 回显服务器,每当客户端连接到它时,它都会显示客户端的 IP 和端口。但是当我运行时netstat -a,会显示客户端的不同端口。我在同一台计算机上运行服务器和客户端。
在我的程序中,它显示client connected: 127.0.0.1:34997,但结果netstat -a|grep 6969是:
tcp 0 0 0.0.0.0:6969 0.0.0.0:* LISTEN
tcp 0 0 localhost:46472 localhost:6969 ESTABLISHED
tcp 0 0 localhost:6969 localhost:46472 ESTABLISHED
Run Code Online (Sandbox Code Playgroud)
echo服务器的代码是:
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <string.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <netdb.h>
#include <arpa/inet.h>
int main(int argc,char **argv){
int listenfd,confd,n;
struct sockaddr_in server,client;
pid_t pid;
char buffer[100];
memset(&server,0,sizeof server);
server.sin_family=AF_INET;
server.sin_addr.s_addr=htonl(INADDR_ANY);
server.sin_port=htons(6969);
listenfd=socket(AF_INET,SOCK_STREAM,0);
if(bind(listenfd,(struct sockaddr *)&server,sizeof server)==-1){
perror("bind error");return-1;
}
if(listen(listenfd,20)==-1){
perror("listen error");return -1;
}
printf("listening for connection..\n");
for(;;){
socklen_t cllen = sizeof(client);
confd=accept(listenfd,(struct sockaddr *)&client,&cllen);
if((pid=fork())==0){
printf("client connected: %s:%d\n",inet_ntoa(client.sin_addr),client.sin_port);
close(listenfd);
for(;;){
n=read(confd,&buffer,sizeof buffer);
if(n==0) break;
write(confd,&buffer,n);
}
printf("client disconnected: %s:%d",inet_ntoa(client.sin_addr),client.sin_port);
exit(0);
}
close(confd);
}
}
Run Code Online (Sandbox Code Playgroud)
你需要字节翻转client.sin_port.
printf("client connected: %s:%d\n",inet_ntoa(client.sin_addr), ntohs(client.sin_port));
Run Code Online (Sandbox Code Playgroud)
34997 是 0x88B5。将这些字节的字节序翻转为 0xB588,即为 46472,如netstat输出所示。有关ntohs手册页的更多信息。
请注意,这client.sin_addr很可能是 an unsigned short(请参阅此处和此处的struct sockaddr_in定义,检查您自己的系统),但这将被提升为 an,因此格式说明符很好。int%d