如何正确的找BUG

什么是BUG

漏洞是在硬件、软件、协议的具体实现或系统安全策略上存在的缺陷,从而可以使攻击者能够在未授权的情况下访问或破坏系统。具体举例来说,比如在Intel Pentium芯片中存在的逻辑错误,在Sendmail早期版本中的编程错误,在NFS协议中认证方式上的弱点,在Unix系统管理员设置匿名Ftp服务时配置不当的问题都可能被攻击者使用,威胁到系统的安全。因而这些都可以认为是系统中存在的安全漏洞。bug狭义的概念是指软件程序漏洞或缺陷,广义的概念还包括测试工程师或用户所发现和提出的软件可更改的细节、或与需求文档存在差异的功能实现等。

简单点说就是 程序不按照你的预期执行,或者程序直接报错了。在每个程序员的职业生涯中都会碰到或多或少的bug,有人写的程序bug就是少,有人写的程序bug就是很多。这是因为每个人的对技术的广度和深度都不同。知道技术的原理写起来代码肯定bug会少些,不懂原理写起来肯定错误百出。但是即便你精通各种技术还是会出现bug,这是不可避免的。

对待BUG的态度

我见过无数程序员一看到程序出错了就很紧张,仿佛报错要他命似的。乱了阵脚,其实报错不可怕,报错都是可以处理的。你看到哪里报错找哪里,找到哪一行想想那一行为啥会报错。直接debug不就可以了。报错没事,心态放平慢慢找,一点一点debug,找到为什么报错就可以了。其实做久了才知道,报错的bug一点都不可怕,不报错的bug才可怕,逻辑完全正确,但就是不按照你预期的走。这种bug往往搞得你怀疑人生。

如何找BUG

找bug的前提是复现问题,很多bug都是在特定的情况下才会出现的,就像我们经常碰到的在自己电脑上没问题在别人电脑上就有问题,或者在外网环境没问题,在内网环境就不行。我们碰到这种情况要第一时间复现问题,如果复现不了问题你肯定解决不了。切记不能自己闷着头瞎调试。你的环境没问题你还在你电脑上调试,能调试出来才怪了。你要去有问题的环境找问题,内网有毛病你就去内网复现问题,复现了再比较和外网有啥区别慢慢解决,切不可产生畏战心理,其实好多问题只要找到根源就豁然开朗了。

一个不太好找的BUG

去年冬天公司安排我去哈尔滨培训,培训前我们把要培训的功能测试了一遍,其他有问题的很快改了,偏偏我就遇到了一个问题,有一个接口请求后台,后台从session里面拿数据,但是后台的session对象一直为null,这就让人很费解。session默认过期时间是30分钟而我一直在请求后台,session是不可能失效的。我在本地怎么测怎么没问题。先说一下我们的环境,开发的时候我们是前端一个项目后端一个项目,前端系统配置菜单,前端直接请求后端拿数据。而我们发布后就成了,前端加页面需要去另一个系统加,另一个系统是一套.net的系统,我们在.net系统里面配置前端页面地址,菜单名,权限等。经常做后台管理系统的同学应该知道一般是上边一栏菜单,左边一栏菜单。中间是功能页面。中间页面是iframe,是一个系统。而我们就不一样了,上边和左边的菜单栏是一个系统,中间的功能页是嵌的我们前端系统的页面地址,中间功能页也是iframe。开始我感觉和这些没问题,既然功能页都是iframe应该没区别。但是我在本地怎么也复现不了。这就很无奈,找bug你一定要找到蛛丝马迹。我就看前端页面发送的请求,看了半天才发现问题。
在这里插入图片描述

我们看响应头有一个 Set-Cookie 这里给浏览器了一个Cookie 。看似没啥毛病,但是我发现每一次请求后端都会给浏览器一个key为JSESSIONID的Cookie,而且每次请求时请求头都不会把这个Cookie发送到后台。这就让人很费解。这样我也就明白了为啥后台用Session对象的时候为null了。现在我们就找为啥请求的时候不将Cookie发送给后台,知道了为啥不发送也就知道了问题所在。后台给浏览器Cookie的时候别的都挺正常的但是SameSite=lax这个东西我看不懂。

经过我的百度查到了问题知道了这个属性是啥意思。

简单点来说就是谷歌为了安全性,在浏览器80版本以后就不允许不同站点的原页面和iframe页面请求时发送Cookie,因为我们内网发布的菜单栏和iframe是俩系统也就是俩站点,所以iframe的页面发送的请求都不带着Cookie,自然也就导致后台拿不到Session了。而外网开发环境菜单栏和iframe是一个系统所以iframe页面发送的请求都带着cookie,也就不会导致后台取不到Session了。至此我们发现问题所在。接着想办法解决就可以了。

其实这个BUG将出来看似很简单,其实不然,首先你要复现问题,其次你一定要知道Session和Http协议的工作原理,如果你不懂这俩技术的原理是肯定找不到问题所在的。

系统不存在一会行一会不行

