抓包是什么?我们为什么要抓包?

一、什么是抓包?

抓包(packet capture)就是将网络传输发送与接收的数据包进行截获、重发、编辑、转存等操作,也用来检查网络安全。抓包也经常被用来进行数据截取等。

二、抓包做什么?

不管做什么事情,首先要有明确的目的,其次是要清除能力的范畴,最后是要有清晰的思路。原始数据——过滤——分析,这时数据处理的基本套路,抓包的目的就是为了获取想要的原始数据,拿到数据以后,我们就可以做以下一些事情:

分析数据传输协议。

定位网络协议的问题。

从数据包中获取想要的信息。

将截取到的数据包进行修改,伪造,重发。

三、为什么抓包?

1、从功能测试角度,通过抓包查看隐藏字段

web表单中会有很多隐藏的字段,这些隐藏字段都有一些特殊的用途,比如收集用户的数据,预防CRSF攻击,防网络爬虫,以及一些其他用途。这些隐藏字段在界面上都看不到,如果想检测这些字段,就必须要使用抓包工具。

2、通过抓包工具了解协议内容,方便开展接口和性能测试

性能测试方面,性能测试其实就是大量模拟用户的请求,所以我们必须要知道请求中的协议内容和特点,才能更好的模拟用户请求,分析协议就需要用到抓包工具;

接口测试方面,在接口测试时,虽然我们尽量要求有完善的接口文档。但很多时候接口文档不可能覆盖所有的情况,或者因为文档滞后,在接口测试过程中,还是需要借助抓包工具来辅助我们进行接口测试。

3、需要通过抓包工具,检查数据加密

安全测试方面,我们需要检查敏感数据在传输过程中是否加密,也需要借助抓包工具才能检查。

4、处理前后端bug归属之争

在我们提交Bug的时候,经常会出现前端(客户端展示)和后端(服务端的逻辑)的争议,那么可以通过抓包工具,确定是数据传递问题还是前端显示问题,如果抓出来的数据就有问题的话,那么一般是后端的问题;如果抓取出来的数据是正确的,那么基本上可以判断是前端问题。

四、抓包的抓用?

通过抓包分析,可以更好的理解整个系统。

经常使用抓包工具辅助测试,可以很好的了解整个系统,比如数据传输过程前后端的关系,以及整个系统的结构。特别是对现在的微服务架构的产品,抓包能够更好的梳理和掌握整个系统各个服务之间的关系,大大增加测试的覆盖度。另外还可以增进对代码、HTTP协议方面知识的理解。

五、常用抓包工具

1、httpwatch

httpwatch与IE和Firefox浏览器集成,但不支持chrome;httpwatch界面清晰直观,发送请求后可以快速简单的查看cookies、headers、Query Strings and data,能够通过页面分组处理多页面场景。

2、Fiddler

Fiddler是一个独立的应用,可以调试PC、Mac、Linux、移动设备的之间的通信,支持大部分框架,如Java、.net、Ruby,需要设置代理。

3、wireshark

wireshark是一款专业的通过抓取网络数据包进行网络监测,网络协议分析工具,可以实时监测网络传输数据,全面透视整个网络的动态信息。

4、firebug

Firebug是Firefox下的一个扩展,它除了能进行网络分析还能够调试所有网站语言,如js、HTML、css等,支持各种浏览器如IE、Firefox、opera、safari。​

最后给大家分享一下我的一些学习资料:

以上内容,对于软件测试的朋友来说应该是最全面最完整的备战仓库了,为了更好地整理每个模块,我也参考了很多网上的优质博文和项目,力求不漏掉每一个知识点,很多朋友靠着这些内容进行复习,拿到了BATJ等大厂的offer,这个仓库也已经帮助了很多的软件测试的学习者,希望也能帮助到你。

关注下方我的微信公众号免费领取!↓ ↓ ↓ ↓ ↓

猜你喜欢

转载自blog.csdn.net/weixin_54696666/article/details/132667922