Burpsuite插件开发之RSA加解密

burpsuite是一款非常好用的抓包工具,我自己也是重度用户,所以就上手了burpsuite的插件接口开发,本文主要记录了一个解密请求包,插入payload,再加密的插件开发过程,插件应用场景主要是用于通过分析apk的实现。这里做探讨的目的只是方便安全测试人员的个人学习,或大家渗透测试使用。

详细的代码见github代码,在文档中数据首先是以rsa方式加密des的key得到encryptKey,然后使用des的key加密数据包得到data,再组装成一个JSON格式串,这是加密过程,当然解密过程就是逆向的。插件应用场景主要是用于通过分析apk的实现,或者泄露的密钥,获取其加解密算法,在解密后的数据包中插入payload,发现注入问题等。

如下则是加密后的数据包:

  1. c={ 
  2.  
  3.  "data":"21BhviedgtbwK6rdlK7vzltqxOLxUmU2g5qaO5LWPYTha5fXslmL6jrMkFnJBwpZPZMNl5foxTUHw2Mae++zkWwtzWkKXI9WJ/CJqxO9uORT5I6iUmIG7bBcgnHpmlSNKfFwBvnr9vj3v5ByvW2s2/pL9rSaeD+/8XsX01NA96mC4g5pVBeU5IY9F4tdxH9yobXfN6GzEVhLeiEd30xzMA\u003d\u003d", 
  4.  
  5.  "encryptKey":"bjWZgigAW/ZaAA55v7Yi9AGt2qsP7BfZZISu70qc/xVUVfh5L/Mw/mMbzxkcZ6uXb1vvgXvF7hHYwjsVzvEkRK0rIfIwkcYzn160fvQ/8+F8YBMDLzTEhf8r0KjOLlJV+HgOsS4QG/G9lOU5mnupfrVA9sf54b3OvXHU0TQVG7U\u003d" 
  6.  
  7.  } 

从数据库包能看到大的数据是一个json格式,里面有data,和encryptKey值,encryptKey就是使用RSA加密des 的key得到的,RSA的工作方式和pem文件可通过界面设置,再接着用这个key采用des方式解密data中的内容。操作界面如下:

2、InsertPoint 接口

InsertPoint顾名思义就是注入点,就是payload插入的地方,比如request中的cookie,参数等位置。为了对一些burpsuite不支持的参数格式进行支持就必须实现该接口,可以用在Active Scanner和Intruder中.

2.1 基础开发知识

最好的方式就是在原有插件的基础上修改,这样能省很多精力,当然如果要一步一步来的话,步骤如下:

(1)包含burp的接口文件

(2)创建一个包名为burp,在里面创建BurpExtender类,实现IBurpExtender接口,这个BurpExtender类是所有接口的心脏,注意这里涉及到名字都不能改动,burp插件就这么规定的。

(3)实现唯一的接口函数

  1. public void registerExtenderCallbacks(final IBurpExtenderCallbacks callbacks) { 
  2.  
  3.         this. callbackscallbacks = callbacks ; 
  4.  
  5.        } 

通过callbacks获取核心基础库能力,像日志,请求,返回值修改等。

(4)日志接口

  1. PrintWriter stdout = new PrintWriter(callbacks.getStdout(), true); 
  2.  
  3. PrintWriter stderr = new PrintWriter(callbacks.getStderr(), true); 
  4.  
  5. //输出到插件的output 
  6.  
  7. stdout.println("Hello output"); 
  8.  
  9. // 输出到alerts tab 
  10.  
  11. callbacks.issueAlert("Hello alerts"); 
  12.  
  13. //打印调用栈 
  14.  
  15. e.printStackTrace(stderr) 

有了这些日志接口就能比较好的调试代码了,如果要很好的跟踪请求的,可以在BApp Store中添加”Custom Logger”这个插件,能够记录所有的请求和返回信息。

2.2 getInsertionPoints

