asio学习之三:asio实现简单的服务器和客户端
2014-03-26 10:03
573 查看
这一节,我们用asio来实现一个简单的的服务器和客户端,服务器是支持daytime协议(ps:DAYTIME协议(DAYTIME protocol)是一个在RFC 867内定义的网络协议。它用作测试电脑网络。主机可以用TCP或UDP埠
13连接支援DAYTIME协议的服务器。服务器会以ASCII字符传回当时日期及时间。
现时测试网络的方法已经转为用ping或traceroute)。
服务器端:
#include <ctime>
#include <iostream>
#include <string>
#include <boost/asio.hpp>
using boost::asio::ip::tcp;
/*以字符串的形式返回当前的时间和日期,这个字符串将要被发送给客户端*/
std::string make_daytime_string()
{
using namespace std; // For time_t, time and ctime;
time_t now = time(0);
return ctime(&now);
}
int main()
{
try
{
boost::asio::io_service io_service;
/*创建一个acceptor对象来监听tcp连接*/
tcp::acceptor acceptor(io_service, tcp::endpoint(tcp::v4(), 13));
for (;;)
{
tcp::socket socket(io_service);
acceptor.accept(socket);
std::string message = make_daytime_string();
boost::system::error_code ignored_error;
boost::asio::write(socket, boost::asio::buffer(message), ignored_error);
}
}
catch (std::exception& e)
{
std::cerr << e.what() << std::endl;
}
return 0;
}
客户端:
#include <iostream>
#include <boost/asio.hpp>
#include <boost/array.hpp>
using boost::asio::ip::tcp;
int main(int argc,char* argv[])
{
/*我是在同一台机器上做测试,所以我就指定服务器的ip地址了,如果你想用其他ip的话,可以将这一句注释掉,然后在运行客户端程序的时候指定服务器ip*/
argv[1] = "127.0.0.1";
try
{
if (argc != 2)
{
std::cerr<<"Usage:client<host>"<<std::endl;
return 1;
}
boost::asio::io_service io_service;
/*创建一个resolver来解析argv[1]所指定的ip地址*/
tcp::resolver resolver(io_service);
/*resolver需要一个query对象,这个对象将把argv[1],按照协议daytime的格式转化并放到一个列表里面*/
tcp::resolver::query query(argv[1],"daytime");
/*我们使用给一个resolver的iterator来从上面的列表中获取ip(ps:用iterator的默认构造函数定义的对象,可以用来作为iterator的终点使用,如下面的end)*/
tcp::resolver::iterator endpoint_iterator = resolver.resolve(query);
tcp::resolver::iterator end;
tcp::socket socket(io_service);
boost::system::error_code error = boost::asio::error::host_not_found;
while (error && endpoint_iterator!=end)
{
socket.close();
socket.connect(*endpoint_iterator++,error);
}
if (error)
{
throw boost::system::system_error(error);
}
for (;;)
{
/*用boost::array来存储从服务器返回的数据,boost::array能够自动的判别数组的大小,帮助我们防止数组越界*/
boost::array<char,128> buf;
boost::system::error_code error;
size_t len = socket.read_some(boost::asio::buffer(buf),error);
if (error == boost::asio::error::eof)
{
break;
}
else if (error)
{
throw boost::system::system_error(error);
}
std::cout.write(buf.data(),len);
}
}
catch (std::exception& e)
{
std::cerr<<e.what()<<std::endl;
}
}
13连接支援DAYTIME协议的服务器。服务器会以ASCII字符传回当时日期及时间。
现时测试网络的方法已经转为用ping或traceroute)。
服务器端:
#include <ctime>
#include <iostream>
#include <string>
#include <boost/asio.hpp>
using boost::asio::ip::tcp;
/*以字符串的形式返回当前的时间和日期,这个字符串将要被发送给客户端*/
std::string make_daytime_string()
{
using namespace std; // For time_t, time and ctime;
time_t now = time(0);
return ctime(&now);
}
int main()
{
try
{
boost::asio::io_service io_service;
/*创建一个acceptor对象来监听tcp连接*/
tcp::acceptor acceptor(io_service, tcp::endpoint(tcp::v4(), 13));
for (;;)
{
tcp::socket socket(io_service);
acceptor.accept(socket);
std::string message = make_daytime_string();
boost::system::error_code ignored_error;
boost::asio::write(socket, boost::asio::buffer(message), ignored_error);
}
}
catch (std::exception& e)
{
std::cerr << e.what() << std::endl;
}
return 0;
}
客户端:
#include <iostream>
#include <boost/asio.hpp>
#include <boost/array.hpp>
using boost::asio::ip::tcp;
int main(int argc,char* argv[])
{
/*我是在同一台机器上做测试,所以我就指定服务器的ip地址了,如果你想用其他ip的话,可以将这一句注释掉,然后在运行客户端程序的时候指定服务器ip*/
argv[1] = "127.0.0.1";
try
{
if (argc != 2)
{
std::cerr<<"Usage:client<host>"<<std::endl;
return 1;
}
boost::asio::io_service io_service;
/*创建一个resolver来解析argv[1]所指定的ip地址*/
tcp::resolver resolver(io_service);
/*resolver需要一个query对象,这个对象将把argv[1],按照协议daytime的格式转化并放到一个列表里面*/
tcp::resolver::query query(argv[1],"daytime");
/*我们使用给一个resolver的iterator来从上面的列表中获取ip(ps:用iterator的默认构造函数定义的对象,可以用来作为iterator的终点使用,如下面的end)*/
tcp::resolver::iterator endpoint_iterator = resolver.resolve(query);
tcp::resolver::iterator end;
tcp::socket socket(io_service);
boost::system::error_code error = boost::asio::error::host_not_found;
while (error && endpoint_iterator!=end)
{
socket.close();
socket.connect(*endpoint_iterator++,error);
}
if (error)
{
throw boost::system::system_error(error);
}
for (;;)
{
/*用boost::array来存储从服务器返回的数据,boost::array能够自动的判别数组的大小,帮助我们防止数组越界*/
boost::array<char,128> buf;
boost::system::error_code error;
size_t len = socket.read_some(boost::asio::buffer(buf),error);
if (error == boost::asio::error::eof)
{
break;
}
else if (error)
{
throw boost::system::system_error(error);
}
std::cout.write(buf.data(),len);
}
}
catch (std::exception& e)
{
std::cerr<<e.what()<<std::endl;
}
}
相关文章推荐
- ASIO学习三:asioftp (FTP客户端的简单实现)
- python3 学习-1(实现简单的服务器与客户端)
- python学习(1)--实现简单的服务器与客户端
- Android与Java NIO实现简单Echo服务器与客户端
- python3实现TCP协议的简单服务器和客户端案例(分享)
- TCP SOCKET服务器|客户端简单实现
- 简单socket服务(二)实现多客户端向服务器发送数据
- boost:asio网络库初学之echo服务器客户端实现
- Linux 网络编程基础(一) ---------------客户端/服务器的简单实现
- TCP服务器、客户端的简单实现
- erlang tcp服务器和客户端的简单实现
- ROS的学习(十六)用C++写一个简单的服务器(service)和客户端(client)
- 网络编程_简单客户端和服务器实现
- 简单的在TCP协议下实现服务器与客户端之间的通信(Socket函数很重要)
- Mina学习(1):mina实现简单服务端与客户端
- 公钥和私钥的含义,以及java客户端和服务器之间进行安全加解密的简单实现
- UDP服务器、客户端的简单实现
- -[Up,every,day] 之 №2_.NET Socket 简单的应用,实现服务器与客户端 实时更新对话.!
- memcached学习——常用命令+基于java客户端的3种简单实现(二)
- QT中简单的实现客户端和服务器的沟通