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工具类去获取了当前登录用户信息。结果导致了这样的异常错误

三、解决问题

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

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

王小睿丶

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

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

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

打赏作者

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

抵扣说明:

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

余额充值