Electron运行环境判断(是否在虚拟机中)

前言

为了防止用户在虚拟机中运行软件,我们需要为当前运行环境做判断,为虚拟机的话我们退出程序就可以了。

原理:使用命令获取计算机的硬件信息,进行关键字匹配

shell 复制代码
# win
powershell "Get-WmiObject -Class Win32_ComputerSystem | Select-Object Manufacturer, Model"
base 复制代码
# Mac
system_profiler SPHardwareDataType

正文

在主流虚拟机中的情况

  1. Hyper-V

关键字Virtual Machine

  1. VMware

Windows系统,关键字VMware

Mac系统,关键字Virtual MachineVMware

  1. QEMU

关键字QEMU

代码

js 复制代码
/* 虚拟机特征 */
const vmSignatures = [
  //虚拟机软件
  'VMware',
  //桌面虚拟化软件
  'VirtualBox',
  //开源的桌面虚拟化软件
  'VBox',
  //开源的硬件模拟器和虚拟化器
  'QEMU',
  //开源的虚拟机管理器(或称 hypervisor)
  'Xen',
  //微软开发的硬件虚拟化产品
  'Hyper-V',
  //虚拟化软件
  'Parallels',
  // 关键字
  'Virtual Machine',
];

/* 是否是虚拟机 */
export const isVirtualMachine = async () => {
  if (process.platform == 'win32') {
    return detectWindowsVM(); // 在Windows系统上检测虚拟机
  }
  if (process.platform == 'darwin') {
    return detectMacOSVM(); // 在Mac系统上检测虚拟机
  }
  return false;
};

/* Windows 虚拟机检测 */
const detectWindowsVM = async (): Promise<boolean> => {
  try {
    const { exec } = require('child_process');
    const util = require('util');
    const execAsync = util.promisify(exec);

    // 使用PowerShell Get-WmiObject检查系统制造商
    try {
      const { stdout: systemInfo } = await execAsync(
        'powershell "Get-WmiObject -Class Win32_ComputerSystem | Select-Object Manufacturer, Model"',
      );

      log.info('systemInfo:', systemInfo.toLowerCase());
      for (const signature of vmSignatures) {
        if (systemInfo.toLowerCase().includes(signature.toLowerCase())) {
          log.info('VM detected by Get-WmiObject:', systemInfo);
          return true;
        }
      }
    } catch (error) {
      log.debug('Get-WmiObject check failed:', error);
    }

    return false;
  } catch (error) {
    log.error('Windows VM detection error:', error);
    return false;
  }
};

/* macOS 虚拟机检测 */
const detectMacOSVM = async (): Promise<boolean> => {
  try {
    const { exec } = require('child_process');
    const util = require('util');
    const execAsync = util.promisify(exec);

    // 检查系统硬件信息
    try {
      const { stdout: sysInfo } = await execAsync(
        'system_profiler SPHardwareDataType',
      );

      log.info('macOS system info:', sysInfo.toLowerCase());
      for (const signature of vmSignatures) {
        if (sysInfo.toLowerCase().includes(signature.toLowerCase())) {
          log.info('VM detected by system info:', signature);
          return true;
        }
      }
    } catch (error) {
      log.debug('System info check failed:', error);
    }

    return false;
  } catch (error) {
    log.error('macOS VM detection error:', error);
    return false;
  }
};

结语

感谢阅读

相关推荐
RFCEO4 分钟前
前端编程 课程十三、:CSS核心基础1:CSS选择器
前端·css·css基础选择器详细教程·css类选择器使用方法·css类选择器命名规范·css后代选择器·精准选中嵌套元素
烬头882128 分钟前
React Native鸿蒙跨平台采用了函数式组件的形式,通过 props 接收分类数据,使用 TouchableOpacity实现了点击交互效果
javascript·react native·react.js·ecmascript·交互·harmonyos
Amumu1213828 分钟前
Vuex介绍
前端·javascript·vue.js
We་ct29 分钟前
LeetCode 54. 螺旋矩阵:两种解法吃透顺时针遍历逻辑
前端·算法·leetcode·矩阵·typescript
qq_177767371 小时前
React Native鸿蒙跨平台通过Animated.Value.interpolate实现滚动距离到动画属性的映射
javascript·react native·react.js·harmonyos
2601_949480061 小时前
【无标题】
开发语言·前端·javascript
css趣多多1 小时前
Vue过滤器
前端·javascript·vue.js
理人综艺好会2 小时前
Web学习之用户认证
前端·学习
●VON2 小时前
React Native for OpenHarmony:项目目录结构与跨平台构建流程详解
javascript·学习·react native·react.js·架构·跨平台·von
We་ct2 小时前
LeetCode 36. 有效的数独:Set实现哈希表最优解
前端·算法·leetcode·typescript·散列表