TCP网络连接的书写

TCP网络连接的书写

文章目录

  • TCP网络连接的书写
    • 服务器端书写
      • 进程sock创建
      • 创建bind进行端口绑定(进行bind的初始化)
      • 监听socket
      • 获取链接
    • 用户端
      • 创建sock套接字
      • connect进行连接

服务器端书写

为TCP是面向连接,所有需要进行对于端口进行监控,另外的UDP的服务器就不需要进行端口的监控(面向字节流的)

进程sock创建

int listensock_ = socket(PF_INEF,SOCK_STREAM,0);

image-20230404193149069

创建bind进行端口绑定(进行bind的初始化)

struct sockaddr_in local;
memset(&local,0,sizeof(local));
local.sin_family = PF_INEF;
local.sin_port = htons(port_);
ip_.empty() ? (local.sin_addr.s_addr = INADDR_ANY) : (inet_aton(ip.c_str,&local.sin_addr));//这里的IANDDR_ANY云服务器独有的
bind(ListenSock_,(const struct sockaddr*)&local,sizeof(local));

这里要特别注意sockaddr与自己创建的sockaddr_t的区别,sockaddr_t为程序员使用的结构体,sockaddr为系统的使用的结构体。sockaddr_t区分了端口号与ip等网络的设置
因为许多的云服务器不一定都是一台主机对于一个ip地址,所有没有办法分辨相应的具体的ip使用。

image-20230404193224059

监听socket

因为TCP是面向连接,所以相应进行端口监听

listen(listen(listenSock_,5));

5的规定了内核应该为相应套接字排队的最大连接个数。用SOMAXCONN则为系统给出的最大值,这里是阻塞示进行等待获取到连接端口的信息就会返回。获取链接

image-20230404193324866

获取链接

使用accept进行获取一个新的sock fd(新的网络套件字),这个套件字使用进行文件的传输。(这个fd是全双工的)

struct sockaddr_in peer;
socklen_t len = sizeof(peer)''
int serviceSock = accept(listenSock_,(struct sockaddr*)&peer,&len);

uint16_t peerPort = ntohs(peer.sin_port);
std::string peeerIp = inet_ntoa(peer.sin_addr);

这里面的peer是输出型参数,储存用户端ip以及端口号,用户端的端口可以不固定,但是服务器的IP和端口一定要固定,防止客户端访问不到服务器的内容。

这里获取的是网络序列的数据,需要转换成为主机序列。(ntohs与inet_ntoa的用法基本相同,只不过转换的东西不同,一个是端口号,一个是IP号)。

TCP网络连接的书写_第1张图片

用户端

使用者的不同会造成不同的书写方法。

创建sock套接字

int scok = socket(AF_INEF,SOCK_STREAM,0);

connect进行连接

连接服务器需要进行connect,而且系统会自动进行bind(会自动进行分配端口),因为客服端不需要固定的端口进行操作,所以端口不固定。

struct sockaddr_in server;
server.sin_family = AF_INET;
server.sin_port = htons(serverPort);

memset(&server,0,sizeof(server));//清空server所以的东西

获取链接之后,就可以使用sock fd进行数据的操作。

TCP网络连接的书写_第2张图片

你可能感兴趣的:(tcp/ip,网络,服务器)