渗透测试工具Burp Suite详解

2023-10-27

Burp Suite 的安装

  • Burp Suite是一款集成化的渗透测试工具,包含了很多功能,可以帮助我们高效地完成对Web应用程序的渗透测试和攻击。

  • Burp Suite由Java语言编写,基于Java自身的跨平台性,使这款软件学习和使用起来更方便。Burp Suite不像其他自动化测试工具,它需要手工配置一些参数,触发一些自动化流程,然后才会开始工作。

  • Burp Suite可执行程序是Java文件类型的jar文件,免费版可以从官网下载。免费版的Burp Suite会有许多限制,无法使用很多高级工具,如果想使用更多的高级功能,需要付费购买专业版。专业版与免费版的主要区别有以下三点。

    • Burp Scanner
    • 工作空间的保存和恢复
    • 拓展工具,如Target Analyzer、Content Discovery和Task Scheduler

burp suite就是一个抓包、改包工具

Burp的安装一共分为三步:
1、java的安装
2、环境变量的配置
3、运行burp

burp的安装与基本使用

java环境

从java官网进行下载:搜索java jdk
安装完成之后,配置环境变量:将C:\Program Files\Java\jdk1.8.0_201复制到
在这里插入图片描述
点击确定

然后打开bin目录,再将目录C:\Program Files\Java\jdk1.8.0_201\bin复制到
在这里插入图片描述
点击确定

现在可以用cmd指令输入javac输入java也可以
在这里插入图片描述
出现如图情况,说明环境变量配置成功。

下载burp

下载地址:https://portswigger.net/burp
在这里插入图片描述
在这里插入图片描述
我这里安装的是exe文件
在这里插入图片描述
双击安装,一直next——》finish
在这里插入图片描述
打开——》I accept——》弹框选delete——》next——》start burp

在这里插入图片描述
免费版本没有Scanner

Burp Suite入门

设置代理

      burp suite代理工具是以拦截代理的方式,拦截所有通过代理的网络流量,如客户端的请求数据、服务端的返回信息等。burp suite主要拦截HTTP和HTTPS 写协议的流量,通过拦截,burp以中间人的方式对客户端的请求数据、服务端的返回信息做各种处理,以达到安全测试的目的。
      在日常工作中,最常用的web客户端就是web浏览器,我们可以通过设置代理信息,拦截web浏览器的流量,并对经过burp代理的流量数据进行处理。burp运行之后,Burp Proxy默认本地代理端口为8080。如图:
在这里插入图片描述

HTTP的代理

以Firedox浏览器为例:
打开菜单——》选项——》网络代理——》设置——》手动配置代理
127.0.0.1端口是8080
在这里插入图片描述
设置浏览器的代理信息
如上图所示,设置HTTP代理为127.0.0.1,端口为8080,与burp Proxy中的代理一致
端口在0~65535之间设置
手动代理:代理到本机,因为想让浏览器通过本机把流量发送到这个端口,再由burp监听到,把包拦下来(端口的选择要和burp一样)
HTTP代理(因为抓的是http的包)

设置完后,burp就可以抓包了。
重新打开:
在这里插入图片描述
SSL看做HTTPS就行了

HTTPS的代理

我们要怎么做才能抓HTTPS的包呢?
在这里插入图片描述
如果要抓HTTP的包要用HTTP代理
如果要抓HTTPS的包,要用HTTPS代理(SSL proxy)
HTTP默认走的是80端口,HTTPS走的是443端口。两者端口不一样,要代理HTTPS就一定要用SSL去代理

设置完代理就可以了吗?不行
HTTPS(S表示security),多添加了一套SSL层(在TCP和HTTP中间),作加密的。
burp suite有一个证书:http://burp/(输入的是http,所以一定要代理http 才可以访问http的网站,代理的是https就可以访问https的网站)
在这里插入图片描述
安装证书后就可以解密百度传回的数据
在这里插入图片描述
导入刚刚下载的证书
在这里插入图片描述
这个证书的名字叫PortSwigger CA
导入后弹出的弹框(选第一个也行,都选中也行)
导入这个证书就可以解密https协议里面的乱码数据了

现在抓一个百度的包吧!
在这里插入图片描述
若只设置了SSL proxy,能不能抓http是包?不能
因为没有代理http的,只代理了https的,SSL就理解为HTTPS,所有要抓http,要设置https代理。

总结:抓https的包
抓https就代理ssl,抓http就代理http
抓https还需要导入证书
代理是代理,导入证书是导入证书,代理一定要代理ssl,导入证书是为了通过https返回来的数据可以解密(证书是解密的,SSL是代理的)

Proxy(代理)

