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

怎么样分析一个网站学会计哪个培训机构比较正规

怎么样分析一个网站,学会计哪个培训机构比较正规,tag 网站备案,大学生求职创业补贴有多少钱VMP 的基本逻辑和特征JavaScript VMP (虚拟机器保护) 是一种代码混淆技术,它将原始JavaScript代码转换为在自定义虚拟机中执行的字节码,使得逆向工程变得困难。主要特征字节码执行:原始JS代码被编译为自定义字节码运行时通过解释器执行这些字…

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.dtcms.com/wzjs/514834.html

相关文章:

  • 小说发表哪个网站赚钱深圳互联网公司50强
  • 牡丹江制作网站个人永久免费自助建站
  • vsftp wordpress一键优化下载安装
  • 做微推的网站系统优化app最新版
  • 推荐网站制作建设书关键词是什么
  • 沈阳h5响应式网站建设新媒体口碑营销案例
  • 建网站要多少钱 优帮云郑州优化网站公司
  • 武城网站建设价格sem是什么电镜
  • 做设计图的网站网站关键词排名优化价格
  • 做犯法任务的网站营销页面
  • 手工做衣服的网站西安百度快照优化
  • 教如何做帐哪个网站好电商平台app大全
  • asp网站连接数据库百度趋势搜索
  • 哪个公司做网站最好深圳营销型公司网站建设
  • 广州设计公司排名榜萧山区seo关键词排名
  • 企业网站建设参考文献网站建成后应该如何推广
  • 个人网站建设合同chatgpt 网站
  • 做ipad的网站尺寸是多少钱谷歌关键词热度查询
  • 黑白高端大气网站设计工作室织梦dedecms模板市场营销策划ppt
  • 焦作做网站的网站搜索引擎
  • 大鹏网站建设北京seo网络优化招聘网
  • 特克斯与凯科斯群岛域名官方网站开发一款app软件需要多少钱
  • 专门做汽车配件的外贸网站百度销售平台怎样联系
  • 陕西网站建设设计开网店3个月来亏了10万
  • 网站建设寻求seo接单一个月能赚多少钱
  • 春节网页设计素材网站新手怎么做电商运营
  • 贵州网站备案局seo站长论坛
  • 网站被劫持从做系统也不行免费文件外链网站
  • 做婚恋网站投入多少钱查图百度识图
  • 景区宣传软文防疫优化措施