AST反混淆js代码——猿人学竞赛第二题

news2024/9/25 23:22:34

猿人学JS比赛第二题解混淆

  • 分析代码
  • 解混淆代码
  • 结果

前一段时间参加猿人学js比赛,今天把第二题的还原做一下笔记。

在这里插入图片描述

分析代码

首先,我们需要对混淆js代码进行分析,确定还原的思路,才能书写解混淆代码进行还原。代码是静态的,不会变的,我们去网站上将混淆代码拿下来看看:

在这里插入图片描述

可以看到,混淆的js代码有三万多行,从一些特征看来是类ob混淆的代码。包含大数组,移位函数等等特征;

在这里插入图片描述

其次,混淆代码内部有一些大对象和switch控制流代码:

在这里插入图片描述

对象内部含有很多属性,在混淆代码中,对象属性值(字符串和函数)被使用。

在这里插入图片描述
到此为止,混淆代码的特征基本上就分析完了。下面就是要还原代码了。

解混淆代码

首先,将大数组内的数据进行还原,这里需要先找到解密函数是哪个?通过分析发现_0xf75e函数是解密函数:
在这里插入图片描述

通过分析代码,我们可以发现,该解密函数并没有直接被调用。而是在别的函数内部被调用,同时存在多层调用。
在这里插入图片描述

在混淆代码内部,实际被调用的代码如下;那么,我们想要还原大数组,也就需要拿到这些函数;拿到这些函数之后,我们就可以对大数组进行还原了

在这里插入图片描述

这里还原后,效果如下:

在这里插入图片描述

可以看到函数调用已经被还原为字符串了。

那么接下来,我们可以先处理一下以下代码:对其进行计算,得到结果。

"1|2|0|3|4|" + "6|5"
3235 + -1 * -6197 + -9432

对其进行计算,得到结果。
接下来,通过分析代码,我们可以发现代码中存在大量关于对象属性的使用:

在这里插入图片描述

这里我们需要对其还原,通过观察对象,我们可以发现,对象属性里包含字符串和函数两种值:

在这里插入图片描述
这里字符串我们可以直接将其还原,函数调用我们需要判断其具体的类型,做进一步处理:还原后部分带代码如下,:

在这里插入图片描述

最后,就需要处理switch语句了:

