TCP网络连接的书写
文章目录
- TCP网络连接的书写
- 服务器端书写
- 进程sock创建
- 创建bind进行端口绑定(进行bind的初始化)
- 监听socket
- 获取链接
- 用户端
- 创建sock套接字
- connect进行连接
服务器端书写
为TCP是面向连接,所有需要进行对于端口进行监控,另外的UDP的服务器就不需要进行端口的监控(面向字节流的)
进程sock创建
int listensock_ = socket(PF_INEF,SOCK_STREAM,0);
创建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使用。
监听socket
因为TCP是面向连接,所以相应进行端口监听
listen(listen(listenSock_,5));
5的规定了内核应该为相应套接字排队的最大连接个数。用SOMAXCONN则为系统给出的最大值,这里是阻塞示进行等待获取到连接端口的信息就会返回。获取链接
获取链接
使用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号)。
用户端
使用者的不同会造成不同的书写方法。
创建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进行数据的操作。