Springboot项目配置shiro报错No SecurityManager accessible to the calling code
问题:
springboot项目在配置shiro拦截器之后,启动项目后报错
No SecurityManager accessible to the calling code, either bound to the org.apache.shiro.util.ThreadContext or as a vm static singleton. This is an invalid application configuration.
查了很多资料,对比别人的代码,好像配置没有问题
SecurityUtils对SecurityManager 的操作使用了单例模式,通过SecurityUtils.getSecurityManager能获取唯一可用的SecurityManager ,这个方法正好是在报错中调用失败的方法,所以我们只需要给他初始化一个SecurityManager ,就能解决问题,
添加配置:
@Beanpublic SecurityManager securityManager(Realm realm) {DefaultWebSecurityManager securityManager = new DefaultWebSecurityManager();/* sManager.setSessionManager(sessionManager());*/securityManager.setRealm(realm);System.out.println(securityManager.toString());System.out.println(securityManager.getRealms());SecurityUtils.setSecurityManager(securityManager);//添加此行代码return securityManager;}