种地 发表于 2025-3-5 14:33:19

功能 & 接口测试,详解从抓包 +linux 日志 + 数据库的 bug 定位!

我在跟很多测试人员交换中发现,很大一部分测试工程师在进行功能和接口测试过程中,对于发现的bug很少去进行定位,只是将bug基于业务操纵上怎样出现的,进行形貌;至于bug产生的原因,开发本身排查去吧。本文中,我们将探究怎样结合抓包分析、linux日志分析以及数据库查询来进行深度定位,进步bug解决的服从,体现更多测试人员的代价。
一、功能测试出现bug,怎样定位?

当界面出现bug,可先抓包分析定位前端还是后端bug,fiddler抓包定位过程:
先查看哀求信息:没有发出哀求、哀求信息错误的 —>前端bug
哀求信息精确的,查看后端返回响应是否精确,若错误—>后端bug,进一步可通过linux日志+数据库定位
哀求信息精确的,后端返回响应也精确,但前端页面信息显示错误(比方无显示/显示非常) --> 前端bug。
题目1:进行如下功能操纵中,最后一步点击提交,页面无任何反应!
https://i-blog.csdnimg.cn/direct/0c0707a5c7004be0b35c0a59059183db.png
怎样定位?

1)抓包分析:因为是web项目,这里通过浏览器开发者工具F12进行分析。
找到网络视图,当点击提交时,无哀求信息,题目出在前端!
https://i-blog.csdnimg.cn/direct/54a53948044046a8a1306a7010d6bf95.png
2)前端有报错提示,点开报错,可以看到原因:TypeError: files is undefined。也就是提交操纵时,files文件未界说。结合当前功能业务思考哪个环节必要提交文件。
https://i-blog.csdnimg.cn/direct/bda7efb90f964de98da1404cfcd22812.png
3)返回功能操纵上一步,发现图片文件未上传。该功能必要优化:当前必填红色* 标注,且当用户必填未填时,弹框给与提示。
https://i-blog.csdnimg.cn/direct/7c6f921318b04cfdbb76a05e3ec288e2.png
题目2:进行如下注册功能操纵,报错:校验失败,服务器非常!
https://i-blog.csdnimg.cn/direct/8cbc24b367e84a269d196bc5c95d7645.png
怎样定位?

1)通常报服务器非常/系统非常,基本可断定是后端bug!当然为了确保前端提交哀求无非常,先可通过抓包确认。注册操纵,会先检查手机号是否存在,分析抓包哀求,得到bug是后端!
https://i-blog.csdnimg.cn/direct/ffb1e57ac2fe48bc850dc63305cd3f21.png
2)该后端bug,需进一步看日志定位!这里必要明确:
项目日志记录在什么文件?这里可以问开发。比方当前我的这个项目是基于tomcat来摆设的,日志记录在tomcat的logs目录的catalina.out文件中
怎样查看日志?因为项目摆设在linux环境上,因此这里查看日志文件,必要通过linux命令来查看,比方tail -f catalina.out。通过查看日志文件,得出报错非常原因:查库select * from nm_user where username=?时,Unknown column ‘username’ in ‘where clause’。即查询的字段名username不存在。
https://i-blog.csdnimg.cn/direct/741b527d5424470fb1dbc7180823629f.png
3)进一步查库确认,查看表计划,不存在username,实则为user_name。明确bug的原因!
https://i-blog.csdnimg.cn/direct/120d3439ea694d18828ca779be0d8106.png
二、接口测试出现bug,怎样定位?

接口测试原理: 使用工具或代码,模拟客户端发送哀求到服务器,服务器接收哀求并处置惩罚,客户端接收服务器返回响应的过程。
接口测试定位bug过程:
1)如果返回结果是正常的、进一步查看数据库是否有题目,无题目,则测试通过;有题目比方数据库数据增编削有题目就提交bug到bug管理系统;
2)如果返回结果是非常的:
a、先确认地址、参数名、参数传值等是否精确,有题目对应修改,再做测试;
b、如果这些哀求设置,传值都没题目,返回结果是非常的,进一步查看数据库以及日志是否有题目,有题目,则提交bug到bug管理系统,而且附上有题目的Jmeter操纵、数据库表数据甚至是日志。
题目:如下添加理财产物接口中,传递的bidding_days参数值为2,返回响应中值为5,与传入不一致!
https://i-blog.csdnimg.cn/direct/80b3df6208ea46df898ae53db1923064.png
https://i-blog.csdnimg.cn/direct/d0a0488142674a0d85f2c36b4940c775.png
bug分析:
1)响应返回数据有题目,数据从数据库查询得到,猜测是否数据库本身数据就错了。查库确认,入库时bidding就存为5,而且发现之前的所有数据都为5。猜测表计划题目!
https://i-blog.csdnimg.cn/direct/b72e8893ba1546e9b5dec72773281a46.png
2)查看该表的计划,发现该字段设了默认值,明确bug的原因!
https://i-blog.csdnimg.cn/direct/71c6265e2b1740f78d10ed4c6abf2c6c.png
这里我创建了一个交流群:748833197,希望优秀的软件测试宝子们都可以聚集在一起,大家可以一起解决软件测试难题、面试难题、以及工作上的问题、以及利用这次机会提升自己的能力!!!

此外,我也会分享软件测试面试经验,跳槽、转行信息。

一起学习交流讨论吧~

定个小目标:1W人


[*]
感谢每一个认真阅读我文章的人!!!
作为一位过来人也是渴望大家少走一些弯路,如果你不想再体验一次学习时找不到资料,没人解答题目,坚持几天便放弃的感受的话,在这里我给大家分享一些自动化测试的学习资源,渴望能给你进步的路上带来帮助。
https://img-blog.csdnimg.cn/direct/5fb98e37cc1b4f2bae72457589697c91.png
软件测试口试文档

我们学习一定是为了找到高薪的工作,下面这些口试题是来自阿里、腾讯、字节等一线互联网大厂最新的口试资料,而且有字节大佬给出了权威的解答,刷完这一套口试资料相信大家都能找到满意的工作。
https://i-blog.csdnimg.cn/direct/514965e1ab1148dfb4c04768ea1b9cbd.jpeg
 https://img-blog.csdnimg.cn/694b35de52e6493c99f913729355584f.png
          视频文档获取方式:
这份文档和视频资料,对于想从事【软件测试】的朋友来说应该是最全面最完备的备战仓库,这个仓库也陪伴我走过了最困难的旅程,渴望也能帮助到你!以上均可以分享,点下方小卡片即可自行领取。

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
页: [1]
查看完整版本: 功能 & 接口测试,详解从抓包 +linux 日志 + 数据库的 bug 定位!