首页 > 解决方案 > netstat 和 program 中的不同端口

问题描述

我有这个简单的 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 

回显服务器的代码是:

#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);

    }
}

标签: csockets

解决方案


您需要字节翻转client.sin_port.

printf("client connected: %s:%d\n",inet_ntoa(client.sin_addr), ntohs(client.sin_port));

34997 是 0x88B5。将这些字节的字节序翻转为 0xB588,得到 46472,如netstat输出所示。ntohs有关手册页的更多信息。

请注意,这client.sin_addr很可能是 an unsigned short(请参阅此处此处struct sockaddr_in的定义,检查您自己的系统),但这将被提升为 an,因此格式说明符很好。int%d


推荐阅读