C++网络通信实例(TCP/IP协议,包括服务端与客户端通信)

简介: C++网络通信实例(TCP/IP协议,包括服务端与客户端通信)

TCP/IP是当下网络协议栈中的主流协议 TCP属于传输层的协议  可靠传输 包括经典的三次握手等等


IP协议是网络层协议 尽全力传输但不可靠 学过计算机网络的同学们对这个应该比较熟悉


以下是使用C++进行网络通信的实例


服务端


主要使用多线程技术建立连接 也就是一个服务端可以连接多个客户端 最大连接数可以限定


向客户端发送字符串this is server 并启动一个线程等待客户端发送信息过来


如果客户端发送A过来 服务器返回B 发送C过来 服务器返回D 发送exit之后服务器关闭线程


效果图如下

image.png

image.png


代码如下

#include<iostream>
#include<stdlib.h>
#include<WinSock2.h>
#define _WINSOCK_DEPRECATED_NO_WARNINGS
using namespace std;
#pragma comment(lib, "ws2_32.lib")
DWORD WINAPI threadpro(LPVOID pParam) {
  SOCKET hsock = (SOCKET)pParam;
  char buffer[1024];
  char sendBuffer[1024];
  if (hsock != INVALID_SOCKET)
  cout << "start receive" << endl;
  while (1)
  {
  int num = recv(hsock, buffer, 1024, 0);
  if (num >= 0)
    cout << "receive from clinet" << buffer << endl;
  if (!strcmp(buffer, "A"))
  {
    memset(sendBuffer, 0, 1024);
    strcpy_s(sendBuffer, "B");
    int ires = send(hsock, sendBuffer, sizeof(sendBuffer), 0);//回送信息
    cout << "send to client" << sendBuffer << endl;
  }
  else if (!strcmp(buffer, "C"))
  {
    memset(sendBuffer, 0, 1024);
    strcpy_s(sendBuffer, "D");
    int ires = send(hsock, sendBuffer, sizeof(sendBuffer), 0);//回送信息
    cout << "send to client" << sendBuffer << endl;
  }
  else if (!strcmp(buffer, "exit"))
  {
    cout << "client close" << endl;
    cout << "server process close" << endl;
    return 0;
  }
  else
  {
    memset(sendBuffer, 0, 1024);
    strcpy_s(sendBuffer, "ERR");
    int ires = send(hsock, sendBuffer, sizeof(sendBuffer), 0);//回送信息
    cout << "send to client" << sendBuffer << endl;
  }
  }
  return 0;
}
void main() {
  WSADATA wsd;
  WSAStartup(MAKEWORD(2, 2), &wsd);
  SOCKET m_SockServer;
  sockaddr_in serveraddr;
  sockaddr_in serveraddrfrom;
  SOCKET m_Server[20];
  serveraddr.sin_family = AF_INET;
  serveraddr.sin_port = htons(4600);//端口号
  //serveraddr.sin_addr.S_un.S_addr = inet_addr("127.0.0.1");
  m_SockServer = socket(AF_INET, SOCK_STREAM, 0);
  int i = bind(m_SockServer, (sockaddr*)&serveraddr, sizeof(serveraddr));//绑定数
  cout << "bind:" << i << endl;
  int imaxconnect = 20;
  int iconnect = 0;
  int ilisret;
  char buf[] = "this is server\0";
  char WarnBuf[] = "it is over max connect\0";
  int len = sizeof(sockaddr);
  while (1) {
  ilisret = listen(m_SockServer, 0);
  m_Server[iconnect] = accept(m_SockServer, (sockaddr*)&serveraddrfrom, &len);
  if (m_Server[iconnect] != INVALID_SOCKET)
  {
    int ires = send(m_Server[iconnect], buf, sizeof(buf), 0);
    cout << "accept:" << ires << endl;
    iconnect++;
    if (iconnect > imaxconnect)
    {
    int ires = send(m_Server[iconnect], WarnBuf, sizeof(WarnBuf), 0);
    }
    else
    {
    HANDLE m_handle;
    DWORD nThreadld = 0;
    m_handle = (HANDLE)::CreateThread(NULL, 0, threadpro, (LPVOID)m_Server[--iconnect], 0, &nThreadld);//启动 线程
    }
  }
  WSACleanup();
  }
}

客户端

