国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > C++ > 正文

websocket++簡單使用及實例分析

2020-05-23 14:03:35
字體:
來源:轉載
供稿:網友
下面小編就為大家帶來一篇websocket++簡單使用及實例分析。小編覺得挺不錯的,現在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
 

前言

html5支持使用websocket協議與服務器保持一個長連接,方便雙方互相傳輸數據,而且服務器也能主動發送信息給客戶端,而在這之前使用HTTP是很難做到的。下面介紹使用C++實現的websocket++的簡單使用。websocket++更詳細介紹點此。

websocket++需要boost的支持,所以工程中需要包含boost的頭文件和庫。boost在VS中的如何使用參考此文章。

C++代碼

#include "stdafx.h"#include <iostream>using namespace std;#include <websocketpp/config/asio_no_tls.hpp>#include <websocketpp/server.hpp>typedef websocketpp::server<websocketpp::config::asio> WebsocketServer;typedef WebsocketServer::message_ptr message_ptr;using websocketpp::lib::placeholders::_1;using websocketpp::lib::placeholders::_2;using websocketpp::lib::bind;void OnOpen(WebsocketServer *server, websocketpp::connection_hdl hdl){  cout << "have client connected" << endl;}void OnClose(WebsocketServer *server, websocketpp::connection_hdl hdl){  cout << "have client disconnected" << endl;}void OnMessage(WebsocketServer *server, websocketpp::connection_hdl hdl, message_ptr msg){  string strMsg = msg->get_payload();  cout << strMsg << endl;  string strRespon = "receive: ";  strRespon.append(strMsg);  server->send(hdl, strRespon, websocketpp::frame::opcode::text);}int main(){  WebsocketServer          server;  // Set logging settings  server.set_access_channels(websocketpp::log::alevel::all);  server.clear_access_channels(websocketpp::log::alevel::frame_payload);  // Initialize ASIO  server.init_asio();  // Register our open handler  server.set_open_handler(bind(&OnOpen, &server, ::_1));  // Register our close handler  server.set_close_handler(bind(&OnClose, &server, _1));  // Register our message handler  server.set_message_handler(bind(&OnMessage, &server, _1, _2));  //Listen on port 2152  server.listen(8090);  //Start the server accept loop  server.start_accept();  //Start the ASIO io_service run loop  server.run();  return 0;}

Html代碼

<!DOCTYPE html><html><head><title>Testing websockets</title></head><body> <div>  <input type="submit" value="Start" onclick="start()" /> </div> <div id="messages"></div> <script type="text/javascript">  var webSocket =   new WebSocket('ws://localhost:8090');   webSocket.onerror = function(event) {   onError(event)  };   webSocket.onopen = function(event) {   onOpen(event)  };    webSocket.onclose = function(event) {   onClose(event)  };   webSocket.onmessage = function(event) {   onMessage(event)  };   function onMessage(event) {   document.getElementById('messages').innerHTML    += '<br />' + event.data;  }   function onOpen(event) {   document.getElementById('messages').innerHTML    = 'Connection established';  }    function onClose(event) {   document.getElementById('messages').innerHTML    += '<br />disconnection';  }  function onError(event) {   alert(event.data);  }   function start() {   webSocket.send('hello');   return false;  } </script></body></html>

運行結果

websocket

 

websocket

以上這篇websocket++簡單使用及實例分析就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持VEVB武林網。



發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 庆元县| 临洮县| 乌苏市| 平罗县| 沁阳市| 新邵县| 五家渠市| 平和县| 崇义县| 舞钢市| 上虞市| 剑阁县| 桓台县| 沾益县| 丰台区| 巴彦淖尔市| 友谊县| 通河县| 杭锦旗| 饶阳县| 峨眉山市| 奇台县| 田东县| 漳平市| 湾仔区| 遂平县| 同心县| 阜新| 基隆市| 秦皇岛市| 栖霞市| 沅江市| 锡林浩特市| 灵山县| 色达县| 新田县| 石狮市| 册亨县| 乌兰浩特市| 永兴县| 锡林浩特市|