news 2026/4/15 15:02:22

某聘新版AST解混淆(青春版)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
某聘新版AST解混淆(青春版)

最近网站大更了一次,代码和结构都变了,某聘的混淆还是挺复杂的,不解硬补的话非常头疼,有很多检测点都发现不了。

但是本人AST技术有限,只能做到把三元表达式,函数定义,三重Switch转一重,也是边写边学了。
三元表达式和去除函数定义就不说了,具体流程就看 某直聘逆向之AST处理加密代码
解混淆之后如图:

本文主要讲三重Switch转一重的具体流程:

第一个大控制流,有三层,最后一层有Switch和ifelse两种表达形式(如上图):

第二个控制流:

第二个控制流有四层。

我的逻辑是:

1.先准备好反推控制流的函数,分上面一个的和下面一个控制流的,上面那个文章也写了的,如:

function calculateP1(qbl, Ybl, $bl) { // 检查参数是否在 0-31 范围内(5位二进制最大值) if (qbl< 0 || qbl > 31) throw new Error('qbl must be between 0 and 31'); //第一层 if (Ybl < 0 || Ybl > 31) throw new Error('Ybl must be between 0 and 31');//第er层 if ($bl < 0 || $bl > 31) throw new Error('$bl must be between 0 and 31');//第san层 return ($bl << 10) | (Ybl << 5) | qbl; } function calculateP2(rp, np, ip, sp) { return (sp << 6) | (ip << 4) | (np << 2) | rp; }

2.我是直接遍历的For循环,因为代码里面也不多,随后只全部替换下面的大Switch,到第三层就能需要判断是Switch还是IFelse了。

3.随后就是判断:

if (t.isSwitchStatement(IfStatement_or_SwitchStatement)){ //是否是Switch //循环IfStatement_or_SwitchStatement然后这里push出只有三层的部分 ... if (third_caseNode.consequent[0].type!=='VariableDeclaration'){ 判断是第一个大控制流的 }else{ //这里是走第二个控制流的,是四层, //循环然后push出四层的 } }else{ let search_result=SearchIfStatement(IfStatement_or_SwitchStatement) }

4.把数组转换成Switch(在每个ForStatement内部替换):

5.然后导出js

最终效果就是

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/15 10:27:42

嵌入式-硬件基础:了解三极管

目录 一、三极管的本质&#xff1a;半导体电流控制器 1. 核心定义 2. 结构与材料 3. 两种类型&#xff1a;NPN 型 vs PNP 型 二、工作原理&#xff1a;“以小控大” 的核心逻辑 1. 导通的前提&#xff1a;正确偏置 2. 载流子的运动过程&#xff08;三步曲&#xff09; …

作者头像 李华
网站建设 2026/4/7 23:24:16

【Java方法】--让你的代码变成一个独立的“任务”——方法

个人主页 目录前言1. 什么是方法&#xff1f;为什么我们需要它&#xff1f;2. 如何定义一个Java方法&#xff1f;**代码示例&#xff1a;**3. 如何调用方法&#xff1f;**代码示例&#xff1a;**4. 拓展&#xff1a;命令行传递参数**如何使用&#xff1f;**结尾前言 想象一下&a…

作者头像 李华
网站建设 2026/4/9 10:45:21

5分钟用vue.config.js搭建开发环境原型

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 请快速生成一个可用于原型开发的vue.config.js配置&#xff0c;要求&#xff1a;1. 配置热重载 2. 设置/api代理到本地3000端口 3. 允许跨域 4. 配置ESLint自动修复 5. 添加vue-rou…

作者头像 李华
网站建设 2026/4/7 19:33:37

小白必看:什么是WiFi密码字典及其基本用法

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 创建一个交互式WiFi密码字典学习应用&#xff0c;通过简单示例演示密码字典的工作原理。要求包含基础知识讲解、简单字典生成演示和实际应用场景说明。使用HTMLJavaScript实现可视化…

作者头像 李华
网站建设 2026/4/15 9:15:05

传统调试 vs AI辅助:解决Internal Server Error的效率对比

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 构建一个对比工具&#xff0c;左侧展示传统调试步骤&#xff08;查看日志、手动排查等&#xff09;&#xff0c;右侧展示AI辅助调试流程&#xff08;自动分析、建议修复&#xff09…

作者头像 李华