基於socket.io打造hybrid調試頁面

来源:http://www.cnblogs.com/dailc/archive/2017/11/28/7910900.html
-Advertisement-
Play Games

前言 參考的 "釘釘調試頁面" 實現,僅供學習! 功能為: __PC端編寫代碼,手機端執行__ 解決的痛點是: __避免了調試 應用時重覆寫各種測試頁面__ 源碼與示例 __源碼__ "https://github.com/dailc/node server examples/tree/master ...


前言

參考的釘釘調試頁面實現,僅供學習!

功能為:

PC端編寫代碼,手機端執行

解決的痛點是:

避免了調試hybrid應用時重覆寫各種測試頁面

源碼與示例

源碼

https://github.com/dailc/node-server-examples/tree/master/node-socketio-hybriddebug

運行

1.`npm install`

2.`npm run serve`啟動`node`服務

3.瀏覽器打開`./test/debugroom.html`頁面

4.開始測試(瀏覽器直接打開或手機掃碼)

註意,手機端鏈接請確保在同一個網段

註意⚠️,實際情況請重寫client頁面,讓其支持對於Hybrid容器的API

示例

image

image

原理

原理其實非常簡單,就是HTML5中的websocket,而且為了方便,還直接使用了成熟的第三方庫socket.io

基本交互如下:

1.先啟動一個node後臺(控制台),基於`express``socket.io`監聽`socket`連接

2.打開一個PC端調試頁面,連接後臺,創建一個房間(可以創建N個房間)

3.PC端頁面基於房間號生成對應房間的客戶端地址(每一個房間中可以有`N`個客戶端),並基於地址創建二維碼,方便使用(可以基於`qrcode.js`等庫)

4.`Hybrid`客戶端掃碼後(或者打開客戶端鏈接後),客戶端頁面連接後臺,根據當前的房間號,在房間中創建客戶端

5.PC端輸入代碼後,點擊執行時,會將代碼文本發送到後臺,然後後臺再推送給客戶端,客戶端通過`eval`即可執行這段代碼,執行完畢後也可通過同樣方式通知PC端

需要註意的是:

  • 服務端是引用的npmsocket.io

  • 客戶端是引用socket.io-client項目中發佈的socket.io.js文件

另外:

  • 後臺程式直接基於es6語法編寫的,然後基於gulp打包成dest文件,實際運行的是dest中的發佈文件,代碼規範接近與airbnb

  • 前端頁面的話比較隨意,樣式還大量用了釘釘原本的樣式,也沒有考慮各種瀏覽器的相容

  • 為什麼說是hybrid調試頁面?因為打造它的核心需求就是用來調試hybridAPI

步驟

由於篇幅關係(也沒有必要),並不會將所有代碼都介紹一遍,只會介紹一些重點步驟,更多的可以直接閱讀源碼(源碼中已經足夠清晰)

設計DebugRoom(PC端)和DebugClienthybrid端)

根據交互,PC端和hybrid端都需要和後臺連接,因此這裡直接單獨封裝了兩個類

DebuRoom類

房間的定義是:

  • 只有一個socket引用

  • 有一個房間id標識

  • 房間內可以管理客戶端(增,刪,查)

class DebugRoom {
    // 所屬的房間號
    this._roomId
    // 所持有的socket對象
    this._socket
    // 客戶端持有預設是一個空對象,key是clientid,value是client
    this._clients
    
    id()
    clients()
    socket()
    getClientsCount()
    removeClient(client)
    addClient(client)
    clearClients()
}

DebugClient類

客戶端的定義是:

  • 只有一個socket引用

  • 有一個客戶端id標識

  • 有一個房間id引用,指向對於的房間號(當然其實也可以是引用DebugRoom對象的)

class DebugClient {
    // 所屬的房間號
    this._roomId
    // 客戶端id
    this._clientId
    // 所持有的socket對象
    this._socket
    
    id()
    roomId()
    socket()
}

設計一些交互介面

前後端交互通過socket.io中定義的事件來,以下是房間以及客戶端和後臺的交互事件介面

通用交互事件

後臺:

// 後臺監聽連接,每有一個連接時(前端通過`io.connect`),會通知客戶端觸發'open'事件
io.on('connection', ...)

