springboot整合shiro的配置类

该博客详细介绍了如何在SpringBoot中配置Shiro,包括ShiroFilterFactoryBean的设置,如权限配置、拦截器、未授权页面以及加密方式。同时,文章也展示了自定义Realm的实现和安全管理配置。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


@Configuration
public class ShiroConfig {
    public ShiroConfig(){
        System.out.println("ShiroConfig init ......");
    }
    /**
     * shiro过滤器配置
     */
    @Bean
    public ShiroFilterFactoryBean shiroFilter(SecurityManager securityManager){
        System.out.println("ShiroConfiguration.shirFilter()");
        ShiroFilterFactoryBean shiroFilterFactoryBean = new ShiroFilterFactoryBean();
        shiroFilterFactoryBean.setSecurityManager(securityManager);
        //拦截器
        Map<String,String> filterChainDefinitionMap = new LinkedHashMap<String, String>();
        //权限配置
        filterChainDefinitionMap.put("/user/adduser","perms[ClinetUser:name]");
        //配置不会被拦截的链接 顺序判断 相关静态资源
        filterChainDefinitionMap.put("/assets/**","anon");
        filterChainDefinitionMap.put("/css/**","anon");
        filterChainDefinitionMap.put("/font/**","anon");
        filterChainDefinitionMap.put("/images/**","anon");
        filterChainDefinitionMap.put("/js/**","anon");
        filterChainDefinitionMap.put("/products/**","anon");
        filterChainDefinitionMap.put("/Widget/**","anon");
        //配置退出其中退出的代码shiro 已经帮我们实现了
        filterChainDefinitionMap.put("/logout","logout");
        //所有的url都必须认证通过才可以访问
        filterChainDefinitionMap.put("/**","authc");
        //未授权界面
        shiroFilterFactoryBean.setUnauthorizedUrl("/403");
        shiroFilterFactoryBean.setFilterChainDefinitionMap(filterChainDefinitionMap);
        return shiroFilterFactoryBean;
    }
    /**
     * 加密方式配置
     *
     */
    @Bean
    public HashedCredentialsMatcher hashedCredentialsMatcher(){
        HashedCredentialsMatcher hashedCredentialsMatcher = new HashedCredentialsMatcher();
        hashedCredentialsMatcher.setHashAlgorithmName("md5");
        hashedCredentialsMatcher.setHashIterations(2);
        return  hashedCredentialsMatcher;
    }

    /**
     * 认证器配置
     *
     */
    @Bean
    public MyShiroRelam myShiroRelam(){
    MyShiroRelam myShiroRelam = new MyShiroRelam();
    return myShiroRelam;
}
    /**
     * 安全管理配置
     *
     */
    @Bean
    public SecurityManager securityManager(){
        DefaultWebSecurityManager securityManager = new DefaultWebSecurityManager();
       securityManager.setRealm(myShiroRealm());
        return securityManager;
    }

    private Realm myShiroRealm() {
        return myShiroRelam();
    }

    /**
     *开启@RequirePermission注解的配置
     * @param securityManager
     *
     */
    @Bean
    public AuthorizationAttributeSourceAdvisor auththorizationAttributeSourceAdvisor(SecurityManager securityManager){
        AuthorizationAttributeSourceAdvisor auththorizationAttributeSourceAdvisor = new AuthorizationAttributeSourceAdvisor();
        auththorizationAttributeSourceAdvisor.setSecurityManager(securityManager);
        return auththorizationAttributeSourceAdvisor;
    }
}
 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值