基於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
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...