JSPrime:基于JavaScript DOM XSS检测的轻量级代码审计工具

如今,随着前端技术人才需求的不断增加,越来越多的开发者逐渐将JavaScript作为其开发语言的第一选择。

目前无论是在传统PC Web平台还是移动终端平台上,在客户端侧或者服务端侧,JavaScript均有不俗的性能体现及丰富的框架支持,所以其作为一个主流开发语言也逐渐被广泛认可接受。同时,JavaScript 也因其解释器性能上的优势,可为企业解决可扩展性和吞吐量等瓶颈问题。所以JavaScript当前来说是一种重要的、强大的开发语言,它的使用者也是日益增多。

但目前的问题是,随着越来越多的JS库的出现及许多开发者在以功能实现为导向时,有时候会出现不安全编码,而这也导致了许多客户端侧攻击事件出现,其中特别是DOM XSS最为普遍。在开发这个工具之前,我们试图分析代码中引起DOM XSS攻击的触发点,但苦于没有足够有效的工具来分析解决问题。因此我们开始尝试开发工具来分析解决代码层面中的问题,到这里我们将这款基于DOM XSS攻击的代码审计工具JSPrime定义为:一款JavaScript静态分析工具,可进行代码审计,且其是一款轻量级且极易上手的点击式工具!其中,静态分析功能模块是基于当前非常流行的Esprima ECMAScript语法进行解析的。

下载地址

JSPrime GitHub下载地址:jsprime

JSPrime主要功能点

1、支持定位分析JS框架或库的Source以及Sinks;

2、许多动态或者静态分析工具的开发往往只支持纯JavaScript语法及功能,可这对于大部分开发者来说这是个问题,因为开发过程中,通常会使用一些JavaScript框架或者库,像jQuery, YUI等等。因为这些扫描器被设计用以支持纯JavaScript语法检测,其在理解开发代码内容方面较为不成熟,容易产生误报。所以为解决这个问题,JSPrime是基于jQuery和YUI等框架,对用户的存在危险性质的输入来源source及代码执行sink输入函数进行检测分析。以下为部分Source以及Sinks的具体信息,详细可查看:Source&Sinks

 

 

3、变量及函数追踪定位;

4、变量及函数范围界限分析;

5、识别已知过滤函数;

6、面向对象(OOP)分析及原形代码设计合规;

7、最小误报率告警;

8、支持Minified.js库(该库目前功能包括DOM操作,事件,动画,cookies和HTTP请求);

9、快速分析检索能力;

10、点击式操作(工具无需各种复杂操作,容易上手)。

安装操作步骤

1、Web端操作

在浏览器中打开“index.html”。

2、服务端操作

(1)若无安装Node.js,请先前往:node.js中文网官网下载;

(2)完成第一步后,于终端中打开此前从GitHub下载的文件中的server.js ,具体命令如下,

node server.js

(3)在服务端开启之后,于浏览器上输入:127.0.0.1:8888。

DOM XSS分析测试用例

关于DOM XSS漏洞测试用例如下(这里只存放前五个测试用例),详细测试用例(共61个)请参考:百度网盘,提取码为6qfd。

  1. ---------------TEST CASE 01-------------   
  2.  
  3. var param = location.hash.split("#")[1];  
  4.  
  5. document.write("Hello " + param + "!"); 
  1. ---------------TEST CASE 02-------------   
  2.  
  3. function timedMsg(callback){  
  4.  
  5. if(callback){  
  6.  
  7. var t=setTimeout(eval('callback'),3000);  
  8.  
  9. return 0;  
  10.  
  11. }}  
  12.  
  13. function fire(){  
  14.  
  15. var call = location.hash.split("#")[1];  
  16.  
  17. timedMsg(call);  
  18.  
  1. ---------------TEST CASE 03------------   
  2.  
  3. function timedMsg(callback){  
  4. if(callback){  
  5. var t=setTimeout(eval('callback'),3000);  
  6. return 0;  
  7. }}  
  8. function fire(){  
  9. var call = location.hash.split("#")[1];  
  10. var check=timedMsg;  
  11. check(call);  
  1. ---------------TEST CASE 04------------    
  2. function timedMsg(abc,callback){  
  3. if(callback){  
  4. var t=setTimeout(eval('callback'),3000);  
  5. return 0;  
  6. }}  
  7. function fire(){  
  8. var call = location.hash.split("#")[1];  
  9. timedMsg(12,"call");  
  1. ---------------TEST CASE 05------------    
  2. function timedMsg(abc,callback){  
  3. if(callback){  
  4. var t=setTimeout(eval('callback'),3000);  
  5. return 0;  
  6. }}  
  7. function fire(){  
  8. var call = location.hash.split("#")[1];  
  9. var check=timedMsg;  
  10. check("123",call);  

相关功能测试截图

前端界面如下,

 

 

分析结果如下,

  

服务器侧界面及分析如下,

 

 

 【编辑推荐】

  1. php漏洞与代码审计
  2. php安全代码审计小结
  3. Python安全编码与代码审计
  4. Jsprime——一款JavaScript静态安全分析工具

 

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/134104.html<

(0)
运维的头像运维
上一篇2025-03-01 00:15
下一篇 2025-03-01 00:16

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注