spring-boot-shiro自定义过滤器无法正常工作

问题描述 投票:0回答:1

所有

spring-boot run error:没有名称为'userAuthorizationFilter'的过滤器应用于可用过滤器池中的链[/ **]。确保首先使用addFilter方法注册了具有该名称/路径的过滤器。

  <dependency>
        <groupId>org.apache.shiro</groupId>
        <artifactId>shiro-spring-boot-web-starter</artifactId>
        <version>1.4.0</version>
  </dependency>

使RO config.Java:

@Configuration
public class ShiroConfig{

@Bean
public ShiroFilterChainDefinition shiroFilterChainDefinition() {
    DefaultShiroFilterChainDefinition chainDefinition = new DefaultShiroFilterChainDefinition();

    chainDefinition.addPathDefinition("/css/**", DefaultFilter.anon.name());
    chainDefinition.addPathDefinition("/js/**", DefaultFilter.anon.name());
    chainDefinition.addPathDefinition("/images/**", DefaultFilter.anon.name());
    chainDefinition.addPathDefinition("/favicon.ico", DefaultFilter.anon.name());


    chainDefinition.addPathDefinition("/logout", DefaultFilter.logout.name());
    chainDefinition.addPathDefinition("/login", DefaultFilter.anon.name());

    chainDefinition.addPathDefinition("/**", "userAuthorizationFilter");
    return chainDefinition;
}

@Bean(name = "userAuthorizationFilter")
public UserAuthorizationFilter userAuthorizationFilter(){
    return new UserAuthorizationFilter();
}


@Bean
public UserRealm userRealm() {
    UserRealm userRealm = new UserRealm();
    return userRealm;
}

@Bean
public DefaultWebSecurityManager securityManager() {
    DefaultWebSecurityManager manager = new DefaultWebSecurityManager();
    manager.setRealm(userRealm());
    return manager;
}

}

[mvn spring-boot:run]错误日志:

Caused by: java.lang.IllegalArgumentException: There is no filter with name 'userAuthorizationFilter' to apply to chain [/**] in the pool of available Filters.  Ensure a filter with that name/path has first been registered with the addFilter method(s).
at org.apache.shiro.web.filter.mgt.DefaultFilterChainManager.addToChain(DefaultFilterChainManager.java:265)
at org.apache.shiro.web.filter.mgt.DefaultFilterChainManager.createChain(DefaultFilterChainManager.java:148)
at org.apache.shiro.spring.web.ShiroFilterFactoryBean.createFilterChainManager(ShiroFilterFactoryBean.java:397)
at org.apache.shiro.spring.web.ShiroFilterFactoryBean.createInstance(ShiroFilterFactoryBean.java:437)
at org.apache.shiro.spring.web.ShiroFilterFactoryBean.getObject(ShiroFilterFactoryBean.java:343)
at org.springframework.beans.factory.support.FactoryBeanRegistrySupport.doGetObjectFromFactoryBean(FactoryBeanRegistrySupport.java:168)
... 43 common frames omitted

我错过了配置的重要部分吗?

任何帮助,将不胜感激。谢谢。

java spring spring-boot shiro
1个回答
2
投票

您似乎没有为自己的过滤器“userAuthorizationFilter”分配别名;

您应该在ShiroFilterFactoryBean初始化中定义别名。

@Bean(name = "shiroFilter")
public ShiroFilterFactoryBean getShiroFilterFactoryBean(DefaultWebSecurityManager securityManager, UserAuthorizationFilter  authorizationFilter) {

    ShiroFilterFactoryBean shiroFilterFactoryBean = new ShiroFilterFactoryBean();
    shiroFilterFactoryBean.setSecurityManager(securityManager);
    //...........................some other codes
    HashMap<String, Filter> map = new HashMap<>();
    map.put("userAuthorizationFilter",authorizationFilter);
    shiroFilterFactoryBean.setFilters(map);

    //...........................some other codes
    return shiroFilterFactoryBean;
}
© www.soinside.com 2019 - 2024. All rights reserved.