自动收集webpack调用模块

自动收集webpack调用模块

之前的文章介绍过JS逆向中处理webpack的通用方法。那篇文章中是将所需模块所在的JS文件整个拷贝到本地来了。往往这些文件巨大而且不止一个,但是其实我们只需要其中的某些模块。有没有办法自动获取到所有需要的模块而不用拷贝整个JS文件嘛?答案是有的。

加断点

找到源代码中加载我们所需模块的位置,这里为21725模块,在此位置和下一行代码位置加上断点。

进入加载器内部在第一行加上一句无效代码并在此处加上断点

收集模块

刷新页面,将代码执行先经过21725模块然后再到加载器的断点处,此时我们需要几个步骤

  1. 清空模块缓存变量d
  2. 创建一个接收所需模块的变量sss
  3. 在加载器内部断点的下一行增加条件断点,断点条件为sss[e]=f[e], 0,这是一个逗号表达式,条件结果永远为false也就是断点不会停,但是会执行语句sss[e]=f[e],将模块塞入到对象sss中
  1. 继续执行代码直到断点停在加载21725模块代码的下一行代码处
  2. 此时在控制台执行语句,控制台就会打印出加载21725模块所需的所有模块
javascript 复制代码
const pairs = Object.keys(sss).map(key => {
  return `"${key}":${sss[key].toString()}`;
});const result = `{${pairs.join(',')}}`;console.log(result);

注意

收集模块时涉及到的模块缓存变量r、获取模块的f、模块的名称e,可能是随机生成的,不能直接套用我例子中的代码。

相关推荐
热心市民老八3 天前
010editor 最新版破解
逆向·reverse
嫂子的姐夫5 天前
010-sha1+base64:爬虫练习网站
爬虫·python·逆向
嫂子的姐夫5 天前
012-AES加解密:某勾网(参数data和响应密文)
javascript·爬虫·python·逆向·加密算法
嫂子的姐夫5 天前
011-AES:深证信
爬虫·python·逆向
嫂子的姐夫5 天前
013-webpack:新东方
爬虫·python·webpack·node.js·逆向
极客小云6 天前
【Rokid AR录屏功能逆向分析:通过蓝牙HCI抓包实现CXR SDK未提供的AR录屏功能】
ar·逆向·vr眼镜·rokid·rokid glasses
介一安全6 天前
Android 安全加固工具 dpt-shell
android·安全·网络安全·逆向
360安全应急响应中心13 天前
iOS安全开发中的Frida检测
安全·逆向
介一安全17 天前
【Frida Android】实战篇18:Frida检测与绕过——基于内核指令的攻防实战
android·网络安全·逆向·安全性测试·frida
介一安全20 天前
【Frida Android】实战篇17:Frida检测与绕过——基于inline hook的攻防实战
android·网络安全·逆向·安全性测试·frida