【BurpSuite】插件开发学习之dotnet-Beautifier

【BurpSuite】插件开发学习之dotnet-Beautifier

前言

插件开发学习第3套。前置文章:

【BurpSuite】插件学习之Log4shell
【BurpSuite】插件学习之Software Vulnerability Scanner

dotnet-Beautifier

https://github.com/PortSwigger/dotnet-beautifier.git
逻辑代码在

|____src
| |____burp
| | |____DotNetBeautifierTab.java
| | |____BurpExtender.java

IMessageEditorTab

继承的是IMessageEditorTab

public class DotNetBeautifierTab implements IMessageEditorTab 

在这里插入图片描述

getTabCaption()

返回自定义选项卡上显示的标题

@Override
    public String getTabCaption() {
        return "Beautify.NET";
    }

效果
在这里插入图片描述

isEnabled()

什么时候会展示,什么时候会隐藏

@Override
    public boolean isEnabled(byte[] content, boolean isRequest) {
        if (isRequest) {
            IRequestInfo requestInfo = helpers.analyzeRequest(content);
            for (IParameter parameter : requestInfo.getParameters()) {
                if (helpers.urlDecode(parameter.getName()).contains("$"))
                    return true;
            }
        }
        return false;
    }

setMessage()

用新的content去替换旧的

public void setMessage(byte[] content, boolean isRequest) {
        messageEditor.setMessage(beautifyContent(content), isRequest);
    }

核心的就是

if (parameterName.contains("$")) {
                String[] fragments = parameterName.split("\\$");
                simplifiedParameterName = fragments[fragments.length - 1];
            } else if (parameterName.matches("^__(VIEWSTATE|PREVIOUSPAGE|EVENTVALIDATION)$")
                    && parameter.getValue().length() != 0) {
                simplifiedParameterName = parameterName;
                parameterValue = "<snipped>";
            } else {
                continue;
            }

判断是否有$,或参数名匹配了^__(VIEWSTATE|PREVIOUSPAGE|EVENTVALIDATION)$
然后remove旧的,保存新的

newContent = helpers.removeParameter(newContent, parameter);
            newContent = helpers.addParameter(
                    newContent,
                    helpers.buildParameter(
                            helpers.urlEncode(simplifiedParameterName),
                            (parameterValue != null)?parameterValue:parameter.getValue(),
                            parameter.getType()
                    )
            );

nameTracker

缓存队列,每次set之前吧目标参数保存到这个里面

优化

仔细想想,其实Proxy Options里面是有Match and Replace的功能
在这里插入图片描述
完全可以实现这个插件的功能。
但是插件的实现方式可以学习,应用方向可以放在replace不太好做的地方。优化方向可以是:编码(base64、UTF8<->GBK、RSA爆破)

优化代码

还没写

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值