// 後臺監聽關閉連接,每當連接關閉時(前端直接關閉或調用`socket.disconnect`),會檢測本地房間與客戶端,如果關閉的是客戶端,則移除這個客戶端,對於的房間下的引用也置空,否則如果是房間,移除並關閉房間內所有的客戶端
io.on('disconnect', ...)

房間與客戶端:

// 前臺監聽打開事件,此時,如果是房間,則會通知後臺觸發'create room',否則通知後臺觸發'create client'
socket.on('open', ...)

// 前臺監聽連接是否關閉
socket.on('disconnect', ...)

房間與後臺交互事件

後臺:

// 監聽創建房間,如果房間ID合法,則會創建一個新的房間(new DebugRoom)
io.on('create room', ...)
// 監聽房間分發數據,並且將數據轉發給房間內的所有客戶端,通知客戶端觸發'receive dispatch data'事件
io.on('dispatch data', ...)

房間:

// 監聽客戶端創建,每一個客戶端加入對應房間時都會通知這個房間
socket.on('client created', ...)
// 監聽客戶端關閉,每一個客戶端退出時都會通知這個房間
socket.on('client destroy', ...)
// 監聽客戶端執行,客戶端每執行一次分發數據時,都會通知房間是否執行成功
socket.on('client excuted', ...)

客戶端與後臺交互事件

後臺:

// 監聽客戶端創建,如果房間已存在,並且客戶端id合法,才會正常創建,創建完後會通知房間觸發'client created'事件
io.on('create client', ...)
// 監聽客戶端響應執行,客戶端執行一次分發數據後,會通知後臺,後臺接收到這個事件後,通知房間觸發'client excuted'事件
io.on('client excute notify', ...)

客戶端:

// 監聽接收分發數據,接收完後會執行數據中的代碼,並且通知後臺是否執行成功,觸發後臺的'client excute notify'事件
socket.on('receive dispatch data', ...)

一些邏輯上的細節

以上流程就是整套程式的基本思路與交互,這裡再補充一些交互細節

  • 用全局的roomsHashclientsHash緩存住所有的房間和客戶端,方便直接查詢

  • 每次創建時,id可以直接綁定在對於的socket中,這樣更方便

  • 房間和客戶端id最好不要直接使用,可以進過一次編碼(這樣可以直接使用中文)

  • 客戶端失聯時,一定要先判斷房間是否以及銷毀,不要重覆操作

  • 失去連接後,緩存中的引用要及時清除

更多源碼請參考https://github.com/dailc/node-server-examples/tree/master/node-socketio-hybriddebug

附錄

參考資料


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 表格是一個組合標簽,用來佈局,相容性好;現在佈局思路大多數是div+Css。 對於表格標簽做了一下概述,認識一下。表格的頭部<thead></thead,和<tfoot></tfoot>可以省略,主要樣式如下 <tr></tr>表格的行,<td></td>表格的單元格。 表格標簽類型及特性: 1,單 ...
  • 針對vue中控制項的用法 首先 初步用法 }) 子組件調用父組件的方法 和父組件傳值入子組件 子組件: 父組件 : 動態切換不同的組件 在掛載點使用component標簽,然後使用v-bind:is=”組件名”,會自動去找匹配的組件名,如果沒有,則不顯示; 改變掛載的組件,只需要修改is指令的值即可 ...
  • JavaScript箭頭函數是ECMAScript 6中引入的編寫函數表達式的一種簡便方法。通常,在JavaScript中,可以通過兩種方式創建函數: 函數語句。 函數表達式。 可以如下所示創建函數語句: 也可以創建相同功能的函數表達式,如下所示: ECMA 2015(或ECMA Script 6) ...
  • jquery中的ajax方法參數總是記不住,這裡記錄一下。 1.url: 要求為String類型的參數,(預設為當前頁地址)發送請求的地址。 2.type: 要求為String類型的參數,請求方式(post或get)預設為get。註意其他http請求方法,例如put和delete也可以使用,但僅部分 ...
  • 作者: 以前在寫項目過程一直都沒有使用過Javascript的setter與getter方法,所以對其是一種要懂不懂的概念;今天看書看到這個知識點,還是模模糊糊的,於是就打算研究研究; Javascript對象的屬性是由名字,值和一組特性構成的。那麼首先,來瞭解一下對象的兩種屬性: + 數據屬性,我 ...
  • 簡介 Vue.use( plugin ):安裝 Vue.js 插件。如果插件是一個對象,必須提供 install 方法。如果插件是一個函數,它會被作為 install 方法。install 方法將被作為 Vue 的參數調用。 當 install 方法被同一個插件多次調用,插件將只會被安裝一次。 Vu ...
  • 項目的GitHub地址:https://github.com/hellobajie/vue-cli-multipage 該腳手架同時支持vux,scss,less 目錄結構 修改配置文件 構建多頁面應用的關鍵在於向配置對象的plugins子項添加多個HtmlWebpackPlugin。 怎樣根據頁面 ...
  • 如上,想要實現左右持續運動,則把該動畫封裝為一個函數,再反覆調用就好。 ...
