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做了序列化,也许是修改之后这个类也刷新了,就能用了。