Burp Proxy的拦截功能主要由intercept(intercept拦截/截夺)选项卡中的Forward、Drop、Interception is on/off和Action构成,他们的功能如下所示。

  • Forward(放包)表示将拦截的数据表或修改后的数据包发送至服务器端。

  • Drop(废包)表示丢弃当前拦截的数据包

  • Interception is on(拦截请求)表示开启拦截功能,单击后变为interception is off(拦截禁用),表示关闭拦截功能

  • 单击Action(行动)按钮,可以将数据包进一步发送到Spider、scanner、Repeater、Intruder等功能组件做进一步测试,同时也包含改变数据包请求方式及其body的编码功能。(发送到其他功能组件)

打开浏览器,输入需要访问的URL并按回车键,这时将看到数据流量经过Burp Proxy并暂停,直到单击Foreword按钮,才会继续传输下去。如果单击了Drop按钮,这次通过的数据将丢失,不再继续处理。
在这里插入图片描述
当Burp Suite拦截的客户端和服务器交互之后,我们可以在Burp Suite的消息分析选项中查看这次请求的实体内容、消息头、请求参数等信息。Burp有四种消息类型显示数据包:Raw、Params、Headers和Hex。

  • Raw主要显示web请求的raw格式,以纯文本的形式显示数据包,包含请求地址、Http协议版本、主机头、浏览器信息、Accept可接受的内容类型、字符集、编码方式、cookie等,可以通过手动修改这些信息,对服务器端进行渗透测试。(Raw就是以文本的形式显示数据包

  • Params主要显示客户端请求的参数信息,包括GET或者POST请求的参数、cookie参数。可以通过修改这些请求参数完成对服务器端的渗透测试。

  • Headers中显示的是数据包中的头信息,以名称、值的形式显示数据包。

  • Hex对应的是Raw中信息的二进制内容,可以通过Hex编辑器对请求的内容进行修改,在进行00截断时非常好用。

target

在这里插入图片描述
在这里插入图片描述
filter过滤

Spider

Spider的蜘蛛爬行功能可以帮助我们了解系统的机构,其中Spider爬取到的内容将在Target中展示

Decoder

Decoder的功能比较简单,它是Burp中自带的编码解码及散列转换的工具,能对原始数据进行各种编码格式和散列的转换。

Repeater

可以重复的发一个包

API就是写插件用的东西

在repeater里面的数据都可以相互转发的

Extender(插件扩展/扩展程序)

BApp Store是官方插件,需要专业版才可以install

Intruder(暴力破解)

将刚刚repeater的内容发送到intruder
在这里插入图片描述
上图可知:它攻击的目标是百度,端口是443,使用的是HTTPS
在这里插入图片描述
把美元$清除了
比如想遍历一下百度的目录
在这里插入图片描述
在这里插入图片描述

攻击方式

sniper

payload里面有三个重要的模块
在这里插入图片描述
上面添加的11和22有什么效果呢?
11和22会在GET /11 GET /22

start attack一下:
在这里插入图片描述
在这里插入图片描述

Battering ram

在这里插入图片描述
在这里插入图片描述

Pitchfork

选择pitch攻击方式,payloads里面就有两个payload(因为选择了两个地方要变化,如下图)
多个标记需要用不同的字典去替换
在这里插入图片描述
在这里插入图片描述

如果有三个地方要变,就是三个payload了

将第二个payload设为33和44
在这里插入图片描述
在这里插入图片描述

Cluster bomb

希望是11的时候,第二个变量
在这里插入图片描述
相当于所有的排列组合

intruder主要就是做暴力破解的,还有一个点比较重要,就是payload processing:
比如GET的值是一个MD5,提交上去必须用明文的MD5
这里要显示11和22的MD5怎么做呢?
把payload处理成MD5(Payload Processing——》Hash——》MD5)
在这里插入图片描述
点击stack,下图中上面一行就是11的MD5:
在这里插入图片描述

intruder–options中的Grep-Match★

Grep-Match:
当我们用所有字典中的内容去对数据包中的动态变量去进行替换的时候,如何判断哪个请求是撞成功了?
这时候就要用到grep-match这个功能了
比如:当我们登录失败的时候会提示我们username or password is not exists~
在这里插入图片描述
反过来说,当我们输入一个正确是用户名密码肯定不会提示username or password is not exists~
那我们就可以把这个提示的内容作为一个区分,来让burpsuite去查找,哪些请求的响应里面没有提示——》就意味着那个请求是正确的请求
在这里插入图片描述

也就是我们可以把所有响应的数据表里面包含的字符串的内容flag出来,那反过来说,没有被flag的数据包就是撞成功的数据包

介绍一个代理插件Switchy Omega

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

渗透测试工具Burp Suite详解 的相关文章

  • C语言实现扫雷【超详细讲解】

    目录 一 实现扫雷的基本思路 二 代码实现的具体步骤 三 完整代码 1 saolei h部分 2 saolei c部分 3 test c部分 扫雷和三子棋有很多相似的地方 相信大家认真学习完三子棋再将本篇博客认真学习完 会很好的掌握相关的知
  • 缠论是一种交易方法炒股是不是一定要学习缠论(利用缠论如何选股)

    纠缠论是一种交易方法 有必要学习纠缠论吗 1 复杂的数学思维 思考不仅对投机很重要 对股票交易也很重要 这是一项重要的人类能力 缜密的思考和清晰的表达是做好任何事情的前提 这里的数学思维是指我们高中时做的几何题 假设条件a 条件b 证明结论
  • matlab 聚类

    原网址 http blog sina com cn s blog 62f3c4ef01014wz1 html cited from cited from http hi baidu com coralliu blog item dbde03
  • 学好诊脉 破解难症

    from 老中医 LaoZY cn 学好诊脉 破解难症 中国中医药报 2009年9月24日 高允旺 山西临汾永旺脑病医院 很多乡村或基层医生学中医往往是自学或跟师学习 在学习中 脉诊是非常不好掌握的 但是脉诊确实又非常重要 笔者在临证40年
  • C++11并发——多线程lock_gurad ,unique_lock (三)

    http www cnblogs com haippy p 3346477 html struct defer lock t 该类型的常量对象 defer lock defer lock 是一个常量对象 std lock guard 介绍
  • cannot call getWriter() after getOutputStream()

    cannot call getWriter after getOutputStream 在项目里的一个导出EXCEL方法总是报错 报错内容为 cannot call getWriter after getOutputStream 字面意思很
  • 简单动态字符串

    Sds Simple Dynamic String 简单动态字符串 是 Redis 底层所使用的字符串表示 几乎所有的 Redis 模块中都用了 sds 常规字符串 在 C 语言中 字符串可以用一个 0 结尾的 char 数组来表示 比如说
  • 华为OD机试 -猴子爬山(Java)

    题目描述 一天一只顽猴想要从山脚爬到山顶 途中经过一个有n个台阶的阶梯 但是这个猴子有个习惯 每一次只跳1步或3步 试问 猴子通过这个阶梯有多少种不同的跳跃方式 输入描述 输入只有一个数n 0 lt n lt 50 代表此阶梯有多个台阶 输
  • Host与SSD交互步骤以及head,tail获取

    一 步骤 1 主机HOST组64Byte的SQE到SQ copy到host内存的SQ中 具体位置由Tail来决定 2 Host写SQ的DB 写的内容是Tail值 通知SSD取命令 register中的位置代表哪个Queue的DB 3 SSD
  • 放开那三国3服务器维护,放开那三国3上不去怎么办 放开那三国3服务器维护登陆方法...

    放开那三国3作为放开那三国系列的最新续作 一经推出自然吸引了不少新手玩家的目光 不过一些小伙伴在下载了游戏之后发现 放开那三国3服务器维护怎么办 下面18183小编就为就来分享一下进不了游戏的解决方法 快一起看看吧 对于服务器维护这一问题
  • 教你解决禁止F12、调试Debugger、丑化JS等反爬

    1 前言 在爬取数据时 有一些网站设置了反爬 禁止F12 网页调试Debugger 丑化Js 比如下面这几种情况 1 禁止查看源代码 2 网页调试Debugger 上面禁止查看网页问题 可以先按F12 再访问网站 但是又有网页调试Debug

随机推荐

  • spi 协议硬件分析以及在linux上的实现分析

    Spi几种模式 模式0 CPOL 0 CPHA 0 模式1 CPOL 0 CPHA 1 模式2 CPOL 1 CPHA 0 模式3 CPOL 1 CPHA 1 现在看看3模式 1 CLK空闲的时候为高电平 CPOL 1 2 在第二个边沿采样
  • 力扣(LeetCode)795. 区间子数组个数(C++)

    模拟 有一种构想 只考虑上边界 在小边界和大边界之间的连续子数组个数 小于等于大边界的连续子数组个数 小于小边界的连续子数组个数 连续子数组个数计算公式
  • 人民日报发文祝贺,这位作者是藏不住了!

    近日 人民日报特地发文祝贺一位90后短视频博主任大学副教授 这是哪位短视频博主这么有排面 竟然被人民日报专门发文祝贺呢 她就是短视频科普 弦论 走红的周思益 同时也是 弦论小女孩的相对论课 一书的作者 周思益是一位90后女生 短头发 娃娃脸
  • vue:图书管理系统的实现以及vue的补充(五)

    1 图书管理系统 需求 图书添加功能 图书删除功能 图书搜索功能 实现 在搜索中输入关键字 会将结果显示在table表单中 点击添加可以将图书信息添加到table表单中 点击删除 可以从表单中删除数据 详细代码
  • 谷歌周彦祺:LLM浪潮中的女性科学家多面手丨智源大会嘉宾风采

    导读 大模型研发竞赛如火如荼 谷歌紧随OpenAI其后推出PalM2 Gemini等系列模型 Scaling Law是否仍然适用于当下的大模型发展 科技巨头与初创企业在竞争中各有哪些优势和劣势 模型研究者应秉持哪些社会责任 2023智源大会
  • 文本分类入门理论

    多模态情感分析 文本分类入门理论 环境 Python3 8 CSDN训练数据地址 https download csdn net download weixin 45889655 49100825免费积分的审核了三天 有积分的审核了两分钟
  • PuTTY远程登录Linux 实例

    云服务器HHS链接 操作步骤 使用密码登录 下载 Windows 远程登录软件 即 PuTTY PuTTY 的获取方式 点此获取 双击 putty exe 打开 PuTTY 客户端 在 PuTTY Configuration 窗口中 输入以
  • html将图片包含在程序中(base64)

  • Vitis-AI 3.0 GPU Docker 安装踩坑及修改

    参考视频 Bili 参考blog CSDN 安装的版本为vitis ai 3 0 特别鸣谢ChatGPT 启动docker获得的报错 走完上述步骤后 启动docker docker run sh xilinx vitis ai pytorc
  • 【力扣】19. 删除链表的倒数第 N 个结点 <链表指针、快慢指针>

    力扣 19 删除链表的倒数第 N 个结点 给你一个链表 删除链表的倒数第 n 个结点 并且返回链表的头结点 示例 1 输入 head 1 2 3 4 5 n 2 输出 1 2 3 5 示例 2 输入 head 1 n 1 输出 示例 3 输
  • conda: command not found(自用)

    conda create n cpdb python 3 9 创建环境时报错 conda command not found 查阅资料发现时环境变量的问题 于是 vim bashrc 打开文件 然后最后一行加入miniconda3的路径 e
  • 循环队列的操作原理

    一 循环队列的定义 为了克服顺序队列中假溢出 通常将一维数组Queue 0 到Queue MAXSIZE 1 看成是一个首 尾相连接的圆环 即Queue 0 与Queue MAXSIZE 1 相连接在一起 将这样形式的队列成为循环 队列 二
  • 微信小程序基础知识--表单

    一 input 属性 type 最大的输入长度 为空的占位 WXML 选项单选 默认选中状态 checked 二 选择到店时间 piker时间选择器组件 从底部弹起 开始和结束时间 有高度才能弹起选择时间 三 按钮 四 form组件 for
  • Windows Server 2012-dns区域传送+转发器

    dns区域传送 在主dns服务器上配置区域传送ip为被传送dns服务器ip 在被传送dns服务器中新建辅助区域 名称设为主dns服务器的域名 配置为主dns服务器的ip 完成 右键选择从服务器传输 然后刷新 成功 转发器 在主dns上配置条
  • 【实践】PPT制作从入门到精通(含素材资源大全)

    1 摘要 作为一个演讲者和一个解决方案工程师 写好满足场景和吸引眼球的PPT是必须的技能 辉哥把所有的私藏货拿出来 希望能给同行带来帮助 2 PPT技能 2 1 PPT技巧 2 1 1 PPT学习三部曲 PPT的学习分为三个阶段 练习基础操
  • 如何定制化Spring Boot Starter,这次我终于学会了

    文章目录 什么是Spring Boot Starter 实现步骤 启动器 自动配置包 总结自定义Starter的实现逻辑 Spring Boot Starter官网描述 Spring Boot Starter官方介绍 什么是Spring B
  • 测试相关知识点

    设计测试用例 主要从功能性 性能性 安全性 易用性 兼容性 网络测试这几个方面来设计 需要考虑问题的角度全面 注意如果是手机端app测试的话需要加上中断测试这项 考虑后台切换 app切换 拔插数据线 来短信 电话 其他app消息 1 微信朋
  • openMP + cuda 实现多GPU编程

    include
  • @FeignClient configuration参数配置

    1 我们定义Feign Client时候 可以通过configuration参数指定一个配置类 那么指定的这个配置入口类上面是否需要添加 Configuration 注解呢 FeignClient name OrderServiceClie
  • 渗透测试工具Burp Suite详解

    Burp Suite 的安装 Burp Suite是一款集成化的渗透测试工具 包含了很多功能 可以帮助我们高效地完成对Web应用程序的渗透测试和攻击 Burp Suite由Java语言编写 基于Java自身的跨平台性 使这款软件学习和使用起