老熟女激烈的高潮_日韩一级黄色录像_亚洲1区2区3区视频_精品少妇一区二区三区在线播放_国产欧美日产久久_午夜福利精品导航凹凸

重慶分公司,新征程啟航

為企業提供網站建設、域名注冊、服務器等服務

vue中怎么引入noVNC遠程桌面-創新互聯

今天就跟大家聊聊有關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

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, // 目標
  "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遠程桌面有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注創新互聯成都網站設計公司行業資訊頻道,感謝大家的支持。

另外有需要云服務器可以了解下創新互聯scvps.cn,海內外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業上云的綜合解決方案,具有“安全穩定、簡單易用、服務可用性高、性價比高”等特點與優勢,專為企業上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。


分享標題:vue中怎么引入noVNC遠程桌面-創新互聯
瀏覽地址:http://www.xueling.net.cn/article/pigjs.html

其他資訊

在線咨詢
服務熱線
服務熱線:028-86922220
TOP
主站蜘蛛池模板: 国产黄频免费无数次看 | yellow网站免费观看 | a级片在线观看免费 | 狂野欧美激情性XXXX按摩 | 亚洲国产成人91精品 | 又嫩又硬又黄又爽的视频 | 业余自由性别成熟偷窥 | 国产果冻豆传媒麻婆精东 | 成全视频在线观看大全腾讯地图 | 久久久久久伊人 | 日一区二区三区 | 国产精品一级无遮挡毛片 | 偷拍区另类综合在线 | 精品服丝袜无码视频一区 | 国产精品厕所 | 欧美成人免费 | 国产91亚洲精品 | 伊人大蕉久在线播放 | 日本一级囗交免费 | 色无码av在线播放 | 日韩欧美一区二区中文字幕 | 亚洲精品AV午夜一区二区三区 | 国产下面一进一出好爽视频 | 高清国产下药迷倒白嫩美女99 | 日本a大片 | 国产一在线精品一区在线观看 | 日韩在线观看免费一二三区 | 九九热视频在线 | 亚洲欧美日韩在线一区二区三区 | 玩丰满高大邻居人妻无码 | 欧美大香线蕉线伊人久久 | p色视频免费在线观看 | 国产欧美亚洲精品第三页 | 91精品国产自产在线 | 999这里有精品 | 天天色综合色 | 欧洲肥臀内射网站 | 大香伊蕉最新视频 | jizz麻豆视频| 中文字幕第35页 | 久久丫精品系列 |