1、下载websocketpp,地址为https://github.com/zaphoyd/websocketpp,版本为0.7。

2、下载boost,地址为https://www.boost.org/,版本为1.6.3。

3、说明:websocketpp并不是必须需要boost,如果C++编译为C11以上,是可以不用的。

4、Qt创建一个console工程(如:websocketClient),将下载下来的websocket_master里面的websocket文件夹放到该工程目录下,在webSocketClient.pro文件中添加include(websocket/websocket.pri),

5、创建websocket_client类,头文件websocket_client.h内容如下:

  #include <websocketpp/config/asio_no_tls_client.hpp>

  #include <websocketpp/client.hpp>

  #include <websocketpp/common/thread.hpp>

  #include <websocketpp/common/memory.hpp>

  #include <iostream>

  #include <sstream>

  #include <cstdlib>

  #include <string>

  #include <map>

  using namespace websocketpp::lib::placeholders;

  typedef websocketpp::client<websocketpp::config::asio_client> client;

  class connection_metadata
  {
  public:
    typedef websocketpp::lib::shared_ptr<connection_metadata> ptr;

    connection_metadata(websocketpp::connection_hdl hdl, std::string uri)

          : m_hdl(hdl)

          , m_status("Connecting")

          , m_uri(uri)

          , m_server("N/A")

    {}  

    void on_open(client *echo_client, websocketpp::connection_hdl hdl)

    {

      m_status = "Open";

           client::connection_ptr con = echo_client->get_con_from_hdl(hdl);

           m_server = con->get_response_header("Server");

    }

    void on_fail(client *echo_client, websocketpp::connection_hdl hdl

    {

      m_status = "Failed";

           client::connection_ptr con = echo_client->get_con_from_hdl(hdl);

           m_server = con->get_response_header("Server");

           m_error_reason = con->get_ec().message();

    }  

    void on_close(client *echo_client, websocketpp::connection_hdl hdl)

    {

           m_status = "Closed";

           client::connection_ptr con = echo_client->get_con_from_hdl(hdl);

           std::stringstream s;

         s << "close code: " << con->get_remote_close_code() << " ("

              << websocketpp::close::status::get_string(con->get_remote_close_code())

              << "), close reason: " << con->get_remote_close_reason();

           m_error_reason = s.str();

    }

    void on_message(websocketpp::connection_hdl hdl, client::message_ptr msg)

    {

          if(msg->get_opcode() == websocketpp::frame::opcode::text)

          {

                std::cout << "on message called with hdl: " << hdl.lock().get() << "and message: " << msg->get_payload() << std::endl;

                m_messages.push_back("<< " + msg->get_payload());

          }

         else

         {

              m_messages.push_back("<< " + websocketpp::utility::to_hex(msg->get_payload()));

         }

    }   

    websocketpp::connection_hdl get_hdl() const

         {

          return m_hdl;

         }

    std::string get_status() const

    {

      return m_status;

    }

    std::string get_uri() const

    {

      return m_uri;

    }

    void record_sent_message(std::string message)

    {

      m_messages.push_back(">> " + message);

    }

    friend std::ostream & operator<< (std::ostream & out, connection_metadata const & data);

  private:

    websocketpp::connection_hdl m_hdl;

    std::string m_status;

    std::string m_uri;

    std::string m_server;

    std::string m_error_reason;

    std::vector<std::string> m_messages;

  };

  std::ostream & operator<< (std::ostream & out, connection_metadata const & data);

//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////

  class websocket_client

  {
  public:
    websocket_client();
    ~websocket_client();

    int connect(std::string const & uri);
    void close();

    void send(std::string message);
    void show();

  private:

      client echo_client;

      connection_metadata::ptr Con;

      websocketpp::lib::shared_ptr<websocketpp::lib::thread> m_thread;

  };

  websocket_client.cpp文件内容如下:

  std::ostream & operator<< (std::ostream & out, connection_metadata const & data)

  {

    out << "> URI: " << data.m_uri << "\n"

      << "> Status: " << data.m_status << "\n"

      << "> Remote Server: " << (data.m_server.empty() ? "None Specified" : data.m_server) << "\n"

      << "> Error/close reason: " << (data.m_error_reason.empty() ? "N/A" : data.m_error_reason) << "\n";

    out << "> Messages Processed: (" << data.m_messages.size() << ") \n";

    for (std::vector<std::string>::const_iterator it = data.m_messages.begin(); it != data.m_messages.end(); ++it)

    {

      out << *it << "\n";

    }

    return out;

  }

  websocket_endpoint::websocket_endpoint()

  {

    echo_client.clear_access_channels(websocketpp::log::alevel::all);

    echo_client.clear_error_channels(websocketpp::log::elevel::all);

    echo_client.init_asio();

     echo_client.start_perpetual();

    m_thread = websocketpp::lib::make_shared<websocketpp::lib::thread>(&client::run, &echo_client);

  }

  websocket_endpoint::~websocket_endpoint()

  {

    echo_client.stop_perpetual();

    if(Con->get_status() == "Open")

    {

      websocketpp::lib::error_code ec;

      echo_client.close(Con->get_hdl(), websocketpp::close::status::going_away, "", ec);

      if(ec)

      {

        std::cout << "> Error closing ws connection " << Con->get_uri() << " :" << ec.message() << std::endl;

      }

    }

    m_thread->join();

  }

  int websocket_endpoint::connect(std::string const & uri)

  {

    websocketpp::lib::error_code ec;

    client::connection_ptr pConnection = echo_client.get_connection(uri,ec);

    if(ec)

    {

      std::cout << "> Connect initialization error: " << ec.message() << std::endl;

      return -1;

    }

    Con = websocketpp::lib::make_shared<connection_metadata>(pConnection->get_handle(),uri);

    pConnection->set_open_handler(websocketpp::lib::bind(&connection_metadata::on_open,Con,&echo_client,::_1));

    pConnection->set_fail_handler(websocketpp::lib::bind(&connection_metadata::on_fail,Con,&echo_client,::_1));

    pConnection->set_close_handler(websocketpp::lib::bind(&connection_metadata::on_close,Con,&echo_client,::_1));

    pConnection->set_message_handler(websocketpp::lib::bind(&connection_metadata::on_message,Con,::_1,::_2));

    echo_client.connect(pConnection);

    return 0;

  }

  void websocket_endpoint::close()

  {

    if(Con->get_status() == "Open")

    {

      websocketpp::lib::error_code ec;

      echo_client.close(Con->get_hdl(),websocketpp::close::status::normal,"",ec);

      if(ec)

      {

        std::cout << "> Error initiating close: " << ec.message() << std::endl;

      }

    }

  }

  void websocket_endpoint::send(std::string message)

  {

    websocketpp::lib::error_code ec;

    echo_client.send(Con->get_hdl(), message, websocketpp::frame::opcode::text, ec);

    if(ec)

    {

      std::cout << "> Error sending messages: " << ec.message() <<std::endl;

      return;

    }

    Con->record_sent_message(message);

  }

  void websocket_endpoint::show()

  {

    std::cout << *Con << std::endl;

  }

6、运行程序后,在终端输入命令

Enter Command: send 11111111(向服务器发送1111111111)

Enter Command:show(显示websocketpp客户端信息及已经发送和接收的数据)

Enter Command:quit(退出)

Qt编写websocketpp客户端的更多相关文章

  1. 使用Qt编写服务器端程序(包括Http传输服务器端)的方法

    使用Qt编写客户端的程序的示例或demo较多,但是编写服务器端程序的demo很少.当然,服务器端的程序一般不需要带界面,这点我们可以理解.不过有些时候我们还是需要使用Qt编写一个简单的测试用的服务器代 ...

  2. Qt编写的开源帖子集合(懒人专用)

    回顾自己学习Qt以来九年了,在这九年多时间里面,从本论坛学习不到不少的东西,今天特意整了一下自己开源过的资源的帖子,整理一起方便大家直接跳转下载,不统计不知道,一统计吓一跳,不知不觉开源了这么多代码, ...

  3. Qt编写项目作品大全(自定义控件+输入法+大屏电子看板+视频监控+楼宇对讲+气体安全等)

    一.自定义控件大全 (一).控件介绍 超过160个精美控件,涵盖了各种仪表盘.进度条.进度球.指南针.曲线图.标尺.温度计.导航条.导航栏,flatui.高亮按钮.滑动选择器.农历等.远超qwt集成的 ...

  4. Qt编写气体安全管理系统10-数据导出

    一.前言 数据导出一般指导出到excel表格,可能有部分用户还需要导出到pdf,因为pdf基本上不可编辑,防止用户重新编辑导出的数据,excel可能绝大部分用过电脑的人都知道,广为流行,主要就是微软的 ...

  5. Qt编写控件属性设计器9-数据库采集

    一.前言 数据库作为数据源,在很多组态软件中使用非常多,指定数据库类型,填写好数据库连接信息,指定对应的数据库表和字段,采集间隔,程序按照采集间隔自动采集数据库数据,绑定到界面上的控件赋值显示即可.使 ...

  6. Qt编写控件属性设计器8-网络采集

    一.前言 上一篇文章已经打通了数据源之一的串口采集,这次要说的是网络采集,网络通信目前用的最多的是三种,TCP/UDP/HTTP,其中tcp通信又包括了客户端服务端两种,tcp通信才用了多次握手机制不 ...

  7. Qt编写控件属性设计器7-串口采集

    一.前言 数据源是组态软件的核心灵魂,少了数据源,组态就是个花架子没卵用,一般数据源有三种方式获取,串口.网络.数据库,至于数据规则是什么,这个用户自己指定,本设计器全部采用第一个字节作为数据来演示. ...

  8. Qt编写Onvif搜索及云台控制工具

    一.前言 这个工具很早以前大概在2013年就想做了,后面杂七杂八的事情一再耽搁,记得当时最初用的是soap类来搜索和解析的,后面发现太大了,每次编译都要等好久,光源码文件加起来都快10MB了,而且函数 ...

  9. Qt编写自定义控件23-广告轮播控件

    一.前言 广告轮播这个控件做的比较早,是很早以前定制一个电信客户端时候用到的,该客户端需要在首页展示轮播预先设定好的图片,图片的路径可以自由设定,然后轮播的间隔速度可以自由控制,同时该控件还需要提供两 ...

随机推荐

  1. [转载]ASP.NET Error – Adding the specified count to the semaphore would cause it to exceed its maximum count

    http://jwcooney.com/2012/08/13/asp-net-error-adding-the-specified-count-to-the-semaphore-would-cause ...

  2. 第12月第2天 uiscrollview _adjustContentOffsetIfNecessary 圆角

    1. uiscrollview在调用setFrame,setBounds等方法的时候会默认调用稀有api: _adjustContentOffsetIfNecessary 这个方法会改变当前的cont ...

  3. 第5月第16天 php crud CodeIgniter CI_DB_active_record

    1.C.R.U.D. Generator for CodeIgniter https://github.com/antonioyee/crud-generator/tree/9e5e48e773a52 ...

  4. Windows中用“ls”命令

    解决办法是: 在C:\Windows\System32目录下新建文本文档,文件内容为: @echo off dir 另存为“ls.bat” 类型为所有文件,编码ANSI 可使用dir 或者ls都可以 ...

  5. C++ socket 网络编程 简单聊天室

    操作系统里的进程通讯方式有6种:(有名/匿名)管道.信号.消息队列.信号量.内存(最快).套接字(最常用),这里我们来介绍用socket来实现进程通讯. 1.简单实现一个单向发送与接收 这是套接字的工 ...

  6. Spring中构造器、init-method、@PostConstruct、afterPropertiesSet孰先孰后,自动注入发生时间以及单例多例的区别、SSH线程安全问题

    首先明白,spring的IOC功能需要是利用反射原理,反射获取类的无参构造方法创建对象,如果一个类没有无参的构造方法spring是不会创建对象的.在这里需要提醒一下,如果我们在class中没有显示的声 ...

  7. LeetCode(Easy)--C++笔记

    前言:这是关于LeetCode上面练习题C++的笔记,有些地方参考有网友的解题方法(可能有些参考没能注明,望谅解),如有需要改进的地方希望留言指教,多谢! 目录: ZigZag Conversion ...

  8. Opencv学习笔记——release和debug两个模式的运行问题

    本文为原创作品,转载请注明出处 欢迎关注我的博客:http://blog.csdn.net/hit2015spring和http://www.cnblogs.com/xujianqing/ 作者:晨凫 ...

  9. MVC layout 命名空间引用问题

    虽然用MVC做了很多项目,但是都是在别人搭好的框架上实现 今天碰到一个很简单的命名空间引用问题 如图所示,Scripts和Styles 都没有引用命名空间 解决方法一: 直接使用 System.Web ...

  10. shell脚本 ------ 输出带颜色的字体

    shell脚本中echo显示内容带颜色显示,echo显示带颜色,需要使用参数-e 格式如下: echo -e “\033[字背景颜色:文字颜色m字符串\033[0m” 例如: echo -e “\03 ...