WebRTC+Vue3+Electron+Nodejs打造一个开源远程桌面(累计100+⭐)

3,134 阅读1分钟

体验

Web端在线体验:desk.hsslive.cn

客户端下载:

Macos:resource.hsslive.cn/billd-desk-…

Windows:resource.hsslive.cn/billd-desk-…

github地址:

web端:github.com/galaxy-s10/…

客户端:github.com/galaxy-s10/…

移动端:github.com/galaxy-s10/…

服务端:github.com/galaxy-s10/…

简介

BilldDesk远程桌面控制,目前实现了类似ToDesk、向日葵等远程桌面的功能。

生态

名称仓库star & fork线上地址
远程桌面网页端billd-deskgithub githubdesk.hsslive.cn
远程桌面客户端billd-desk-electrongithub github
远程桌面移动端billd-desk-fluttergithub github
远程桌面服务端billd-desk-servergithub github

功能

  • Web端控制桌面客户端
  • Web端查看Web端
  • 桌面客户端控制桌面客户端
  • 桌面客户端查看Web端
  • 连接鉴权
  • 支持Macos系统
  • 支持Windows系统
  • 支持Linux系统
  • 文件传输
  • 移动客户端
  • 后台管理

目前暂不考虑实现以下功能:

  • ❌ Web端控制Web端
  • ❌ 桌面客户端控制Web端

预览

控制端发起远程控制

111.png

222.png

控制端正在控制被控端

333.png

被控端

444.png

本地启动

  • 安装依赖(建议使用 node 版本:v18.19.0)
pnpm i

更新 billd 相关依赖:

pnpm i billd-utils@latest billd-scss@latest billd-html-webpack-plugin@latest
  • 运行
npm run dev
  • 打包windows、macos、linux包
npm run build
  • 打包windows包
npm run build:win
  • 打包macos包
npm run build:mac
  • 打包linux包
npm run build:linux

常见问题

rebuild

npm config set registry https://registry.npmmirror.com
./node_modules/.bin/electron-rebuild

rebuild时cpu-feature报错

直接删了node_modules的cpu-feature

pnpm安装electron时卡在postinstall

  1. 直接ctrl+c退出npm安装
  2. 进入node_modules/electron/install.js,将
    downloadArtifact({
      version,
      artifactName: 'electron',
      force: process.env.force_no_cache === 'true',
      cacheRoot: process.env.electron_config_cache,
      checksums:
        process.env.electron_use_remote_checksums ??
        process.env.npm_config_electron_use_remote_checksums
          ? undefined
          : require('./checksums.json'),
      platform,
      arch,
    })
      .then(extractFile)
      .catch((err) => {
        console.error(err.stack);
        process.exit(1);
      });
    
    修改为:
    downloadArtifact({
      version,
      artifactName: 'electron',
      force: process.env.force_no_cache === 'true',
      cacheRoot: process.env.electron_config_cache,
      checksums:
        process.env.electron_use_remote_checksums ??
        process.env.npm_config_electron_use_remote_checksums
          ? undefined
          : require('./checksums.json'),
      platform,
      arch,
      mirrorOptions: {
        mirror: 'https://npmmirror.com/mirrors/electron/',
        platform,
        arch,
      },
    })
      .then(extractFile)
      .catch((err) => {
        console.error(err.stack);
        process.exit(1);
      });
    
  3. 在node_modules/electron目录下执行node install

性能测试

todo

交流群🔥

WechatIMG1417.jpg

兼容性

  • Windows
  • Macos
  • Linux