一周排行
    -Advertisement-
    Play Games
  • 前言 本文介紹一款使用 C# 與 WPF 開發的音頻播放器,其界面簡潔大方,操作體驗流暢。該播放器支持多種音頻格式(如 MP4、WMA、OGG、FLAC 等),並具備標記、實時歌詞顯示等功能。 另外,還支持換膚及多語言(中英文)切換。核心音頻處理採用 FFmpeg 組件,獲得了廣泛認可,目前 Git ...
  • OAuth2.0授權驗證-gitee授權碼模式 本文主要介紹如何筆者自己是如何使用gitee提供的OAuth2.0協議完成授權驗證並登錄到自己的系統,完整模式如圖 1、創建應用 打開gitee個人中心->第三方應用->創建應用 創建應用後在我的應用界面,查看已創建應用的Client ID和Clien ...
  • 解決了這個問題:《winForm下,fastReport.net 從.net framework 升級到.net5遇到的錯誤“Operation is not supported on this platform.”》 本文內容轉載自:https://www.fcnsoft.com/Home/Sho ...
  • 國內文章 WPF 從裸 Win 32 的 WM_Pointer 消息獲取觸摸點繪製筆跡 https://www.cnblogs.com/lindexi/p/18390983 本文將告訴大家如何在 WPF 裡面,接收裸 Win 32 的 WM_Pointer 消息,從消息裡面獲取觸摸點信息,使用觸摸點 ...
  • 前言 給大家推薦一個專為新零售快消行業打造了一套高效的進銷存管理系統。 系統不僅具備強大的庫存管理功能,還集成了高性能的輕量級 POS 解決方案,確保頁面載入速度極快,提供良好的用戶體驗。 項目介紹 Dorisoy.POS 是一款基於 .NET 7 和 Angular 4 開發的新零售快消進銷存管理 ...
  • ABP CLI常用的代碼分享 一、確保環境配置正確 安裝.NET CLI: ABP CLI是基於.NET Core或.NET 5/6/7等更高版本構建的,因此首先需要在你的開發環境中安裝.NET CLI。這可以通過訪問Microsoft官網下載並安裝相應版本的.NET SDK來實現。 安裝ABP ...
  • 問題 問題是這樣的:第三方的webapi,需要先調用登陸介面獲取Cookie,訪問其它介面時攜帶Cookie信息。 但使用HttpClient類調用登陸介面,返回的Headers中沒有找到Cookie信息。 分析 首先,使用Postman測試該登陸介面,正常返回Cookie信息,說明是HttpCli ...
  • 國內文章 關於.NET在中國為什麼工資低的分析 https://www.cnblogs.com/thinkingmore/p/18406244 .NET在中國開發者的薪資偏低,主要因市場需求、技術棧選擇和企業文化等因素所致。歷史上,.NET曾因微軟的閉源策略發展受限,儘管後來推出了跨平臺的.NET ...
  • 在WPF開發應用中,動畫不僅可以引起用戶的註意與興趣,而且還使軟體更加便於使用。前面幾篇文章講解了畫筆(Brush),形狀(Shape),幾何圖形(Geometry),變換(Transform)等相關內容,今天繼續講解動畫相關內容和知識點,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 什麼是委托? 委托可以說是把一個方法代入另一個方法執行,相當於指向函數的指針;事件就相當於保存委托的數組; 1.實例化委托的方式: 方式1:通過new創建實例: public delegate void ShowDelegate(); 或者 public delegate string ShowDe ...