![![在这里插入图片描述](https://img-blog.csdnimg.cn/9caade5ac7bb41a3bf9f915dc4815d4c.png](https://img-blog.csdnimg.cn/572edc0174e249f697f1d518267c7f2e.png

通过观察代码,我们可以发现,switch语句在一个循环内部,同时根据_0x726bea[_0x370538++]进行条件分支选择,那么我们就可以拿到其遍历的值的顺序,将switch语句进行改写:

还原后结果如下:
在这里插入图片描述
到此,基本上已经还原的差不多了,此时再去分析js代码,找到加密参数位置就是轻而易举了。
直接搜索关键字即可;加密关键位置如下:
在这里插入图片描述

到这里,再去扣代码就很简单了,这里就不说了。里面有一些小检测,过掉即可。
在这里插入图片描述

结果

最后展示一下用python代码请求拿到的结果:
在这里插入图片描述

在这里插入图片描述

本文完整分析就到这里。完整AST代码就不放在这里了,有需要的请联系我。
如果你有需要解混淆的代码,也可以联系我。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/638103.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

KYOCERA Programming Contest 2023(AtCoder Beginner Contest 305)(A、B、C、D)[施工中]

文章目录 A - Water Station(模拟)B - ABCDEFG(模拟)C - Snuke the Cookie Picker(模拟、暴力)D - Sleep Log(二分,前缀) A - Water Station(模拟) 题意:在[0,100]所有 x % 5 0的地方设置一个水站&#x…

由源码生成Python可调用的dll

1. 不带参数的函数与调用 blog.csdn.net/qq 40833391/article/details/128000638python编程(python调用dll程序)_python 调用dll_嵌入式-老费的博客-CSDN博客思路很简单,只需要在Visual Studio中设置输出类型即可 1.1. 创建项目 首先创建一…

【HashMap集合】存储学生对象并遍历

HashMap集合存储学生对象并遍历 1.键是String,值是Student 需求:创建一个HashMap集合,键是学号(String),值是学生对象(Student)。存储三个键值对元素,并遍历 思路: 定义学生类 创建HashMap集合对象 创建…

uni.navigateBack()返回上一页携带参数的实现

a页面跳转b页面,再b页面点击确定返回到a页面刷新列表 //b页面confirm(){let pages getCurrentPages();//当前页面let prevPage pages[pages.length - 2];//上一个页面prevPage.setData({//直接给上一个页面赋值isRefresh: true})uni.navigateBack();} 返回到a页面…

适用于 Linux 的 Windows 子系统wsl文档

参考链接:https://learn.microsoft.com/zh-cn/windows/wsl/ 鸟哥的Linux私房菜:http://cn.linux.vbird.org/ http://cn.linux.vbird.org/linux_basic/linux_basic.php http://cn.linux.vbird.org/linux_server/ 目录 安装列出可用的 Linux 发行版列出已…

【Protobuf】Map类型的使用

文章目录 2.4 map 类型一、 基本认识二、map相关函数4.3 contact2.4的改写 2.4 map 类型 本系列文章将通过对通讯录项目的不断完善,带大家由浅入深的学习Protobuf的使用。这是Contacts的2.4版本,在这篇文章中将带大家学习Protobuf的 map 语法&#xff0c…

STM32F407软件模拟I2C实现MPU6050通讯(CUBEIDE)

STM32F407软件模拟I2C实现MPU6050通讯(CUBEIDE) 文章目录 STM32F407软件模拟I2C实现MPU6050通讯(CUBEIDE)模拟I2C读写的实现mpu6050_iic.cmpu6050_iic.h代码分析 复位,读取温度,角度等函数封装mpu6050.cmpu…

HTTPS 原理浅析及其在 Android 中的使用

1.HTTP协议的不足 HTTP1.x在传输数据时,所有传输的内容都是明文,客户端和服务器端都无法验证对方的身份,存在的问题如下: 通信使用明文(不加密),内容可能会被窃听;不验证通信方的身份,有可能遭…

Hbase-- 03

4.原理加强 4.1数据存储 4.1.1行式存储 传统的行式数据库将一个个完整的数据行存储在数据页中 4.1.2列式存储 列式数据库是将同一个数据列的各个值存放在一起 传统行式数据库的特性如下: ①数据是按行存储的。 ②没有索引的查询使用大量I/O。比如一般的数据库表…

vue3 element-plus后台管理系统实现登录与记住密码功能

一、效果 二、代码部分 1、勾选记住密码布局代码 2、判断是否勾选,勾选则保存账号密码,否则不保存账号密码,由于是demo,故并没有做加密,如果是生成最好是对密码做加密处理。 3、页面挂载的时候需要背叛的是否保存密码,…

JDK8 ConcurrentHashMap 怎么放弃 Lock 使用 synchronized 了

synchronized 之前一直都是重量级锁,但是 JDK6 中官方是对他进行过升级,引入了偏向锁,轻量级锁,重量级锁,现在采用的是锁升级的方式去做的。针对synchronized 获取锁的方式,JVM 使用了锁升级的优化方式&…

十行代码,就能真正让你理解DMA(CPU的秘书)

下面的代码是单片机串口发送数据的程序. char a0xAA;//定义变量a,值为0xAA; TXREG a;//把数据由内存转移到串口外设;那我们定义的变量a的值存储在哪里了呢?可以看下单片机的逻辑框图。 变量其实都是存在一个叫SRAM的存储器中,它…

Playwright 和 Selenium 的区别是什么?

前言 最近有不少同学问到 Playwright 和 Selenium 的区别是什么?有同学可能之前学过 selenium 了,再学一个 playwright 感觉有些多余,可能之前有项目已经是 selenium 写的了,换成 playwright 需要时间成本,并且可能有…

【支付系统】核心支付流程

支付在产品中常见的用处为购买和充值.这两种功能操作大相径庭,其中购买相对充值多了很多步骤,它需要锁商品或者库存,还需要超时未支付取消订单等操作.在这篇文章中主要探讨支付部分,属于购买和充值公共部分. 下面是绘制的简易支付时序图 以上时序图并非完整,其实核心步骤就是, …

商城购买会员打折满减优惠券商品

文章目录 前言一、代码结构二、UML图三、代码实现3.1.domain3.2.enums3.3.strategy3.4.service3.5.config 四、单元测试五、模式应用六、问题及优化思路6.1.问题6.2.优化 总结 前言 使用策略模式、工厂方法模式、单例模式实现一些购买策略,需求:商城商品…

服装库存管理系统 Mybatis+Layui+MVC+JSP【完整功能介绍+实现详情+源码】

完整源码资料 地址直达:http://t.csdn.cn/RWsGw 前言 这是大二时候写的第一个Java项目,框架基本上都没有用到、而且用到的技术很老很老。只简单使用了一个Mybatis简化数据库的操作。前端框架用的还是Layui,贼难用。闲的无聊,对这…

缺少成本票怎么解决?首选自然人代开,方便又快捷!

《税筹顾问》专注于园区招商,您的贴身节税小能手,合理合规节税! 成本票缺失导致的严重结果就是,缺少成本入账,导致利润虚高,企业所得税变高了,那么现有的解决方式很多,只是一些方法过…

图形学实验(完整文件见上传)

CRect rect; this->GetClientRect(rect); pDC->Ellipse(rect); // DDALineView.cpp : implementation of the CDDALineView class // #include “stdafx.h” #include “DDALine.h” #include “DDALineDoc.h” #include “DDALineView.h” #ifdef _DEBUG #define new…

Qt扫盲-QEvent 理论总结

QEvent 理论总结 一、概述二、事件类型1. Qt 已定义类型2. 开放用户定义类型 三、注册事件 一、概述 Qt的主事件循环(QCoreApplication::exec())从事件队列中获取原生窗口系统事件,将它们转换为QEvents,并将转换后的事件发送给QObjects。 一般来说&…

Multimodal fusion via cortical network inspired losses(第一次优质论文分享)

Multimodal fusion via cortical network inspired losses 论文介绍1. 论文研究的任务是什么?2. 论文关注/拟解决的问题是什么?3. 论文提出什么方法如何解决这个问题?4. 如何设计实验 来证明 所提方法确实解决了 拟解决的问题? 论…