下面我们就来讲讲如何实现一个InsertionPoints接口。第一步继承IScannerInsertionPointProvider接口,实现getInsertionPoints()方法,同时通过callbacks.registerScannerInsertionPointProvider(this)方法注册成为insertion point provider。下面我们就来看看getInsertionPoints()的实现。

  1.  @Override  
  2.  public List<IScannerInsertionPoint> getInsertionPoints (IHttpRequestResponse baseRequestResponse) { // 生成insertPoints数组   
  3.  List<IScannerInsertionPoint> insertionPoints = new ArrayList<IScannerInsertionPoint>(); // 获取请求参数  
  4.  IRequestInfo requestInfo = helpers.analyzeRequest(baseRequestResponse.getRequest());   
  5.  List<IParameter> requestParams = requestInfo.getParameters(); 
  6.  
  7.     for (IParameter parameter : requestParams) { 
  8.         String value = parameter.getValue(); 
  9.         value = helpers.urlDecode(value).trim(); 
  10.         EncryptBean encryptBean = new EncryptBean(); 
  11.         if (parameter.getName().trim().equals("c")){//参数中含有c参数表示要加密的内容 
  12.             encryptBean = JSON.parseObject(value, EncryptBean.class); 
  13.             stdout.println("private key: " + key.privateKey + " public key " + key.publicKey); 
  14.             try { 
  15.                 value = decryptRSAAndDES(key, encryptBean); 
  16.                 stdout.println("after decrypted:Will scan  data at parameter " + parameter + " with value decrypted " + value); 
  17.             } catch (Exception e) { 
  18.                 e.printStackTrace(stderr); 
  19.             } 
  20.             if (value.isEmpty()) continue; 
  21.  
  22.             try { 
  23.                 String basename = parameter.getName(); 
  24.                 //insertionPoints.add(new InsertionPoint(this, baseRequestResponse.getRequest(), basename, value)); 
  25.                 JSONObject jsonObj = JSON.parseObject(value); 
  26.                 String basevalue = ""
  27.                 for(Map.Entry<String, Object> entry: jsonObj.entrySet()){ 
  28.                     basename = entry.getKey(); 
  29.                     basevalue = entry.getValue().toString();                     
  30.                     //在这里传入总的value值以便在InsertionPoint进行分解,构造加密后的request请求,构造InsertionPoint时传入的value为总的value值 
  31.                     insertionPoints.add(0,new InsertionPoint(this, baseRequestResponse.getRequest(), basename, value)); 
  32.                     stdout.println("in for:Will scan AES encrypted data at parameter " + basename + " with value " + value); 
  33.                 } 
  34.             } catch(Exception e) { 
  35.             } 
  36.         } 
  37.     } 
  38.     return insertionPoints; 

这一段代码的大体意思就是通过helper.analyzeRequest方法获取所有请求信息,遍历其中的参数信息,当发现参数名等于”c”时就会调用解密过程,这块的代码需要根据参数格式自定义解析参数过程。调用解密的过程大体就是先解析JSON格式,然后解密,得到解密数据的内容后调用

  1. `new InsertionPoint(this, baseRequestResponse.getRequest(), basename, value)` 

 实例化一个注入点。一般情况下basename和value是一一对应的,如param1=phoneNum,但是这里我们basename传入param1,value值则是解密后的值如

  1. `{"userid":"51ba27cb-514d-3d86-0000-2f7515a40613","task_id":"1450147269","param1":"000000000000000","m":"https"}`, 

这么传递是为了方便实例化插入点。接着我们看下InsertionPoint的参数构造。

2.3 InsertionPoint

  1. InsertionPoint(BurpExtender newParent, byte[] baseRequest, String basename,  
  2.                 String basevalue) {  
  3.     this.parent = newParentthis.baseRequest = baseRequest; this.baseName = basename;   
  4.     //this.baseValue = basevalue;  
  5.      this.value = basevaluethis.baseValue = JSON.parseObject(basevalue).getString(basename); 

在InsertionPoint的代码中有一个很重要的接口就是buildRequest,这个函数就是用来添加payload。

  1. @Override 
  2. public byte[] buildRequest(byte[] payload) 
  3.     String payloadPlain = parent.helpers.bytesToString(payload); 
  4.     String payloadEncrypted = ""
  5.     String tmpAESKey = "0123456789abcdef"
  6.     parent.stdout.println("payloadPlain:" + payloadPlain); 
  7.     parent.callbacks.issueAlert("payloadPlain:" + payloadPlain); 
  8.     try { 
  9.         Map<String,String> map = JSON.parseObject(this.value, new TypeReference<Map<String, String>>(){}.getType()); 
  10.         map.put(this.baseName, getBaseValue() + payloadPlain ); 
  11.         String allPayloadPlain = JSON.toJSONString(map); 
  12.         payloadEncrypted = parent.encryptRSAAndDES(allPayloadPlain, tmpAESKey, parent.key); 
  13.     } catch(Exception e) { 
  14.         parent.callbacks.issueAlert(e.toString()); 
  15.     } 
  16.     parent.stdout.println("Inserting " + payloadPlain + " [" + payloadEncrypted + "] in parameter " + baseName); 
  17.     // TODO: Only URL parameters, must change to support POST parameters, cookies, etc. 
  18.     //"c" 解密数据格式包一致 
  19.     return parent.helpers.updateParameter(baseRequest, parent.helpers.buildParameter("c", payloadEncrypted, IParameter.PARAM_BODY)); 

这段代码就是获取payload,然后嵌入到解密后的请求包,然后将请求加密,最后调用updateParameter更新参数信息。在这里要注意parent.helpers.buildParameter(“c”, payloadEncrypted, IParameter.PARAM_BODY) c是body中的请求参数,和我们的数据格式对应,IParameter.PARAM_BODY这个参数则表明是Body中的请求参数,如果是URl中的则是PARAM_URL

2.4 接口关系

知道了上述接口的作用,感觉还糊里糊涂的。那就是这些接口是怎么串起来的,数据包是如何流动的,下面我们来看下active scanning的流程。

ActiveScanner引擎从InsertionPoints Provider获取Insertion Points,然后调用BuildRequest发送Request,Requst再经过HttpListener的处理到达webServer。

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

(0)
运维的头像运维
上一篇2025-03-09 04:57
下一篇 2025-03-09 04:58

相关推荐

  • 个人主题怎么制作?

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

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

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

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

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

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

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

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

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

    2025-11-20
    0

发表回复

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