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

1. 复现问题

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

在这里插入图片描述

具体错误信息如下:

Description:

Method filterShiroFilterRegistrationBean in org.apache.shiro.spring.config.web.autoconfigure.ShiroWebFilterConfiguration required a bean named 'shiroFilterFactoryBean' that could not be found.


Action:

Consider defining a bean named 'shiroFilterFactoryBean' in your configuration.

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

2. 分析问题

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

/**
 * @author zby
 * @datetime 2022/8/19 09:39
 * @desc shiro配置类
 */
@Configuration
public class ShiroConfig {

  @Autowired
  private JwtTokenProvider jwtTokenProvider;
  
  /**
   * 设置过滤器
   *
   * @author zby
   * @datetime 2022/8/19:13:06
   * @return shiroFilter过滤器
   */
  @Bean("shiroFilter")
  public ShiroFilterFactoryBean shiroFilter(SecurityManager securityManager) {
    ShiroFilterFactoryBean shiroFilterFactoryBean = new ShiroFilterFactoryBean();
    // 配置安全管理
    shiroFilterFactoryBean.setSecurityManager(securityManager);
    Map<String, Filter> filters = shiroFilterFactoryBean.getFilters();
    filters.put(AUTHC_TOKEN, new JwtAuthFilter(jwtTokenProvider));
    //        filters.put("anyRole", createRolesFilter());
    shiroFilterFactoryBean.setFilters(filters);
    shiroFilterFactoryBean.setFilterChainDefinitionMap(
        shiroFilterChainDefinition().getFilterChainMap());
    return shiroFilterFactoryBean;
  }

  /**
   * 禁用session, 不保存用户登录状态。保证每次请求都重新认证。 需要注意的是,如果用户代码里调用Subject.getSession()还是可以用session。
   * 如果要完全禁用,要配合下面的noSessionCreation的Filter来实现
   *
   * @author zby
   * @datetime 2022/8/19:14:20
   * @return
   */
  @Bean
  protected SessionStorageEvaluator sessionStorageEvaluator() {
    DefaultWebSessionStorageEvaluator sessionStorageEvaluator =
        new DefaultWebSessionStorageEvaluator();
    sessionStorageEvaluator.setSessionStorageEnabled(false);
    return sessionStorageEvaluator;
  }
  
  /**
   * DbRealm,默认的密码校验算法为BCrypt
   *
   * @author zby
   * @datetime 2022/8/19:14:22
   * @return
   */
  @Bean("dbRealm")
  public Realm dbShiroRealm() {
    DbShiroRealm myShiroRealm = new DbShiroRealm();
    // 将Realm的默认密码校验设置为BCrypt算法
    myShiroRealm.setCredentialsMatcher(
            (authenticationToken, authenticationInfo) -> {
              String password =
                  new String(((UsernamePasswordToken) authenticationToken).getPassword());
              String hashed = (String) authenticationInfo.getCredentials();
              return BCrypt.checkpw(password, hashed);
            });
    return myShiroRealm;
  }
}

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

3. 解决问题

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

/**
 * 设置过滤器
 *
 * @author zby
 * @datetime 2022/8/19:13:06
 * @return shiroFilter过滤器
 */
@Bean("shiroFilterFactoryBean")
public ShiroFilterFactoryBean shiroFilter(SecurityManager securityManager) {
    ShiroFilterFactoryBean shiroFilterFactoryBean = new ShiroFilterFactoryBean();
  // 配置安全管理
  shiroFilterFactoryBean.setSecurityManager(securityManager);
  Map<String, Filter> filters = shiroFilterFactoryBean.getFilters();
  filters.put(AUTHC_TOKEN, new JwtAuthFilter(jwtTokenProvider));
  //        filters.put("anyRole", createRolesFilter());
  shiroFilterFactoryBean.setFilters(filters);
  shiroFilterFactoryBean.setFilterChainDefinitionMap(
      shiroFilterChainDefinition().getFilterChainMap());
  return shiroFilterFactoryBean;
}

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

在这里插入图片描述

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

互联网全栈开发实战

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

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

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

打赏作者

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

抵扣说明:

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

余额充值