C++ socket 通信客户端和服务器端
来源:互联网 发布:天纵软件 编辑:程序博客网 时间:2024/05/16 11:49
#include <iostream> #include <stdio.h> #include <windows.h> //一定要包含该头文件#pragma comment(lib, "WS2_32.lib") //windwows下的socket编程函数库using namespace std; int main() { WSADATA wsaData; WORD sockVersion = MAKEWORD(2, 2); //windows网络编程库的版本号信息 SOCKET sock = 0; //TCP通信的socket数据结构 if (WSAStartup(sockVersion, &wsaData) != 0) //WSAStartup函数是在程序中初始化并加载Windows网络 { cout << "initlization failed!" << endl; exit(0); //如果WSAStartup返回值为1的话就表示ws2_32.dll文件有问题,程序退出 } sock = ::socket(AF_INET, SOCK_STREAM, IPPROTO_TCP); //在本机上创建一个socket if (sock == INVALID_SOCKET) //判断socket是否创建成功 { cout << "failed socket!" << endl; return 0; //如果创建失败就在程序中返回0结束程序 } sockaddr_in sin; //创建一个socket编程类型的网络地址数据结构以便connect函数对本机创建的socket数据 //结构进行初始化。 sin.sin_family = AF_INET; //设置网络协议族类型 sin.sin_port = htons(4567); //设置远程计算机的端口号 sin.sin_addr.S_un.S_addr = inet_addr("127.0.0.1");//设置远程计算机的IP地址 if (connect(sock, (sockaddr*)&sin, sizeof(sockaddr)) == -1) //初始化socket并连接远程计算机 { cout << "connect failed!" << endl; return 0; //连接失败就返回0到程序 } char buffer[256] = "\0"; //声明一个从网络接收数据的缓存区 int nRecv = 0; //声明一个从网络接收到的数据字节长度 nRecv = recv(sock, buffer, 256, 0); //recv是一个接收网络的TCP数据包函数,nRecv是从网络接收到数 //据的字节长度 if (nRecv > 0) { buffer[nRecv] = '\0'; //如果接收到网络数据包长度大于0的话就在接收到的数据包未尾添加一个字符串 //结束符 cout << "reveive data: " << buffer << endl; //按字符串格式输出接收到的数据 } closesocket(sock); //关闭这个TCP网络通信连接 WSACleanup(); //释放ws2_32.dll动态库 } //服务端: #include <iostream> #include <stdio.h> #include <windows.h> //一定要包含该头文件 using namespace std; #pragma comment(lib, "WS2_32.lib") //windwows下的socket编程函数库 int main() { WSADATA wsaData; WORD sockVersion = MAKEWORD(2, 2); //windows网络编程库的版本号信息 SOCKET sListen = 0; //TCP通信的socket数据结构 sockaddr_in sin = {0}; //创建一个socket编程类型的网络地址数据结构这个用于本地 sockaddr_in remoteAddr = {0}; //创建一个socket编程类型的网络地址数据结构这个用于储存远程主机的 //IP地址和端口号 char szText[] = "TCP Server Demo"; int nAddrLen = 0; nAddrLen = sizeof(sockaddr_in); //计算这个sockaddr_in数据结构的大小 sin.sin_port = htons(4567); //设置本地(这里指服务端)计算机要打开的端口 sin.sin_family = AF_INET; //设置网络通信的网络协议族类型 sin.sin_addr.S_un.S_addr = INADDR_ANY; //设置本地计算机的IP地址,一般INADDR_ANY在程序运行时 //会自动计算成本地的IP地址的 //init wsa if (WSAStartup(sockVersion, &wsaData) != 0) //WSAStartup函数是在程序中初始化并加载Windows网络 { cout << "initlization failed!" << endl; exit(0); //如果WSAStartup返回值为1的话就表示ws2_32.dll文件有问题,程序退出 } sListen = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP); //在本机上创建一个socket //使用bind函数绑定本机的ip和打开端口到本机创建的socket结构上,并初始化该socket //重点说明一个在服务器上是用bind函数来初始化socket,在客户机上是用connect函数来初始化socket的喔 if (bind(sListen, (LPSOCKADDR)&sin, sizeof(sin)) == SOCKET_ERROR) { cout << "bind failed!" << endl; return 0; //如果socket绑定失败返回程序0并退出程序 } if (listen(sListen, 2) == SOCKET_ERROR) //listen是用来打开本地计算机的端口,参数2表示客户端同 //时连接服务器的数量,这里是说可以同时有2个客户端连接 //到本机打开的端口 { cout << "listen failed!" << endl; return 0; //如果打开本地端口失败就返回0并退出程序 } SOCKET sClient = INADDR_ANY; //再服务器上再创建一个socket结构,用来储存与一个客户端进行通信连 //接的连接实例 while (true) { //accept函数是用来创建一个TCP通信连接实例的,他使用一个远程计算机的IP地址和本地计算机上创建的一个 //socket,这两个信息来创建一个本地计算机到远程计算机的一个TCP通信连接实例的socket,sClient就是当前 //程序中的这个连接实例的socket 了。注accept函数也可以直接理解为接受一个客户机的连接请求。 sClient = accept(sListen, (SOCKADDR*)&remoteAddr, &nAddrLen); if (sClient == INVALID_SOCKET) { cout << "accept failed!" << endl; continue; //如果本地计算机(服务器)接受一个客户端连接请求失败就退出监听状态 } //send函数是在TCP连接建立之后,就来发送数据的。其中sClient是存放有一个连接实例的socket结构来 //的。这个服务器上的send函数的socket参数和客户机上的socket参数是不同的喔,记住这里的socket参数是通过 //accept函数创建的喔。不是用connet函数和bind函数创建喔。一定要记住这个sClient是一个关键来的。然后 //szText就是我们想要发送的数据了。这里我们向连接到该服务器的客户端发送了一个“TCP Server Demo”的信息。 send(sClient, szText, strlen(szText), 0); closesocket(sClient); //关闭这个用accept函数建立socket对象,关闭与remoteAddr连接通信。 //remoteAddr这结构理包含了有远程计算机的IP和端口号信息,当客户机 //使用connect函数发送一个连接请求时,被accept函数接受并处理后,远 //程计算机的IP地址和端口信息就被填到了remoteAddr这个结构中去 } closesocket(sListen); //关闭本地计算机(服务器)上的由bind函数创建的socket对象,关闭本机 //打开的端口,关闭服务器 WSACleanup(); //释放ws2_32.dll动态库 }
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
- 33
- 34
- 35
- 36
- 37
- 38
- 39
- 40
- 41
- 42
- 43
- 44
- 45
- 46
- 47
- 48
- 49
- 50
- 51
- 52
- 53
- 54
- 55
- 56
- 57
- 58
- 59
- 60
- 61
- 62
- 63
- 64
- 65
- 66
- 67
- 68
- 69
- 70
- 71
- 72
- 73
- 74
- 75
- 76
- 77
- 78
- 79
- 80
- 81
- 82
- 83
- 84
- 85
- 86
- 87
- 88
- 89
- 90
- 91
- 92
- 93
- 94
- 95
- 96
- 97
- 98
- 99
- 100
- 101
- 102
- 103
- 104
- 105
- 106
- 107
- 108
- 109
- 110
- 111
- 112
- 113
- 114
- 115
- 116
- 117
- 118
- 119
- 120
- 121
- 122
- 123
- 124
- 125
- 126
- 127
- 128
- 129
- 130
- 131
- 132
- 133
- 134
- 135
- 136
- 137
- 138
- 139
- 140
- 141
- 142
- 143
- 144
- 145
- 146
- 147
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
- 33
- 34
- 35
- 36
- 37
- 38
- 39
- 40
- 41
- 42
- 43
- 44
- 45
- 46
- 47
- 48
- 49
- 50
- 51
- 52
- 53
- 54
- 55
- 56
- 57
- 58
- 59
- 60
- 61
- 62
- 63
- 64
- 65
- 66
- 67
- 68
- 69
- 70
- 71
- 72
- 73
- 74
- 75
- 76
- 77
- 78
- 79
- 80
- 81
- 82
- 83
- 84
- 85
- 86
- 87
- 88
- 89
- 90
- 91
- 92
- 93
- 94
- 95
- 96
- 97
- 98
- 99
- 100
- 101
- 102
- 103
- 104
- 105
- 106
- 107
- 108
- 109
- 110
- 111
- 112
- 113
- 114
- 115
- 116
- 117
- 118
- 119
- 120
- 121
- 122
- 123
- 124
- 125
- 126
- 127
- 128
- 129
- 130
- 131
- 132
- 133
- 134
- 135
- 136
- 137
- 138
- 139
- 140
- 141
- 142
- 143
- 144
- 145
- 146
- 147
0 0
- 底层通信,socket 服务器端 和客户端
- 实现服务器端和客户端的Socket通信
- C++ socket 通信客户端和服务器端
- C++ socket 通信客户端和服务器端
- Socket通信 客户端和服务器端的通信 客户端
- 客户端和服务器端通信
- 客户端和服务器端通信
- 用Socket实现客户端和服务器端通信(完整版)
- Socket实现客户端和服务器端的消息通信
- 使用socket 将 服务器端和客户端通信的例子
- java socket 客户端和服务器端互相通信(聊天)
- java socket 客户端和服务器端互相通信(聊天)
- java socket编程 初级 服务器端和客户端 通信
- ios socket编程的客户端和服务器端通信简单实例
- 客户端和服务器端的通信(Socket编程)
- Socket通信——C++服务器端和Java客户端
- java-基本的Socket编程-实现服务器端和客户端通信
- Android通过Socket方式实现客户端和服务器端通信
- 面向对象
- select()函数以及FD_ZERO、FD_SET、FD_CLR、FD_ISSET
- Hadoop中RPC使用
- 设计模式学习之代理模式
- tensorflow 基础定义
- C++ socket 通信客户端和服务器端
- C语言中的字符串处理函数重写
- DataSetObserver使用——自定义View之一
- PDU格式短信解析
- web项目过滤器与拦截器小细节
- 剑指offer:和为S的两个数字
- Android开发线程间的交互之异步任务(AsyncTask)
- 设计模式学习之策略模式
- [bzoj4860]树的难题