3

我有用 C 编写的服务器和客户端程序,它工作正常,但我无法找出下面解释的行为的原因:

服务器.c

server_address.sin_family = AF_INET;
server_address.sin_port = htons(9374);
server_address.sin_addr.s_addr = htonl(INADDR_ANY);  
server_len = sizeof(server_address);    
bind(server_sockfd, (struct sockaddr *)&server_address, server_len);

getsockname (server_sockfd, (struct sockaddr *)&server_address, &server_len);
printf("server port = %d\n", server_address.sin_port); 
printf("Server Waiting......\n");
listen(server_sockfd, 5);

客户端.c

address.sin_family = AF_INET;
address.sin_port = htons(9374);

int length, result;
length = sizeof(address);

result = connect(sockfd, (struct sockaddr *)&address, length);

getsockname(sockfd, (struct sockaddr *)&address, &length);
printf("Connecting to Port = %d \n", address.sin_port);

在服务器端输出:

[root@dhcppc1 Socket]# ./server
server port = 40484 
Server Waiting......

客户端输出:

[root@dhcppc1 Socket]# ./client
Connecting to Port = 18576 

我的问题是:

虽然9374在服务器和客户端代码中实现了相同的端口号(

4

1 回答 1

4

getsockname() 返回连接的本地端口号。一个 TCP 连接有两个端口,一个用于连接的每一端。

由于您的客户端没有调用 bind() 来选择本地端口,因此系统为您随机选择了一个。

因此,您的服务器程序正在显示它正在侦听的自己的端口,而您的客户端显示它自己的发送端口。

另请注意,您正在以网络端格式打印端口号,要以主机端格式打印,请像这样使用 ntohs() (在客户端上类似)

printf("server port = %d\n", ntohs(server_address.sin_port));

这将使服务器打印出 9374

如果您想获取客户端上的服务器端口,请使用 getpeername() 而不是 getsockname() - 再说一次,您已经知道服务器端口,因为那是您连接的端口,9374。

于 2013-04-04T19:18:40.050 回答