gpt4 book ai didi

c - 从监听(服务器)套接字获取对等名()

转载 作者:行者123 更新时间:2023-11-30 16:40:52 25 4
gpt4 key购买 nike

我正在尝试进行套接字编程。我做了一些例子,从套接字获取ip和端口。

我尝试获取服务器和客户端的 IP 和端口。

服务器有两个套接字,监听套接字和与客户端进行数据传输的套接字(我将其命名为“客户端套接字”)。客户端有一个套接字。我想要这些套接字的本地 ip 和端口以及对等方的 ip 和端口。因此我使用了 getsockname() 和 getpeername()。

代码如下。

** 服务器 **

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <arpa/inet.h>
#include <sys/socket.h>

void error_handling(char *message);

int main(int argc, char *argv[])
{
int serv_sock;
int clnt_sock;

struct sockaddr_in serv_addr;
struct sockaddr_in clnt_addr;
socklen_t clnt_addr_size;

char message[]="Hello World!";

if(argc!=2){
printf("Usage : %s <port>\n", argv[0]);
exit(1);
}

serv_sock=socket(PF_INET, SOCK_STREAM, 0);
if(serv_sock == -1)
error_handling("socket() error");

memset(&serv_addr, 0, sizeof(serv_addr));
serv_addr.sin_family=AF_INET;
serv_addr.sin_addr.s_addr=htonl(INADDR_ANY);
serv_addr.sin_port=htons(atoi(argv[1]));



if(bind(serv_sock, (struct sockaddr*) &serv_addr, sizeof(serv_addr))==-1 )
error_handling("bind() error");

if(listen(serv_sock, 5)==-1)
error_handling("listen() error");



clnt_addr_size=sizeof(clnt_addr);
clnt_sock=accept(serv_sock, (struct sockaddr*)&clnt_addr,&clnt_addr_size);
if(clnt_sock==-1)
error_handling("accept() error");

write(clnt_sock, message, sizeof(message));

struct sockaddr_in addr1;
struct sockaddr_in addr2;

struct sockaddr_in addr3;
struct sockaddr_in addr4;

socklen_t serv_len = sizeof(serv_addr);
int serv_peer_err = getpeername(serv_sock, (struct sockaddr *)&addr1, &serv_len);
int clnt_peer_err = getpeername(clnt_sock, (struct sockaddr *)&addr2, &clnt_addr_size);

int serv_sock_err = getsockname(serv_sock, (struct sockaddr *)&addr3, &serv_len);
int clnt_sock_err = getsockname(clnt_sock, (struct sockaddr *)&addr4, &clnt_addr_size);

printf("Server socket's ip : %s\n", inet_ntoa(addr3.sin_addr));
printf("Server socket's port : %d\n", ntohs(addr3.sin_port));
printf("Server socket's peer ip : %s\n", inet_ntoa(addr1.sin_addr));
printf("Server socket's peer port : %d\n\n\n\n\n\n", ntohs(addr1.sin_port));



printf("Client socket's ip : %s\n", inet_ntoa(addr4.sin_addr));
printf("Client socket's port : %d\n", ntohs(addr4.sin_port));
printf("Client socket's peer ip : %s\n", inet_ntoa(addr2.sin_addr));
printf("client socket's peer port %d\n", ntohs(addr2.sin_port));

printf("%d %d %d %d\n", serv_peer_err, clnt_peer_err, serv_sock_err, clnt_sock_err);


close(clnt_sock);
close(serv_sock);
return 0;
}

void error_handling(char *message)
{
fputs(message, stderr);
fputc('\n', stderr);
exit(1);
}

** 客户端 **

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <arpa/inet.h>
#include <sys/socket.h>

void error_handling(char *message);

int main(int argc, char* argv[])
{
int sock;
struct sockaddr_in serv_addr;
char message[30];
int str_len;

if(argc!=3){
printf("Usage : %s <IP> <port>\n", argv[0]);
exit(1);
}

sock=socket(PF_INET, SOCK_STREAM, 0);
if(sock == -1)
error_handling("socket() error");

memset(&serv_addr, 0, sizeof(serv_addr));
serv_addr.sin_family=AF_INET;
serv_addr.sin_addr.s_addr=inet_addr(argv[1]);
serv_addr.sin_port=htons(atoi(argv[2]));

if(connect(sock, (struct sockaddr*)&serv_addr, sizeof(serv_addr))==-1)
error_handling("connect() error!");

str_len=read(sock, message, sizeof(message)-1);
if(str_len==-1)
error_handling("read() error!");

struct sockaddr_in addr1;
struct sockaddr_in addr2;

int clnt_sock_err, clnt_peer_err;
socklen_t serv_len = sizeof(serv_addr);
clnt_peer_err = getpeername(sock, (struct sockaddr *)&addr1, &serv_len);
clnt_sock_err = getsockname(sock, (struct sockaddr *)&addr2, &serv_len);

printf("Client socket's ip : %s\n", inet_ntoa(addr2.sin_addr));
printf("client socket's port %d\n", ntohs(addr2.sin_port));
printf("Client socket's peer ip : %s\n", inet_ntoa(addr1.sin_addr));
printf("Client socket's peer port : %d\n", ntohs(addr1.sin_port));

printf("%d %d\n", clnt_sock_err, clnt_peer_err);



printf("Message from server: %s \n", message);
close(sock);
return 0;
}

void error_handling(char *message)
{
fputs(message, stderr);
fputc('\n', stderr);
exit(1);
}

我运行它,ip是loopback(127.0.0.1),端口是7755。

结果是:

服务器

服务器套接字的IP:0.0.0.0

服务器套接字的端口:7755

服务器套接字的对等IP:1.0.0.0

服务器套接字的对等端口:4992

客户端套接字的IP:127.0.0.1

客户端套接字的端口:7755

客户端套接字的对等IP:127.0.0.1

客户端套接字的对等端口 6311

-1 0 0 0

客户端

客户端套接字的IP:127.0.0.1

客户端套接字的端口 6311

客户端套接字的对等IP:127.0.0.1

客户端套接字的对等端口:7755

0 0

来自服务器的消息:Hello World!

我注意到 getpeername() 对服务器套接字的对等方失败,然后返回 -1。但它显示IP和端口:1.0.0.0和4992。我不知道这些是什么意思。我认为另一个结果是有道理的。我知道监听(服务器)套接字只处理连接,而不处理数据传输,服务器通过accept()创建另一个套接字用于数据传输。

我的问题是ㅡ如果监听(服务器)套接字只处理客户端的连接,那么它的对等端不应该存在?错误的IP和端口是什么?只是垃圾值(value)?

最佳答案

getpeername() from listening(server) socket

监听(服务器)套接字没有对等方。它是一个本地的、未连接的监听套接字,没有远程端点。没有同行,没有同行名称。

I noticed getpeername() failed with server socket's peer, then returned -1. but it showed IP and port : 1.0.0.0 and 4992.

如果它失败了,那么它所做的任何其他事情都是无关紧要的。

I don't know what these mean.

它们没有任何意义。它们只是缓冲区中残留的垃圾,没有被修改,因为出现了错误。

and I think another results make sense.

没有任何结果有意义。没有结果可以得到。只是一个错误。

I know listening(server) socket only deal with connection, not data transfer, server create another socket for data transfer by accept().

正确。

my question is ㅡ if listening(server) socket only deal with client's connection, then its peer should not be exist?

正确。

what's that wrong IP and Port? just garbage value?

是的。

关于c - 从监听(服务器)套接字获取对等名(),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46484240/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com