切面方法成功执行完之后出现NullPointException-记今天的实现一小时,DeBug一下午

在实现登录次数验证时,尝试通过AOP切面获取Session,但因Session获取时机不当引发异常。最终发现是由于切面匹配错误,void方法使用returning参数导致NullPointerException。调整切点命名并理解了AOP方法执行顺序,成功解决问题。

今天,继续写登陆次数验证.本来想切面里面去切登录方法,拿到session,通过session判断用户是否已登录.还是有点图样图森破.Session的获取与创建在response之后就不可以了,会抛出异常.算了,就直接写在doLogin的Controller里面了.的确,只切一个方法,直接在方法里面写逻辑更优.噼里啪啦写完实现之后开始运行项目.点击登录.啪唧.啥反应都没.response里面已经跳到错误异常页面了.查看了下console的输出.NullPointException.

然后进入了一下午的DeBug,只要执行完了service的方法就会报错.尝试过try,catch包裹整个serviceImpl,并没有捕获到任何异常.找了我的导师和另一个大佬帮我DeBug,改了很久都没想到为什么会出现这个NullPointException,最后大佬试了下改了我的方法名.将void addFailedTime(LoginRecordDto selectDto);改为了void updateFailedTime(LoginRecordDto selectDto);竟然成功不报错了.他对我说可能是切面的问题,重复切了.贴下方法,和几个切点.

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值