扫码关注我们
JSPanda扫描客户端原型污染漏洞

关于JSPanda

JSPanda是一个功能强大的客户端原型污染漏洞扫描工具,它污染从源代码中收集的所有单词,并将它们显示在屏幕上。因此,它可能产生假阳性结果。这些输出为研究人员提供了额外的安全分析信息,并不是完全自动化的。

注意:当前版本的JSPanda还没有检测高级原型污染漏洞的能力。

JSPanda运行机制

  • 使用了多种针对原型污染漏洞的Payload;

  • 可以收集目标项目中的所有链接,并对其进行扫描,然后添加Payload至JSPanda所获取到的URL中,并使用无头Chromedriver导航至每一条URL链接;

  • 扫描目标JavaScript库源代码中潜在易受攻击的所有单词,JSPanda可以扫描目标项目中的脚本工具,并创建一个简单的JS  PoC代码,以帮助广大研究人员对目标代码执行手动扫描;

工具要求

  • 下载并安装最新版本的Google Chrome浏览器以及Chromedriver驱动程序;

  • Selenium

工具下载

广大研究人员可以使用下列命令将该项目源码克隆至本地:

git clone https://github.com/RedSection/jspanda.git

工具运行

(1) 执行扫描

首先,我们需要将目标项目的URL地址添加进JSPanda的url.txt文件中,比如说“example.com”。添加完成后,我们就可以运行下列命令来执行扫描了:

python3.7 jspanda.py

(2) 基础源代码分析

首先,我们需要将一个JavaScript库的源代码添加至analyze.js中,然后使用analyze.py文件来生成PoC代码。

接下来,在Chrome浏览器的命令行终端窗口中执行我们刚才生成的PoC代码。它将会对从源代码中收集到的所有单词进行污染操作,并将结果显示在控制台窗口中。这个过程有可能会产生假阳性结果。这些输出信息仅为研究人员提供额外的安全分析信息,其目的并非实现完全的自动化操作。

运行命令如下:

python3.7 analyze.py