#include<iostream>
#include<stdlib.h>
#include"winsock2.h"
#include<time.h>
#define _WINSOCK_DEPRECATED_NO_WARNINGS
using namespace std;
#pragma comment(lib,"ws2_32.lib")
void main() {
  WSADATA wsd;
  WSAStartup(MAKEWORD(2, 2), &wsd);
  SOCKET m_SockClient;
  sockaddr_in clientaddr;
  clientaddr.sin_family = AF_INET;
  clientaddr.sin_port = htons(4600);
  //clientaddr.sin_addr.S_un.S_addr =inet_addr("127.0.0.1");
  m_SockClient = socket(AF_INET, SOCK_STREAM, 0);
  int i = connect(m_SockClient, (sockaddr*)&clientaddr, sizeof(clientaddr));
  cout << "connect" << i << endl;
  char buffer[1024];
  char inBuf[1024];
  int num;
  num = recv(m_SockClient, buffer, 1024, 0);
  if (num > 0) {
  cout << "receive from server" << buffer << endl;
  while (1) {
    num = 0;
    cin >> inBuf;
    if (!strcmp(inBuf, "exit")) {
    send(m_SockClient, inBuf, sizeof(inBuf), 0);
    return;
    }
    send(m_SockClient, inBuf, sizeof(inBuf), 0);
    num = recv(m_SockClient, buffer, 1024, 0);
    if (num >= 0)
    cout << "reveive from server" << buffer << endl;
  }
  }
}
相关文章
|
NoSQL 网络协议 Linux
Redis的实现一:c、c++的网络通信编程技术,先实现server和client的通信
本文介绍了使用C/C++进行网络通信编程的基础知识,包括创建socket、设置套接字选项、绑定地址、监听连接以及循环接受和处理客户端请求的基本步骤。
221 6
|
9月前
|
域名解析 网络协议 安全
计算机网络TCP/IP四层模型
本文介绍了TCP/IP模型的四层结构及其与OSI模型的对比。网络接口层负责物理网络接口,处理MAC地址和帧传输;网络层管理IP地址和路由选择,确保数据包准确送达;传输层提供端到端通信,支持可靠(TCP)或不可靠(UDP)传输;应用层直接面向用户,提供如HTTP、FTP等服务。此外,还详细描述了数据封装与解封装过程,以及两模型在层次划分上的差异。
2012 13
|
12月前
|
数据可视化 关系型数据库 MySQL
嵌入式C++、STM32、MySQL、GPS、InfluxDB和MQTT协议数据可视化
通过本文的介绍,我们详细讲解了如何结合嵌入式C++、STM32、MySQL、GPS、InfluxDB和MQTT协议,实现数据的采集、传输、存储和可视化。这种架构在物联网项目中非常常见,可以有效地处理和展示实时数据。希望本文能帮助您更好地理解和应用这些技术,构建高效、可靠的数据处理和可视化系统。
710 82
|
网络协议 安全 网络安全
网络编程:基于socket的TCP/IP通信。
网络编程:基于socket的TCP/IP通信。
|
12月前
|
消息中间件 Linux C++
c++ linux通过实现独立进程之间的通信和传递字符串 demo
的进程间通信机制,适用于父子进程之间的数据传输。希望本文能帮助您更好地理解和应用Linux管道,提升开发效率。 在实际开发中,除了管道,还可以根据具体需求选择消息队列、共享内存、套接字等其他进程间通信方
322 16
|
网络协议
网络通信的基石:TCP/IP协议栈的层次结构解析
在现代网络通信中,TCP/IP协议栈是构建互联网的基础。它定义了数据如何在网络中传输,以及如何确保数据的完整性和可靠性。本文将深入探讨TCP/IP协议栈的层次结构,揭示每一层的功能和重要性。
998 5
|
网络协议 安全 Go
Go语言进行网络编程可以通过**使用TCP/IP协议栈、并发模型、HTTP协议等**方式
【10月更文挑战第28天】Go语言进行网络编程可以通过**使用TCP/IP协议栈、并发模型、HTTP协议等**方式
289 13
|
网络协议 网络安全 网络虚拟化
本文介绍了十个重要的网络技术术语,包括IP地址、子网掩码、域名系统(DNS)、防火墙、虚拟专用网络(VPN)、路由器、交换机、超文本传输协议(HTTP)、传输控制协议/网际协议(TCP/IP)和云计算
本文介绍了十个重要的网络技术术语,包括IP地址、子网掩码、域名系统(DNS)、防火墙、虚拟专用网络(VPN)、路由器、交换机、超文本传输协议(HTTP)、传输控制协议/网际协议(TCP/IP)和云计算。通过这些术语的详细解释,帮助读者更好地理解和应用网络技术,应对数字化时代的挑战和机遇。
1289 3
|
存储 网络协议 安全
30 道初级网络工程师面试题,涵盖 OSI 模型、TCP/IP 协议栈、IP 地址、子网掩码、VLAN、STP、DHCP、DNS、防火墙、NAT、VPN 等基础知识和技术,帮助小白们充分准备面试,顺利踏入职场
本文精选了 30 道初级网络工程师面试题,涵盖 OSI 模型、TCP/IP 协议栈、IP 地址、子网掩码、VLAN、STP、DHCP、DNS、防火墙、NAT、VPN 等基础知识和技术,帮助小白们充分准备面试,顺利踏入职场。
1915 2
|
网络协议 算法 网络性能优化
计算机网络常见面试题(一):TCP/IP五层模型、TCP三次握手、四次挥手,TCP传输可靠性保障、ARQ协议
计算机网络常见面试题(一):TCP/IP五层模型、应用层常见的协议、TCP与UDP的区别,TCP三次握手、四次挥手,TCP传输可靠性保障、ARQ协议、ARP协议