VisualStudio2015下利用boost::asio实现客户端和服务器端的连接及文本信息发送

2023-05-16

1.主要实现本地文本信息传送

//服务端
#include <hl/version_check/boost_impl.h>
#include <hl/net_driver.h>
#include <boost/bind.hpp>
#include <boost/asio.hpp>
#include <boost/make_shared.hpp>
#include <boost/asio/ip/tcp.hpp>
#include <boost/asio/coroutine.hpp>
#include <boost/enable_shared_from_this.hpp>
#include <iostream>

class server
{
public:
	class tcp_connection : public boost::enable_shared_from_this<tcp_connection>
	{
	public:

		boost::asio::ip::tcp::socket& socket()              //获取套接字
		{
			return _socket;
		}

		void start()
		{
			//const char text[] = "HTTP/1.1 200 OK\r\nContent-length:2\r\n\r\nok";  //  HTTP/1.1:协议为Http,版本是1.1
			boost::asio::async_write(_socket, boost::asio::buffer("1", 1),
				boost::bind(&tcp_connection::handle_write, shared_from_this(), _1, _2));//两个占位符的实际传入的值是什么?
		}

		tcp_connection(boost::asio::io_service& ios) : _socket(ios)
		{
		}

	private:

		char buffer[1024];
		void handle_write(const boost::system::error_code& e, size_t s)
		{
			if (e)
			{
				std::cout << e.message() << std::endl;
			}
			else
			{
	
				memset(buffer, 0, 1024);
				boost::asio::async_read(_socket, boost::asio::buffer(buffer, 1), boost::bind(&tcp_connection::handle_read, shared_from_this(), _1, _2));//每次接收一个字符并存在buffer中,调用handle_read

			}
		}

		void handle_read(const boost::system::error_code& e, size_t s)
		{
			if (e)
			{
				std::cout << e.message() << std::endl;
			}
			else
			{
				std::cout <<"server recv:"<< buffer << "\n";   //把接收到的字符打印出来
			}

			ho::thread::sleep(1000); //休息1秒
			boost::asio::async_write(_socket, boost::asio::buffer("1", 1),
			boost::bind(&tcp_connection::handle_write, shared_from_this(), _1, _2));//每次发送一个'1',调用handle_write

		}


		boost::asio::ip::tcp::socket _socket;
	};


	class tcp_server : public boost::asio::coroutine, public boost::enable_shared_from_this<tcp_server>
	{
	private:
		boost::asio::io_service &_ios;
		boost::shared_ptr<boost::asio::ip::tcp::acceptor> _acceptor;
		boost::shared_ptr<tcp_connection> _conn;

	public:
		tcp_server(boost::asio::io_service& ios) : _ios(ios)
		{

		}

		void go()
		{
			_ios.post(boost::bind(&tcp_server::go_internal, shared_from_this()));
		}
#include <boost/asio/yield.hpp>
		void go_internal()
		{

			reenter(this)
			{
				_acceptor = boost::make_shared<boost::asio::ip::tcp::acceptor>(_ios, boost::asio::ip::tcp::endpoint(boost::asio::ip::tcp::v4(), 10086));//10086为端口号
				for (;;)
				{
					_conn = boost::make_shared<tcp_connection>(_ios);
					yield _acceptor->async_accept(_conn->socket(), boost::bind(&tcp_server::go_internal, shared_from_this()));
					_conn->start();
				}
			}
		}
#include <boost/asio/unyield.hpp>
	};

};
struct __TEST_ASIO;
typedef ho::net_service2<__TEST_ASIO> test_asio_service;


void main()
{
	boost::make_shared<server::tcp_server>(test_asio_service::get_io_service())->go(); //开启服务器
	for (;;)
	{
		ho::thread::sleep(1000);
	}
}

#include <hl/version_check/boost_impl.h>
#include <hl/net_driver.h>
#include <boost/bind.hpp>
#include <boost/asio.hpp>
#include <boost/make_shared.hpp>
#include <boost/asio/ip/tcp.hpp>
#include <boost/asio/coroutine.hpp>
#include <boost/enable_shared_from_this.hpp>
#include <iostream>

