关于处理addGiftmoneyAction接口报错问题的总结

时间:2023-03-09 19:16:12
关于处理addGiftmoneyAction接口报错问题的总结

昨天UniUser中AddGiftmoneyAction接口在被调用时抛出异常,曾哥让我来解决这个问题,虽然最后查出是路径问题,但是由于解决问题 的思路不够清晰,导致浪费了大量的时间和精力,也没有给出最好的解决方案。经过曾哥的一番指导豁然开朗,现在对这个问题的分析过程做一个总结,与大家共勉。
   首先,昨天在前台调用user.addGiftmoneyAction这个接口的时候,结果为新增失败。服务器日志如下:

关于处理addGiftmoneyAction接口报错问题的总结

这个时候,应该可以轻易地定位到抛出异常的地方,就是AddGiftmoneyAction中第411行,这个时候,应该迅速找到代码的411行。

关于处理addGiftmoneyAction接口报错问题的总结

这里可以看到,是writeFile这个方法报错,从服务器报错中也可以看到,是/usr/giftmoney/html/-1/11/redEnvelope_trhome.html这个文件不存在。

所以接下来要去服务器验证一下,验证发现服务器上存在/usr/giftmoney/html/-1这个目录,但是命令进不去,这是因为 -(减号)在Linux系统里有特殊含义,因此无法进入该文件夹,导致报错。

到这里,问题已经找到了,下面来解决这个问题。

首先,这个-1是从哪里来的?

从411行代码可以看出,-1是orgid的值,这个值由bcid传入(263行),而

bcid则是接口的入参,因此,只要bcid不传入负数问题就解决了。

关于处理addGiftmoneyAction接口报错问题的总结

回想我自己解决问题的过程,先是去向运维要日志,看到抛出文件不存在的错误后,并没有直接找到报错行411行,而是转向接口去从头分析,分析之后并没有发现问题又开始本地测试,因为本地环境与服务器环境的差异导致在目标问题出现之前就抛出了一堆错误,为了能测通只好又要先去解决这些问题,而且windows文件目录与lunux目录不一样,所以本地测通也不能保证换成服务器地址也行得通,这样的差异导致查找问题的思路越来越乱,最终无法定位到是传参导致的问题。

所以,在问题出现之后,首先要有清晰地思路来分析问题,准确判断是什么环节出现的问题,而不是一出现问题就开始在本地来回的测试。

相关文章