还有一个问题,就是我们一台服务器上部署了两个后台系统,一个是A系统占用80端口,一个是B系统占用8080端口。有些前端页面请求了A系统的后台,有些前端页面请求了B系统的后台。别人给我反映经常丢Session(也就是上面说的后台拿不到Session对象)一会好使一会不好使,好几个人都没找到咋回事,找到我了,其实我也很懵。但是我不认同别人的说法,系统绝对不存在一会可以一会不可以,可以的时候一定有可以的原因,不可以的时候一定有不可以的原因。有因必有果。经过我的测试如果一直使用请求A系统的页面是没问题的,一直使用请求B系统的页面也是可以的。但是打开过请求B系统的页面再打开请求A系统的页面必报错。然后我发现了问题所在,第一次打开请求B系统的页面B系统会响应给浏览器一个key为JSESSIONID的Cookie,因为这个浏览器第一次请求B系统。但是JSESSIONID的Path属性为/ 而且Cookie作用域和端口没关系,如果这时候我们打开请求A系统的页面也会把这个JSESSIONID带过去,而这个值和A系统没关系,A系统也就会重新给浏览器一个JSESSIONID,自然A系统也就拿不到Session了。出现BUG第一步一定是要复现,如果复现不了肯定找不到,其次要找痕迹想办法找到哪里不正常,懂原理。如果我不懂Cookie的作用域和端口没关系肯定找不到原因所在。

如果喜欢本篇文章不妨关注点赞收藏,有什么困惑欢迎评论。

欢迎关注接地气程序员,公众号,掘金,博客园,简书,CSDN同名。

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: irptrace是一种用于跟踪TCP/IP网络数据包的工具,用于诊断网络故障和分析网络性能问题。irptrace bug指的是irptrace工具中的错误或问题。 irptrace bug可能会导致以下问题: 1. 数据包丢失:irptrace工具可能无法正确跟踪特定的数据包,从而导致数据包丢失。这可能使得在分析网络故障或性能问题时无法得到完整的数据包信息。 2. 数据包误解释:irptrace工具在解释和显示跟踪到的数据包时,可能存在解析错误或误解释。这可能会导致分析人员对问题的理解出现偏差,从而影响故障排查和问题解决的准确性。 3. 流量捕获问题:irptrace可能无法正确捕获特定的网络流量,导致分析人员无法获得完整的数据包信息。这可能会给故障排查和网络性能分析带来困扰。 为解决irptrace bug,可以采取以下措施: 1. 更新工具版本:检查irptrace是否有更新的版本可用,并及时进行升级。新版本通常会修复之前版本存在的问题和错误。 2. 反馈问题:向irptrace的开发者或社区反馈发现的bug。提供详细的bug报告,包括复现步骤、操作环境以及出现的错误现象。这有助于开发者理解和解决bug。 3. 使用替代工具:如果irptrace存在严重的bug,且无法得到及时修复,可以考虑寻替代的网络数据包跟踪工具,以满足分析需求。 总之,irptrace bug可能会对网络故障排查和性能分析造成不便和困扰。通过及时更新版本、反馈问题和使用替代工具,可以最大程度地减少bug带来的影响。 ### 回答2: irptrace bug是指在irptrace程序中存在的错误或缺陷。irptrace是一种用于追踪和分析网络中的IRP(Input/Output Request Packet)的工具。IRP是Windows操作系统中的一种数据结构,用于表示设备驱动程序之间的通信请求。 irptrace bug可能会导致程序运行时出现意外的行为或错误的输出。这些错误可能由以下原因引起: 1. 内存错误:在处理IRP时,程序可能会对内存进行错误的读写操作,导致数据损坏或程序崩溃。 2. 逻辑错误:IRP的处理可能存在逻辑错误,导致程序无法正确解析和响应IRP请求。 3. 并发问题:在多线程或多进程环境中,IRP的处理可能存在并发问题,导致数据竞争和不确定的行为。 解决irptrace bug的方法通常涉及以下步骤: 1. 重现bug:通过使用给定的输入或具体的测试用例来重现错误。这有助于开发者定位和理解bug的根本原因。 2. 调试:使用调试工具(如调试器或日志记录)跟踪程序执行的每个步骤,bug所在的代码位置。 3. 修复bug:根据调试结果,开发者需要改正或修复引起bug的代码。这可能包括修复内存错误、修改逻辑错误或解决并发问题。 4. 测试:对修复后的代码进行全面测试,确保在各种输入和使用情况下没有再次出现类似的bug。 最后,irptrace bug的修复应该通过软件版本控制和发布机制,将修复应用到所有受影响的版发布版本中,以确保用户可以使用到修复后的版本。这样可以提高irptrace的稳定性和可靠性。 ### 回答3: irptrace bug是指由于irptrace程序中的程序错误或漏洞导致的问题。irptrace是一种用于跟踪和分析网络协议包的工具,常用于网络故障排除和性能分析。然而,由于代码编写或设计上的错误,irptrace可能会出现一些bug,影响其正常运行和准确性。 irptrace bug的出现可能导致不正确的跟踪结果,或者在特定情况下导致程序崩溃。例如,一个常见的bug可能是irptrace在解析或处理特定类型的网络协议包时出现错误。这可能导致irptrace无法正确解码和显示相关信息,或者给出错误的跟踪结果。 修复irptrace bug需要进行代码审查和测试,以确定问题所在,并对代码进行修改和优化。开发人员需要仔细检查输入验证和边界情况处理,以确保代码的健壮性和鲁棒性。 此外,用户也可以通过向irptrace开发团队报告bug来促进修复。这通常包括提供复现bug所需的详细信息,例如操作系统版本、irptrace版本、复现bug的步骤和所使用的网络环境。这些信息将帮助开发人员更好地理解和定位bug,并更快地进行修复。 总之,irptrace bug是指由于irptrace程序中的错误或漏洞导致的问题。修复这些bug需要开发人员进行代码审查和测试,并且用户的报告也是促进修复的重要渠道。这样可以确保irptrace能够正常运行且给出准确的跟踪结果,提高网络故障排除和性能分析的效率和准确性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值