//客户端
class client
{
public:
	client(boost::asio::io_service& io_service,
		const std::string& server, const std::string& path)
		: resolver_(io_service),
		socket_(io_service)
	{
		boost::asio::ip::tcp::resolver::query query(server, "10086");//10086为端口号
		resolver_.async_resolve(query,
			boost::bind(&client::handle_resolve, this,
				boost::asio::placeholders::error,
				boost::asio::placeholders::iterator));
	}

private:
	char _buffer[1024];

	void handle_resolve(const boost::system::error_code& err,
		boost::asio::ip::tcp::resolver::iterator endpoint_iterator)
	{
		if (!err)
		{
			// Attempt a connection to each endpoint in the list until we
			// successfully establish a connection.
			boost::asio::async_connect(socket_, endpoint_iterator,
				boost::bind(&client::handle_connect, this,
					boost::asio::placeholders::error));
		}
		else
		{
			std::cout << "Error: " << err.message() << "\n";
		}
	}

	void handle_connect(const boost::system::error_code& err)
	{
		if (!err)
		{
			boost::asio::async_read(socket_, boost::asio::buffer(_buffer, 1),
				boost::bind(&client::handle_read, this, _1, _2));
		}
		else
		{
			std::cout << "Error: " << err.message() << "\n";
		}
	}

	void handle_read(const boost::system::error_code& err, size_t s)
	{
		if (!err)
		{
			std::cout  << " client recv:"  << _buffer << "\n";

			boost::asio::async_write(socket_, boost::asio::buffer("2", 1), boost::bind(&client::handle_write, this, _1, _2));

		}
		else
		{
			std::cout << "Error: " << err.message() << "\n";
		}
	}

	void handle_write(const boost::system::error_code& err, size_t s)
	{
		if (!err)
		{
			memset(_buffer, 0, 1024);
			boost::asio::async_read(socket_, boost::asio::buffer(_buffer, 1),
				boost::bind(&client::handle_read, this, _1, _2));

		}
		else
		{
			std::cout << "Error: " << err.message() << "\n";
		}
	}


	boost::asio::ip::tcp::resolver resolver_;
	boost::asio::ip::tcp::socket socket_;
	boost::asio::streambuf request_;
	boost::asio::streambuf response_;
};

void main()
{

	boost::asio::io_service io_service;                //开启客户端 
	client c(io_service, "127.0.0.1", "");
	io_service.run();

}

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

