当前位置: 首页 > web >正文

JavaScript VMP (Virtual Machine Protection) 分析与调试

VMP 的基本逻辑和特征

JavaScript VMP (虚拟机器保护) 是一种代码混淆技术,它将原始JavaScript代码转换为在自定义虚拟机中执行的字节码,使得逆向工程变得困难。

主要特征

  1. 字节码执行

    • 原始JS代码被编译为自定义字节码

    • 运行时通过解释器执行这些字节码

  2. 虚拟指令集

    • 自定义的操作码和操作数

    • 可能包含算术、逻辑、控制流等虚拟指令

  3. 堆栈或寄存器架构

    • 模拟传统虚拟机的堆栈或寄存器操作

  4. 反调试技术

    • 检测开发者工具

    • 检测调试器存在

    • 使用无限循环或异常干扰调试

  5. 代码动态生成

    • 运行时动态构造关键代码片段

    • 可能配合evalFunction构造函数使用

调试方法

1. 静态分析

  • 代码格式化:使用工具美化混淆代码

  • 识别虚拟机结构:查找以下模式:

  • // 典型的VMP结构
    var vm = {stack: [],ip: 0,bytecode: [...],dispatch: function() {while(this.ip < this.bytecode.length) {var opcode = this.bytecode[this.ip++];switch(opcode) {case 0x01: /* 操作1 */ break;case 0x02: /* 操作2 */ break;// ...}}}
    };

    2. 动态调试

  • 使用Chrome DevTools

    • 设置断点并单步执行

    • 监控调用栈和变量变化

    • 使用"Blackbox script"功能忽略库代码

  • Hook关键函数

// Hook Function构造函数
var originalFunction = Function;
Function = function() {console.log('Function constructor called with args:', arguments);return originalFunction.apply(this, arguments);
};

3. 反反调试技巧

  • 禁用调试检测

    // 覆盖常见的调试检测
    Object.defineProperty(window, 'console', {get: function() {return {log: function(){}, debug: function(){}, /* 其他方法 */};}
    });

    修改时间相关检测

    // 干扰基于时间的检测
    Date.now = function() { return 0; };
    performance.now = function() { return 0; };

还原VMP代码的步骤

  1. 识别字节码加载部分:找到字节码数组和解释器主循环

  2. 分析指令集:通过交叉引用确定各操作码的功能

  3. 重建控制流

    • 跟踪跳转指令(如JMP、CALL、RET)

    • 重建函数调用关系

  4. 模拟执行

    • 编写脚本模拟虚拟机执行

    • 记录执行路径和数据流

  5. 转换为高级代码

    • 根据模拟结果将字节码转换回JS代码

实用工具

  1. Babel:用于解析和转换JS代码

  2. AST Explorer:可视化分析代码结构

  3. Terser:代码反混淆工具

  4. 自定义解析脚本:针对特定VMP实现编写解析器

示例分析

假设遇到如下VMP代码:

var _0xabc = [0x1, 0x2, 0x3, 'push', 'pop', 0x4];
var vm = {s: [],p: 0,run: function() {while(this.p < _0xabc.length) {var op = _0xabc[this.p++];if(typeof op == 'string') {this[op]();} else {this.s.push(op);}}},push: function() { /* ... */ },pop: function() { /* ... */ }
};
vm.run();

分析步骤:

  1. 识别字节码数组_0xabc

  2. 分析解释器循环run方法

  3. 确定指令含义(数字为数据,字符串为操作)

  4. 模拟执行并记录堆栈状态

http://www.xdnf.cn/news/15222.html

相关文章:

  • 创建显示心电图的组件
  • 前端学习4:小白入门注册表单的制作(包括详细思考CSS、JS实现过程)
  • uniapp语音播报天气预报微信小程序
  • 格密码--数学基础--02基变换、幺模矩阵与 Hermite 标准形
  • 从UI设计到数字孪生实战应用:构建智慧金融的风险评估与预警平台
  • 使用 SSH 连接 GitHub
  • 飞算 JavaAI 深度体验:开启 Java 开发智能化新纪元
  • 速学 RocketMQ
  • 基于定制开发开源AI智能名片与S2B2C商城小程序的旅游日志创新应用研究
  • FPGA实现SDI转LVDS视频发送,基于GTX+OSERDES2原语架构,提供2套工程源码和技术支持
  • Maui劝退:用windows直接真机调试iOS,无须和Mac配对
  • leetcode:518. 零钱兑换 II[完全背包]
  • Python 类型注解实战:`Optional` 与安全数据处理的艺术
  • 静态路由综合实验
  • GitHub敏感信息收集与防御指南
  • 人大金仓下载安装教程总结
  • 时间显示 蓝桥云课Java
  • 安卓应用启动崩溃的问题排查记录
  • P1722 矩阵 II 题解 DFS深度优先遍历与卡特兰数(Catalan number)解
  • 【实战】使用 ELK 搭建 Spring Boot Docker 容器日志监控系统
  • 【三维生成】FlashDreamer:基于扩散模型的单目图像到3D场景
  • 力扣-54.螺旋矩阵
  • “Datawhale AI夏令营”基于带货视频评论的用户洞察挑战赛
  • 敏捷测试中的质量闸门如何设置?
  • 【RL-VLM-F】算法框架图绘图学习笔记
  • 【PyTorch】PyTorch中的数据预处理操作
  • Java 与 MySQL 性能优化:MySQL连接池参数优化与性能提升
  • 7月10号总结 (1)
  • HTTP核心基础详解(附实战要点)
  • Android开发中几种scope的对比