解决spring boot shiro的 Consider defining a bean named ‘shiroFilterFactoryBean‘ in your configuration问题

客官°小女子只卖身不卖艺 2023-09-28 21:14 105阅读 0赞

文章目录

    1. 复现问题
    1. 分析问题
    1. 解决问题

1. 复现问题

今天在启动spring boot项目时。出现了如下错误:

在这里插入图片描述

具体错误信息如下:

  1. Description:
  2. Method filterShiroFilterRegistrationBean in org.apache.shiro.spring.config.web.autoconfigure.ShiroWebFilterConfiguration required a bean named 'shiroFilterFactoryBean' that could not be found.
  3. Action:
  4. Consider defining a bean named 'shiroFilterFactoryBean' in your configuration.

上述错误就是我们没有定义一个名为shiroFilterFactoryBeanbean,那么,这个bean有什么作用呢?

2. 分析问题

这是配置shiro出现的问题,具体代码如下:

  1. /**
  2. * @author zby
  3. * @datetime 2022/8/19 09:39
  4. * @desc shiro配置类
  5. */
  6. @Configuration
  7. public class ShiroConfig {
  8. @Autowired
  9. private JwtTokenProvider jwtTokenProvider;
  10. /**
  11. * 设置过滤器
  12. *
  13. * @author zby
  14. * @datetime 2022/8/19:13:06
  15. * @return shiroFilter过滤器
  16. */
  17. @Bean("shiroFilter")
  18. public ShiroFilterFactoryBean shiroFilter(SecurityManager securityManager) {
  19. ShiroFilterFactoryBean shiroFilterFactoryBean = new ShiroFilterFactoryBean();
  20. // 配置安全管理
  21. shiroFilterFactoryBean.setSecurityManager(securityManager);
  22. Map<String, Filter> filters = shiroFilterFactoryBean.getFilters();
  23. filters.put(AUTHC_TOKEN, new JwtAuthFilter(jwtTokenProvider));
  24. // filters.put("anyRole", createRolesFilter());
  25. shiroFilterFactoryBean.setFilters(filters);
  26. shiroFilterFactoryBean.setFilterChainDefinitionMap(
  27. shiroFilterChainDefinition().getFilterChainMap());
  28. return shiroFilterFactoryBean;
  29. }
  30. /**
  31. * 禁用session, 不保存用户登录状态。保证每次请求都重新认证。 需要注意的是,如果用户代码里调用Subject.getSession()还是可以用session。
  32. * 如果要完全禁用,要配合下面的noSessionCreation的Filter来实现
  33. *
  34. * @author zby
  35. * @datetime 2022/8/19:14:20
  36. * @return
  37. */
  38. @Bean
  39. protected SessionStorageEvaluator sessionStorageEvaluator() {
  40. DefaultWebSessionStorageEvaluator sessionStorageEvaluator =
  41. new DefaultWebSessionStorageEvaluator();
  42. sessionStorageEvaluator.setSessionStorageEnabled(false);
  43. return sessionStorageEvaluator;
  44. }
  45. /**
  46. * DbRealm,默认的密码校验算法为BCrypt
  47. *
  48. * @author zby
  49. * @datetime 2022/8/19:14:22
  50. * @return
  51. */
  52. @Bean("dbRealm")
  53. public Realm dbShiroRealm() {
  54. DbShiroRealm myShiroRealm = new DbShiroRealm();
  55. // 将Realm的默认密码校验设置为BCrypt算法
  56. myShiroRealm.setCredentialsMatcher(
  57. (authenticationToken, authenticationInfo) -> {
  58. String password =
  59. new String(((UsernamePasswordToken) authenticationToken).getPassword());
  60. String hashed = (String) authenticationInfo.getCredentials();
  61. return BCrypt.checkpw(password, hashed);
  62. });
  63. return myShiroRealm;
  64. }
  65. }

ShiroConfig类中虽然实例化ShiroFilterFactoryBean对象,但是 @Bean("shiroFilter")里写的是shiroFilter,而不是shiroFilterFactoryBean,故而报错。

3. 解决问题

既然知道了是什么原因造成的,我们便可以将上述代码进行如下修改:

  1. /**
  2. * 设置过滤器
  3. *
  4. * @author zby
  5. * @datetime 2022/8/19:13:06
  6. * @return shiroFilter过滤器
  7. */
  8. @Bean("shiroFilterFactoryBean")
  9. public ShiroFilterFactoryBean shiroFilter(SecurityManager securityManager) {
  10. ShiroFilterFactoryBean shiroFilterFactoryBean = new ShiroFilterFactoryBean();
  11. // 配置安全管理
  12. shiroFilterFactoryBean.setSecurityManager(securityManager);
  13. Map<String, Filter> filters = shiroFilterFactoryBean.getFilters();
  14. filters.put(AUTHC_TOKEN, new JwtAuthFilter(jwtTokenProvider));
  15. // filters.put("anyRole", createRolesFilter());
  16. shiroFilterFactoryBean.setFilters(filters);
  17. shiroFilterFactoryBean.setFilterChainDefinitionMap(
  18. shiroFilterChainDefinition().getFilterChainMap());
  19. return shiroFilterFactoryBean;
  20. }

如此便能成功启动spring boot,如下图所示:

在这里插入图片描述

发表评论

表情:
评论列表 (有 0 条评论,105人围观)

还没有评论,来说两句吧...

相关阅读