服务器虚拟化vnc,Vue中使用novnc来构建虚拟化桌面

这篇博客详细介绍了如何在Vue项目中集成novnc库,实现远程桌面的连接和断开处理。通过监听连接状态,动态调整视口大小,并提供重连功能,为用户提供虚拟化桌面服务。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

安装novnc

yarn add @novnc/novnc

npm i @novnc/novnc

具体用法可以参阅官方文档

https://github.com/novnc/noVN…

在vue里面使用

template

//虚拟化桌面将已canvas的形式被渲染到这里

script

import RFB from '@novnc/novnc/core/rfb';

export default {

name: 'novnc',

data () {

rfb:null,

url: undefined, //链接的url

IsClean: false, //是否已断开并不可重新连接

connectNum:0 //重连次数

},

methods: {

// vnc连接断开的回调函数

disconnectedFromServer (msg) {

if(msg.detail.clean){

// 根据 断开信息的msg.detail.clean 来判断是否可以重新连接

this.contentVnc()

} else {

//这里做不可重新连接的一些操作

}

},

// 连接成功的回调函数

connectedToServer() {

console.log('success')

},

//连接vnc的函数

connectVnc () {

const PASSWORD = '';

let rfb = new RFB(document.getElementById('screen'), this.url, {

// 向vnc 传递的一些参数,比如说虚拟机的开机密码等

credentials: {password: password}

});

rfb.addEventListener('connect', this.connectedToServer);

rfb.addEventListener('disconnect', this.disconnectedFromServer);

rfb.scaleViewport = true; //scaleViewport指示是否应在本地扩展远程会话以使其适合其容器。禁用时,如果远程会话小于其容器,则它将居中,或者根据clipViewport它是否更大来处理。默认情况下禁用。

rfb.resizeSession = true; //是一个boolean指示是否每当容器改变尺寸应被发送到调整远程会话的请求。默认情况下禁用

this.rfb = rfb;

}

},

在mounted周期里面连接vnc

mounted () {

//这时已经可以获取到dom元素

this.connectVnc()

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值