您好,登錄后才能下訂單哦!
今天就跟大家聊聊有關vue中怎么引入noVNC遠程桌面,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。
1 、首先,先簡單介紹一下概念。
VNCServer 是一個為了滿足分布式用戶共享服務器資源,而在服務器開啟的一項服務,對應的客戶端軟件有圖形化客戶端 VNCViewer,而 noVNC 則是 HTML5 VNC 客戶端,它采用 HTML 5 WebSocket, Canvas 和 JavaScript 實現。
noVNC 被普遍用在各大云計算、虛擬機控制面板中。noVNC 采用 WebSockets 實現,但是當前大多 VNC 服務器不支持 WebSocket,所以 noVNC 不能直連 VNC 服務器,而是需要開啟一個代理來做 WebSockets 和 TCP sockets 之間的轉換。這個代理叫做 websockify。
2 、項目中有這樣一個需求,系統中有多個功能頁,但是功能還包括原有的在物理終端設備上的功能(包括后來在電腦的虛擬終端客戶端),這就用到了noVNC。好處是可以將其他功能系統(或稱之為頁面)嵌入新的項目中,還可以去點擊操作上面的功能等,可以暫時解決一些問題。
3 、由于項目框架是vue,所以以下均為前端實現部分
首先是先引入noVNC的庫。有兩種引入方式,一是,直接下載源碼到自己的項目中,此方式一些問題下面進行詳細介紹;
git clone git://github.com/novnc/noVNC
二是,如果采用了webpack的方式,可以使用npm進行安裝依賴,更方便。
npm install @novnc/novnc
下面是詳細代碼部分
HTML
<template> <div class="page-home" ref="canvas"> <canvas id="noVNC_canvas" width="800" height="600"> Canvas not supported. </canvas> </div> </template>
Script
import WebUtil from '../../noVNC/app/webutil.js' import Base64 from '../../noVNC/core/base64.js' import Websock from '../../noVNC/core/websock.js' import '../../noVNC/core/des.js' import '../../noVNC/core/input/keysymdef.js' import '../../noVNC/core/input/xtscancodes.js' import '../../noVNC/core/input/util.js' import {Keyboard, Mouse} from '../../noVNC/core/input/devices.js' import Display from '../../noVNC/core/display.js' import '../../noVNC/core/inflator.js' import RFB from '../../noVNC/core/rfb.js' import '../../noVNC/core/input/keysym.js'
由于采用的是第一種引入方式,所以在資源引入上用了import的方式。需要注意的是在引入某些文件時,項目是基于es6的語法,所以引入外部js的方式略有差異。例如引入webutil.js文件,需要增加export default,然后才能正確使用。在引入時可以稍微修改一下文件即可。文件中有相應的備注描述。
引入資源完成后接下來就是如何去使用了,其實并不復雜。話不多說,上碼。
connectVNC () { var DEFAULT_HOST = '', DEFAULT_PORT = '', DEFAULT_PASSWORD = "", DEFAULT_PATH = "websockify" ; var cRfb = null; var oTarget = document.getElementById("noVNC_canvas"); let that = this if (!this.currentEquipment) { return } let novncPort = this.currentEquipment.novncPort getNovncIp().then(function (resData) { WebUtil.init_logging(WebUtil.getConfigVar("logging", "warn")); var sHost = resData.data.content.ip || DEFAULT_HOST, nPort = novncPort || DEFAULT_PORT, sPassword = DEFAULT_PASSWORD, sPath = DEFAULT_PATH ; cRfb = new RFB({ "target": oTarget,<span class="space" > // 目標</span> "focusContainer": top.document, // 鼠標焦點定位 "encrypt": WebUtil.getConfigVar("encrypt", window.location.protocol === "https:"), "repeaterID": WebUtil.getConfigVar("repeaterID", ""), "true_color": WebUtil.getConfigVar("true_color", true), "local_cursor": WebUtil.getConfigVar("cursor", true), "shared": WebUtil.getConfigVar("shared", true), "view_only": WebUtil.getConfigVar("view_only", false), "onFBUComplete": that._onCompleteHandler, // 回調函數 "onDisconnected": that._disconnected // 斷開連接 }); // console.log('sHost:' + sHost + '--nPort:' + nPort) cRfb.connect(sHost, nPort, sPassword, sPath); }) },
首先是在methods生命周期中定義了一個方法,把初始化相關的操作寫在里面。然后再mounted生命周期中去調用this.connectVnc()。一定要在這個生命周期內去調用,否則canvas未初始化是不能獲取到dom結構的。
簡單描述一下就是,實例化一個對象,包括一些用到的方法或者屬性,然后調用connect方法,并傳入host,port,password,path參數即可建立連接。
其中有兩個方法,一個是鏈接成功后的回調_.onCompleteHandler,一個是斷開連接的回調_disconnected
// 遠程桌面連接成功后的回調函數 _onCompleteHandler (rfb, fbu) { // 清除 onComplete 的回調。 rfb.set_onFBUComplete(function () { }); var oDisplay = rfb.get_display(), nWidth = oDisplay.get_width(), nHeight = oDisplay.get_height(), oView = oDisplay.get_target(), nViewWidth = oView.clientWidth, nViewHeight = oView.clientHeight ; // 設置當前與實際的比例。 oDisplay.setScale(nWidth / nViewWidth, nHeight / nViewHeight); }
看完上述內容,你們對vue中怎么引入noVNC遠程桌面有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。