记录一个很离谱的shiro问题

springboot版本2.2.13.RELEASE

shiro版本1.5.3

        昨天在本地完成了一个小功能,全部调试好了,准备放到项目上测试的时候,我把数据库地址从本机改到项目数据库,shiro就开始报下面这个错误:

Servlet.service() for servlet [dispatchernServlet] in context with path [] threw exception [Request processing failed; nested exception is java.util.NoSuchElementException] with root cause

java.util.NoSuchElementException Create breakpoint : null

        前端的网页后台能登进去,但是所有页面全都打不开。从报错信息看,问题看起来是出在这行代码上,是迭代器的问题,后端错误信息在下面。

77  protected AuthorizationInfo doGetAuthorizationInfo(PrincipalCollection principalCollection) {
78      ManagerEntity newManager = (ManagerEntity) principalCollection.fromRealm(getName()).iterator().next();

        离谱的来了,换了数据库出问题了那我换回去不就行了,结果换回去了,依旧是报这个问题,百度了一通没找到解决办法就下班了。今天上班的时候,我试了重启电脑,切换数据库,回退代码,重新编译,删了项目重建,通通不行,关键是同样的代码我同事电脑上都能跑起来,我自己就不行。

        没办法了我决定自己排查试试看。就在错误的那一行之前加了一行打印,把newManager的赋值部分,到使用迭代器之前的内容打印输出一下看看是什么,为什么用不了迭代器。ManagerEntity没有重写toString,于是我重写了一下方便输出,然后重启项目,后端报了个下面这样的错:

         但是没有影响,可以继续使用,登进后台发现所有问题都消失了,项目又能跑起来了。真的太离谱了,我把打印和重写的toString又删了,项目依然没问题,至此问题解决。

        问题分析:应该是哪里的缓存没清理的问题,估计涉及到jvm底层,还无法理解。ManageEntity做了序列化,也许是修改之后这个类也刷新了,就能用了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

风落拾羽

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值