• Shiro学习(3)shiroConfig配置类


    一、Shiro配置类创建流程

    创建shiro配置函数ShiroConfig可以分为四大块:
    1、创建realm
    2、创建安全管理器
    3、配置shiro过滤器工厂
    4、开启对shiro注解的支持

    1、创建Realm

    可以直接创建CustonRealm这个对象,也可以通过Realm创建。

    	@Bean
        public Realm getRealm(){
            CustonRealm custonRealm = new CustonRealm();
            return custonRealm;
        }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    2、创建安全管理器

    注意SecurityManager导包,是shiro的SecurityManager。
    配置原理:对SecurityManager来说他管理了所有的Realm,通过这些代码获取了Realm管理信息

    	@Bean
        public SecurityManager getSecurityManager(Realm realm){
            DefaultWebSecurityManager securityManager = new DefaultWebSecurityManager();
            securityManager.setRealm(realm);
            return securityManager;
        }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    3、配置shiro过滤器工厂

    在web程序中,shiro进行权限控制是通过一组过滤器集合进行的操作。
    过滤器配置需要有以下几步:
    1、创建过滤器工厂
    2、设置安全管理器
    3、通用配置(跳转登录页面,为授权跳转的页面)
    4、设置过滤器集合

    	@Bean
        public ShiroFilterFactoryBean shiroFilter(SecurityManager securityManager){
            //1、创建过滤器工厂
            ShiroFilterFactoryBean filterFactory = new ShiroFilterFactoryBean();
            //2、设置安全管理器
            filterFactory.setSecurityManager(securityManager);
            //3、通用配置(跳转登录页面,为授权跳转的页面)
            filterFactory.setLoginUrl("/autherror?code=1");//授权成功,跳转的url地址
            filterFactory.setUnauthorizedUrl("/autherror?code=2");//未授权的跳转页面
            //4、设置过滤器集合
            /**
             * 设置所有过滤器,使用有顺序的map
             *  key->拦截url地址
             *  value-> 过滤器类型
             */
            Map filterMap = new LinkedHashMap<>();
            filterMap.put("/user/home","anon");//无需认证即可访问
            filterMap.put("/user/**","authc");//当前请求地址必须认证后访问
            filterFactory.setFilterChainDefinitionMap(filterMap);
            return filterFactory;
        }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    4、开启对shiro注解的支持

    固定配置

    	@Bean
        public AuthorizationAttributeSourceAdvisor authorizationAttributeSourceAdvisor(SecurityManager securityManager) {
            AuthorizationAttributeSourceAdvisor advisor = new AuthorizationAttributeSourceAdvisor();
            advisor.setSecurityManager(securityManager);
            return advisor;
        }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
  • 相关阅读:
    Hbase基本使用,读写原理,性能优化学习
    【Vite 实践】Vite 库模式能满足你吗?或许你需要统一构建
    StyleLint入门配置
    AUTOSAR知识点 之 Dcm (一):基础知识梳理
    ELK学习总结
    应用--WebApplication
    C++ Reference: Standard C++ Library reference: C Library: cstdio
    静态链表习题初入门之(A-B)∪(B-A)
    Leetcode第142题—环形链表Ⅱ
    day05_流程控制语句
  • 原文地址:https://blog.csdn.net/m0_67403240/article/details/126496326