聊聊如何判断发现的缺陷属于前后端

目录

一、观察缺陷现象

二、检查网络请求(核心方法)

三、模拟请求验证后端

四、查看日志

五、数据流分析

六、判断前后端缺陷方法


判断发现的缺陷是前后端,可以通过观察缺陷现象,检查网络请求,查看后端日志,模拟请求,控制台错误,环境因素,数据一致性等措施,我们可以比较准确地定位缺陷属于前端还是后端。

判断一个缺陷属于前端还是后端,需要结合现象、数据流向和技术栈进行分析。

常见的属于前端的问题

页面渲染错误(样式、布局)

用户交互无响应(如点击事件未绑定)

表单验证错误(前端验证未通过,而后端验证通过)

未正确发送请求(如请求方法错误、URL错误)

未正确处理响应数据(如解析错误、展示错误)

常见的属于后端的问题

接口返回错误的数据(例如从数据库查询出错)

接口返回的数据不符合约定(如字段缺失、类型错误)

接口未处理某些边界条件(如空值、异常输入)

数据库操作失败(增删改查错误)

接口性能问题(响应慢)

身份验证/授权失败(权限控制问题)

一、观察缺陷现象

前端问题特征:

页面样式错乱、元素错位、颜色/字体异常。

浏览器控制台报错(JavaScript错误、资源加载失败)。

交互逻辑问题(点击按钮无响应、表单验证失败)。

仅在特定浏览器或设备上出现。

后端问题特征:

数据错误(如用户信息显示为他人数据)。

操作后数据未持久化(如提交表单后数据库未更新)。

接口超时(HTTP 504)、服务器错误(HTTP 5xx)。

第三方服务集成失败(支付、短信等)。

二、检查网络请求(核心方法)

使用浏览器开发者工具(F12 → Network):

步骤:

触发缺陷,观察网络请求。

检查请求是否发送:

未发送请求 → 前端问题(如事件未绑定、JS报错)。

检查请求参数:

参数错误/缺失 → 前端问题(如未正确组装数据)。

检查响应结果:

HTTP状态码为4xx/5xx → 后端问题(如认证失败/服务异常)。

响应数据错误 → 后端问题(如接口返回错误数据)。

响应数据正确但显示错误 → 前端问题(如数据渲染逻辑错误)。

三、模拟请求验证后端

使用工具(Postman/cURL)直接调用后端接口:

操作:

复制前端请求的URL、参数、Headers,在Postman中发送相同请求。

结论:

模拟请求成功 → 前端问题(如数据处理错误)。

模拟请求失败 → 后端问题(如接口逻辑缺陷)。

四、查看日志

前端日志:

浏览器Console中的错误信息(如JS报错、API请求失败)。

后端日志:

服务器日志(查看请求是否到达、处理异常、SQL错误等)。

关键结论:若后端日志无请求记录 → 前端未发送请求。

五、数据流分析

典型流程:

用户操作 → 前端调用API → 后端处理 → 数据库 → 返回响应 → 前端渲染

定位点:

问题发生在渲染阶段(如数据展示错乱)→ 前端。

问题发生在数据源头(如数据库写入错误)→ 后端。

六、判断前后端缺陷方法

✅ 前端负责展示与交互,后端负责数据与逻辑。

✅ 网络请求分析是黄金标准,日志和模拟请求是验证关键。

相关推荐
卓码软件测评2 小时前
【网站测试:CORS配置错误引发的安全风险及测试】
功能测试·安全·web安全·压力测试·可用性测试·安全性测试
测试老哥11 小时前
pytest+requests+allure自动化测试接入Jenkins学习
自动化测试·软件测试·学习·测试工具·职场和发展·jenkins·pytest
Mike_Wuzy1 天前
【音频信号发生器】基本应用
测试工具
程序员三藏1 天前
Selenium+python自动化测试:解决无法启动IE浏览器及报错问题
自动化测试·软件测试·python·selenium·测试工具·职场和发展·测试用例
Warren981 天前
软件测试-Selenium学习笔记
java·javascript·笔记·学习·selenium·测试工具·安全
zzc9211 天前
Wireshark获取数据传输的码元速率
网络·测试工具·wifi·wireshark·路由器·802.11n·物理层参数
小丁爱养花2 天前
接口性能测试工具 - JMeter
测试工具·jmeter
甄超锋2 天前
python sqlite3模块
jvm·数据库·python·测试工具·django·sqlite·flask
中草药z3 天前
【自动化测试】Selenium详解-WebUI自动化测试
前端·功能测试·selenium·自动化·html·web·测试
zzc9213 天前
TLSv1.2协议与TCP/UDP协议传输数据内容差异
网络·测试工具·安全·wireshark·ssl·密钥·tlsv1.2