VisualStudio2015下利用boost::asio实现客户端和服务器端的连接及文本信息发送 的相关文章

  • ZYNQ 平台 AD9361实现网络通信的一种方案+网卡驱动分析及实现

    声明 xff1a 文中若有不合理的地方 xff0c 欢迎讨论学习及指正 xff0c 本文仅仅涉及软件部分的代码 xff0c 不阐述逻辑代码的实现 功能 xff1a 通过AD9361芯片实现无线组网 xff0c 能实现视频 文件 音频等传输
  • MTD分析

    概述 xff1a 本文对mtd的整个结构进行了分析 xff0c 分析得并非很深入 xff0c 但可以了解大体框架和目录结构 xff0c 另外本文会对源码文件进行分析 xff0c 大致描述其作用 xff0c 针对本文的内容中 xff0c 如有
  • CAN总线详解(转)

    1 简介 CAN是控制器局域网络 Controller Area Network CAN 的简称 xff0c 是一种能够实现分布式实时控制的串行通信网络 优点 xff1a 传输速度最高到1Mbps xff0c 通信距离最远到10km xff
  • Linux Socket CAN——驱动开发(转)

    Linux Socket CAN驱动开发 一 CAN总线协议 CAN是Controller Area Network 控制器局域网 的缩写 CAN通信协议在1986年由德国电气商博世公司所开发 xff0c 主要面向汽车的通信系统 现已是IS
  • Joint state with name: “base_l_wheel_joint” was received but not found in URDF

    ROS melodic下运行出现 WARN xff1a Joint state with name base l wheel joint was received but not found in URDF 原因是在robot描述文件URD
  • 已解决 vmware 虚拟机安装后没有虚拟网卡问题

    我用的方法是重装vmware xff0c 使用的是win10的系统 之前安装网ubuntu以后 xff0c 发现主机并没有虚拟网卡 xff0c 也百度了各种方法 xff0c 然而并没有什么用 xff0c 也问了很多人 xff0c 他们也提供
  • rk3399下pwm驱动

    现在记录一下rk3399下pwm的驱动编写 xff0c 下面是内核pwm的API xff0c 从开源论坛复制 xff08 firefly的开源论坛里面的Wiki教程 xff09 1 在要使用 PWM 控制的设备驱动文件中包含以下头文件 xf
  • rk3399下spi驱动

    SPI 使用 Note xff1a 本文从firefly wiki截取 SPI是一种高速的 xff0c 全双工 xff0c 同步串行通信接口 xff0c 用于连接微控制器 传感器 存储设备等 Firefly RK3399 开发板提供了 SP
  • rk3399 u-boot修改开机logo以及开机动画和开机视频

    首先分析了一下uboot启动流程中的一部分代码 xff0c 如下 第一部分 xff1a 开机logo xff08 下面代码分析排版有点乱 xff0c 可以忽略 xff09 1 board late init rk33xx c board r
  • VMware 虚拟网卡防火墙问题

    看了很多人遇到过一段时间会自己删除虚拟网卡的问题 xff0c 这里做一个补充 xff0c 关于防火墙问题 xff0c 如下 这里点进去 点击更改设置 xff08 先找到下图这一项 xff09 最后记得保存更改 xff0c 关于VMware的
  • postman汉化包下载

    postman汉化包 https github com hlmd Postman cn releases postman官网下载地址 Download Postman Get Started for Free
  • 一帧数据接收方法

    最近在做485数据通讯 xff0c 遇到一些通讯问题 xff0c 特意去查找资料 xff0c 一帧数据接收有三种方法 xff0c 现分享如下 xff1a 第一种方法 xff1a 根据帧头和帧尾进行校验 xff0c 串口发送2字节例如 xff
  • 如何使用RTKLIB进行RTK定位(一)

    今天从这个demo xff0c 教给大家如何使用RTKLIB进行RTK定位 xff0c 包括配置文件 数据等 xff1b RTKLIB源码和exe下载地址 xff1a RTKLIB An Open Source Program Packag
  • C++ “::” 作用域符 双冒号

    一 是作用域符 xff0c 是运算符中等级最高的 xff0c 它分为三种 1 global scope 全局作用域符 xff09 xff0c 用法 xff08 name 2 class scope 类作用域符 xff09 xff0c 用法
  • OpenMv测距(Apriltag)

    利用OpenMv测离Apriltag的距离 xff08 其他色块啥的算法都差不多 xff0c 主要是Apriltag精确一些 xff09 span class token comment 本次利用OpenMv单目测距Apriltag离摄像头
  • CMake Error at /usr/lib/x86_64-linux-gnu/cmake/Qt5Core/Qt5CoreConfig.cmake:27 (message)

    CMake Error at usr lib x86 64 linux gnu cmake Qt5Core Qt5CoreConfig cmake 27 message 在catkin make的时候 xff0c 如果提示 so文件报错 x
  • Deep-Sort多目标追踪算法代码解析

    Deep SORT是多目标跟踪 Multi Object Tracking 中常用到的一种算法 xff0c 是一个Detection Based Tracking的方法 这个算法工业界关注度非常高 xff0c 在知乎上有很多文章都是使用了D
  • 红黑树的查找时间复杂度O(logn)

    红黑树查找时间复杂度 如果二叉排序树是平衡的 xff0c 则n个节点的二叉排序树的高度为Log2n 43 1 其查找效率为O Log2n xff0c 近似于折半查找 如果二叉排序树完全不平衡 xff0c 则其深度可达到n xff0c 查找效
  • Ubuntu16.04环境下STM32和ROS间的串口通信

    目录 前言介绍 lt 1 gt 最终协议的样子 lt 2 gt 本方案提供的API实现的功能 原理 lt 1 gt 简要叙述 lt 2 gt 这里是如何使用共用体的 xff1f 前期准备 lt 1 gt 确保硬件连接 lt 2 gt 查看串
  • C++版本OpenCv教程(三十五 )Laplacian算子

    上述的边缘检测算子都具有方向性 xff0c 因此需要分别求取X方向的边缘和Y方向的边缘 xff0c 之后将两个方向的边缘综合得到图像的整体边缘 Laplacian算子具有各方向同性的特点 xff0c 能够对任意方向的边缘进行提取 xff0c

随机推荐