Shiro提示org.apache.shiro.session.UnknownSessionException: There is no session with id的问题

前几天在搞通过异步去同步其他从库的数据,供其余系统能够使用。本地测试通过,无异常然后就打到线上,今天同步数据发现从库的数据没有更新。排查问题后才发现日志报错了,就提示这个异常
org.apache.shiro.session.UnknownSessionException: There is no session with id的问题

一、问题排查

 找准百度,一顿输出,大致的意思说啥

因为在shiro的DefaultWebSessionManager类中,默认Cookie名称是JSESSIONID,这样的话与servlet容器名冲突,
如jetty, tomcat等默认JSESSIONID, 当跳出shiro
servlet时如error-page容器会为JSESSIONID重新分配值导致登录会话丢失

这答案莫名其妙,然后我大致捋了下前因后果,结合我的业务操作逻辑以及要干的活。大致明白了问题出现在哪里了。

二、问题原因

我的业务是在执行完我本身的业务逻辑后,调用了异步线程池异步的去执行我后续的代码逻辑,但是这时候我犯了一个小小的错误,就是在异步的线程任务中,我通过Shiro工具类去获取了当前登录用户信息。结果导致了这样的异常错误

三、解决问题

说到这里,小伙伴们大致应该猜到怎么解决了吧。

本身用户登录在一个线程,这时候你开启了异步线程池去执行后续逻辑,然后你还想获取当前用户的信息,两种操作都不属于同一个线程了。

如果小伙伴们遇到了类似的问题,先排查自身的业务代码有没有不在同一个线程中的。

你可能感兴趣的:(工作中遇到的问题,apache,java,spring)