「前端经验总结」特定业务场景数据收集,帮助解决用户具体操作无法确定的问题

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介: 前端开发中,有些业务场景下的操作,再测试过程中可能没有遇到,但是用户反馈了该问题,如何进行问题复现是我们时不时会遇到的问题。今天分享一下如何进行特定业务场景数据收集,来帮助解决用户具体操作无法确定的问题。

文章背景

面向用户使用的产品,即使项目加入了埋点,某些用户描述的操作场景,也比较难确定实际情况。比如提示对话框,有些页面的数据权限是对话框的展现形式,用户这个时候操作了对话框,进行了页面跳转,是正常的业务逻辑。但是有些情况下,用户跟客服反馈问题时,会有表达上不清晰或者遗漏自己做过的操作等情况。

有些时候,因用户提供的信息不准确,研发在日志系统和埋点系统查找上报数据的时候,犹如大海捞针。为此,产品同事和研发同事共同做了多次操作优化。

但是用户提供信息不准确这种情况是无法完全避免,所以我开始思考别的解决方案。

逆向思维

做了一些正向思维的操作优化,发现还是有用户提出的问题,无法进行快速定位。虽然,已知的业务场景就那几个,但是在日志系统里,很难找到帮助支撑结论的数据。

等等,已知的业务场景,我既然知道了哪些业务场景,为什么不按照这个维度进行数据收集呢?我收集到数据,即使用户提供的信息是错误的,但是场景是真是发生的,我只有找到场景数据,反推用户信息,然后跟用户确实反推出来的信息,不就能解决问题了。

逆向思维,真是解决问题的「良方」之一。

功能设计

上报公共方法

上报方法里主要讲需要上报的数据整理成请求的入参,然后传入日志上报的接口中。

  • apiMethod:接口请求方式,有GET和POST两种;
  • params:操作场景的主要参数;
  • httpApi:如果场景属于异步请求返回值场景,则上报它的api接口相对路径;
  • res:如果场景属于异步请求返回值场景,则上报它的响应体;
  • describe:场景描述,这个很重要,把用户方操作逻辑描述成文字,方便查询问题时,找到进行过的操作。
/**   * 日志上报功能   * @param {Object} data 上报数据   * @return {void} 无   */apiLog(data) {
// 接口请求方法constapiMethod=data.method?data.method : 'GET';
// 调用公共上报方法constreqData= {
method: apiMethod, // 此接口请求方法params: data.params, // 入参url: data.httpApi, // api接口相对路径  };
// 调用上报接口reportApi(reqData, data.res, data.describe);
}

特定业务场景上报

以用户查看订单信息为例。

早上,叶一一刚进入办公室,就看到问题群里信息在闪烁。打开发现客服反馈了一个问题,用户说看不到订单记录。测试的同事正在帮忙筛查问题,测试的同事第一反应是,用户登录的账号不是之前下单的账号。但是用户比较坚持说确定了账号是下单的账号。

测试的同事用提供的账号确实查到了信息,但是研发的同事查登录日志没有查到信息。

此时叶一一打开业务日志的面板,开始筛选操作场景,然后根据用户操作时间,确实了一个大概的操作范围,成功找到几条数据中的账号,该账号和用户提供的信息只有结尾的数字不同。于是叶一一让测试的同事帮忙,让用户确认登录账号是否是家人的账号。果然用户检查了账号后发现登录错了账号。

订单数据为空的时候会上报一条业务数据。

// 日志上报utils.apiLog({
httpApi: '/api/order',
params: {
accountId: '111',
  },
res: {
userName: '张三',
orderList: [],
  },
describe: '当前订单数据为空,可能原因:1、用户账号没有进行过下单操作,2、用户登录的不是下单账号。',
});


总结

依靠这个简单的有点简陋的功能,帮助解决了问题群里60%左右操作问题,大部分因为缺少关键操作描述或者描述信息不准确,而不好排查问题。

实际业务场景比举例中复杂很多,可以根据实际业务场景制定实现策略。

这个功能当时开发主要是为了用极少的开发成本,换取重复问题解决的人力成本,所以功能设计的比较简单。可以根据实际情况,在这个思维上尽情发挥。

相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
目录
相关文章
|
3月前
|
自然语言处理 资源调度 前端开发
前端大模型入门(四):不同文本分割器对比和效果展示-教你如何根据场景选择合适的长文本分割方式
本文详细介绍了五种Langchain文本分割器:`CharacterTextSplitter`、`RecursiveCharacterTextSplitter`、`TokenTextSplitter`、`MarkdownTextSplitter` 和 `LatexTextSplitter`,从原理、优缺点及适用场景等方面进行了对比分析,旨在帮助开发者选择最适合当前需求的文本分割工具,提高大模型应用的处理效率和效果。
258 1
|
8月前
|
资源调度 前端开发 JavaScript
第十章(应用场景篇) Single-SPA微前端架构深度解析与实践教程
第十章(应用场景篇) Single-SPA微前端架构深度解析与实践教程
266 0
|
8月前
|
前端开发 JavaScript
【Web 前端】什么是扩展运算符,用于什么场景?
【5月更文挑战第1天】【Web 前端】什么是扩展运算符,用于什么场景?
【Web 前端】什么是扩展运算符,用于什么场景?
|
8月前
|
存储 前端开发 算法
常见的前端加密方式有哪些?运用场景有哪些?
【4月更文挑战第12天】前端加密技术包括对称加密(如AES、DES)、非对称加密(如RSA)和Hash算法(如MD5、SHA-1)。对称加密用于本地数据加密、HTTPS通信,非对称加密常用于用户登录认证,Hash算法适用于数据完整性校验和密码存储。应用场景包括用户登录认证、敏感数据传输、文件加密和支付安全。加密技术结合访问控制、安全审计等措施,能提升数据和用户信息安全。
915 9
|
8月前
|
前端开发 JavaScript 容器
第九章(应用场景篇)Qiankun微前端深度解析与实践教程
第九章(应用场景篇)Qiankun微前端深度解析与实践教程
269 0
|
前端开发 JavaScript 算法
前端(七)——React框架的定位与应用场景解析
前端(七)——React框架的定位与应用场景解析
511 0
|
8月前
|
前端开发 JavaScript 数据安全/隐私保护
前端javascript的DOM对象操作技巧,全场景解析(二)
前端javascript的DOM对象操作技巧,全场景解析(二)
|
8月前
|
移动开发 缓存 JavaScript
前端javascript的DOM对象操作技巧,全场景解析(一)
前端javascript的DOM对象操作技巧,全场景解析(一)
|
8月前
|
前端开发 安全 开发工具
前端场景的代码部署方式都有那些?
【4月更文挑战第17天】本文分析了四种常见的前端代码部署方式:FTP/SFTP、Git、Docker和云服务平台部署。FTP/SFTP简单易用但效率低;Git提供版本控制,适合自动化部署,但有学习成本;Docker确保环境一致性,高效扩展,但较复杂;云服务平台弹性伸缩,高可用,但可能产生依赖和成本。选择部署方式应综合考虑项目需求、技术能力和成本。
215 0
|
8月前
|
NoSQL JavaScript 前端开发
报错场景:ant design vue前端登录时,输入的验证码是对的,但是一直提上验证码错误,登录不进去 报错信息(Error in execution; nested exception)
报错场景:ant design vue前端登录时,输入的验证码是对的,但是一直提上验证码错误,登录不进去 报错信息(Error in execution; nested exception)
79 0