#include <iostream>

#include <fstream>

#include <sstream>

#include <boost/asio.hpp>

using namespace std;

using boost::asio::ip::tcp;

const char* serviceList =  "\n\t       Services\n"

"\t**************************\n"

"\t[1] Get current time.\n"

"\t[2] Who's online.\n"

"\t[3] Get system info.\n"

"\t**************************\n\n"

"Please pick a service[1-3]: ";

ifstream fin;

void getResult(const string& cmdPrefix, const char* outputFile,

string& res) {

// cmd == "w > who"

string cmd(cmdPrefix + outputFile);

system(cmd.c_str());//将字符串解析为系统命令,然后执行

fin.open(outputFile);//存在打开文件,否则创建

if (fin) {  ostringstream os; os << fin.rdbuf(); res = os.str();

}

if (fin.is_open()) { fin.close();     }

}

string getServiceContent(const int& select) {

string res;

switch (select) { //time(0)获取当前时间,ctime将时间转换成字

符串。      case 1: {    time_t t = time(0); res = ctime(&t);  break;

}      case 2: getResult("w > ", "who", res);    break;   case 3: getResult("uname -a > ", "uname", res); break;

default:  res = "Sorry, no such service.\n";  break;     }

return res; }

int main() {     try {   boost::asio::io_service io_service; // #1

tcp::acceptor acceptor(io_service, tcp::endpoint(tcp::v4     //tcp::endpoint(端点)由ip地址,端口号,协议版本组成。

(), 8868)); // #2    for (;;) {   tcp::socket socket(io_service); // #3   /不断创建socket对象,并且与acceptor进行关联

acceptor.accept(socket); // #4

// 1, send service list to client

boost::system::error_code ignored_error;

boost::asio::write(socket, boost::asio::buffer(serviceList),     //buffer相当于显示器的一个缓冲,临时存储数据的一个容器

boost::asio::transfer_all(), ignored_error);  //自我感觉read和write是一个固定套路

// 2, receive selection from client              char selection[20];

size_t n = socket.read_some(boost::asio::buffer(selection),

ignored_error);             // 3, send response

string response = getServiceContent(atoi(selection));

boost::asio::write(socket, boost::asio::buffer(response),

boost::asio::transfer_all(), ignored_error);

} // #6     } catch (std::exception& e) {

std::cerr << e.what() << std::endl;     }

return 0; }

************************************************************************

/*  * tcp_sync_client.cpp  *  *  Created on: 2010-3-16 上午11:47:12  *      Author: kwarph  *         Web: http://www.xuanyuan-soft.cn  *        Mail: kwarph@gmail.com  */

#include <iostream>

#include <boost/asio.hpp>

using namespace std;

using boost::asio::ip::tcp;

int main(int argc, char* argv[]) {

try {         // 1, 创建io_service对象

boost::asio::io_service io_service;

// 2, 创建resolver对象关联到io_service对象

tcp::resolver resolver(io_service);

// 3, 创建一个查询对象

tcp::resolver::query query("localhost", "8868");

// 4, 用resolver对象和查询对象获取可用服务器地址

tcp::resolver::iterator endpoint_iterator = resolver.resolve(query); //把用resolve解析query的即localhost首地址给endpoint_iterator      tcp::resolver::iterator end;

//iterator就是endpoint的指针

// 5, 创建tcp::socket对象,关联到io_service

tcp::socket socket(io_service);

// 6, socket对象发起到服务器端的同步连接操作

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);

// 7, 一系列 同步read()和write()

char buf[512];

//1. receive service list from server

//        size_t len = socket.read_some(boost::asio::buffer(buf), error);         //

   size_t len = socket.receive(boost::asio::buffer(buf), 0, error);

//2.confirm size of info with server//进行read操作时,先socket.read_some r然后才是asio::read. write则相反,需先asio::write,再socket.write_some,b并且还要socket.send

size_t len = boost::asio::read(socket, boost::asio::buffer(buf), boost::asio::transfer_at_least(1), error);//asio读写时的参数更多

buf[len] = '\0';         cout << buf;

string selection;         cin >> selection;

//3. send selection to server //

boost::asio::write(socket, boost::asio::buffer(selection), //

boost::asio::transfer_all(), error);

//        socket.write_some(boost::asio::buffer(selection,selection.size()), error);

socket.send(boost::asio::buffer(selection,selection.size()),0, error);

//4. receive response from server

len = socket.read_some(boost::asio::buffer(buf), error);

buf[len] = '\0';          cout << buf;     }  catch (std::exception& e) {

std::cerr << e.what() << std::endl;     }

return 0; }

tcp_sync_server and tcp_sync_client的更多相关文章

随机推荐

  1. xshell连接虚拟机Ubuntu问题

    近期为了学习数据库的操作,准备在虚拟机中搭建环境以便操作(为什么在虚拟机搭建学习环境?),系统刚装好第一步就被阻止了. 总是会提示Could not connect to.原因是虚拟机没有安装ssh服 ...

  2. 浏览器与CDN缓存行为

    @地址栏回车 1. 未过期: 浏览器拦截,直接返回: (expires/cache-control两个参数决定,如果两个参数都有,cache-control覆盖expires); 2. 已过期: et ...

  3. Oracle_insert_delete_update

    Oracle_insert_delete_update --复制表格的结构 create table temp as (select * from emp where 1=2); select * f ...

  4. cnzz友盟怎么安装网站统计代码监控网站流量

    做网站的都知道cnzz统计,它是用来统计网站流量的,可以分析网站数据,进行更好的对网站优化,下面我教大家怎么添加统计代码 工具/原料 cnzz 方法/步骤 打开百度搜索"cnzz友盟&quo ...

  5. 通读cheerio API ——NodeJs中的jquery

    通读cheerio API ——NodeJs中的jquery 所谓工欲善其事,必先利其器,所以通读了cheerio的API,顺便翻译了一遍,有些地方因为知道的比较少,不知道什么意思,保留了英文,希望各 ...

  6. string用法总结

    要想使用标准C++中的string类,必须要包含#include <string> 注意是<string>而不是<string.h>,带.h的是C语言中的头文件 s ...

  7. Linux几个小杂碎点(更新中)

    1 BIOS时间和系统时间问题 安装完CentOS后,系统时间是CST时间,而BIOS时间是UTC时间,因此系统时间会比BIOS时间快8个小时.如果您设置BIOS自动开机的话,就会总是差个8小时.需要 ...

  8. android 通过getDimension,getDimensionPixelOffset和getDimensionPixelSize获取dimens.xml文件里面的变量值

    dimens.xml里写上三个变量: <dimen name="activity_vertical_margin1">16dp</dimen> <di ...

  9. linux命令读取文件中特定行

    1.如果你只想看文件的前5行,可以使用head命令, 如: head -5 /etc/passwd 2.如果你想查看文件的后10行,可以使用tail命令, 如: tail -10 /etc/passw ...

  10. nginx把POST转GET请求解决405问题

    405重定向,然后把POST转GET upstream local { server 10.0.1.11:81; } server { listen 81; server_name testf.xxx ...