问题:
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 ,就能解决问题,
添加配置:
@Bean
public 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;
}