Chinaunix首页 | 论坛 | 博客
  • 博客访问: 603775
  • 博文数量: 298
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 3077
  • 用 户 组: 普通用户
  • 注册时间: 2019-06-17 10:57
文章分类

全部博文(298)

文章存档

2022年(96)

2021年(201)

2019年(1)

我的朋友

分类: Java

2022-04-06 16:44:31


点击(此处)折叠或打开


  1. package org.fh.config;

  2. import org.apache.shiro.cache.ehcache.EhCacheManager;
  3. import org.apache.shiro.spring.LifecycleBeanPostProcessor;
  4. import org.apache.shiro.spring.security.interceptor.AuthorizationAttributeSourceAdvisor;
  5. import org.apache.shiro.spring.web.ShiroFilterFactoryBean;
  6. import org.apache.shiro.web.mgt.DefaultWebSecurityManager;
  7. import org.fh.realm.MyShiroRealm;
  8. import org.springframework.aop.framework.autoproxy.DefaultAdvisorAutoProxyCreator;
  9. import org.springframework.context.annotation.Bean;
  10. import org.springframework.context.annotation.Configuration;
  11. import org.springframework.transaction.annotation.EnableTransactionManagement;

  12. import net.sf.ehcache.CacheManager;

  13. import java.util.LinkedHashMap;
  14. import java.util.Map;

  15. /**
  16.  * 说明:Shiro 配置
  17.  * 作者:FH Admin
  18.  * from:fhadmin.cn
  19.  */
  20. @Configuration
  21. @EnableTransactionManagement
  22. public class ShiroConfiguration {

  23.     /**
  24.      * ShiroFilterFactoryBean 处理拦截资源文件问题
  25.      * 注意:单独一个ShiroFilterFactoryBean配置是或报错的,因为在
  26.      * 初始化ShiroFilterFactoryBean的时候需要注入:SecurityManager
  27.      *
  28.      * Filter Chain定义说明
  29.      * 1、一个URL可以配置多个Filter,使用逗号分隔
  30.      * 2、当设置多个过滤器时,全部验证通过,才视为通过
  31.      * 3、部分过滤器可指定参数,如perms,roles
  32.      */
  33.     
  34.     @Bean(name = "shiroFilter")
  35.     public ShiroFilterFactoryBean shiroFilterFactoryBean(DefaultWebSecurityManager securityManager) {
  36.         ShiroFilterFactoryBean factoryBean = new MyShiroFilterFactoryBean();
  37.         factoryBean.setSecurityManager(securityManager);
  38.         factoryBean.setLoginUrl("/");                    // 如果不设置默认会自动寻找Web工程根目录下的"/login.jsp"页面
  39.         factoryBean.setSuccessUrl("/main/index");        // 登录成功后要跳转的连接
  40.         factoryBean.setUnauthorizedUrl("/");
  41.         loadShiroFilterChain(factoryBean);
  42.         return factoryBean;
  43.     }
  44.     
  45.     /**
  46.      * 加载ShiroFilter权限控制规则
  47.      */
  48.     private void loadShiroFilterChain(ShiroFilterFactoryBean factoryBean) {
  49.         /** 下面这些规则配置最好配置到配置文件中 */
  50.         Map<String, String> filterChainMap = new LinkedHashMap<String, String>();
  51.         /**
  52.          * authc:该过滤器下的页面必须验证后才能访问,它是Shiro内置的一个拦截器 org.apache.shiro.web.filter.authc.FormAuthenticationFilter
  53.          * anon:它对应的过滤器里面是空的,什么都没做,可以理解为不拦截
  54.          * authc:所有url都必须认证通过才可以访问; anon:所有url都都可以匿名访问
  55.         */
  56.         filterChainMap.put("/404/**", "anon");
  57.         filterChainMap.put("/assets/**", "anon");
  58.         filterChainMap.put("/admin/check", "anon");
  59.         filterChainMap.put("/admin/islogin", "anon");
  60.         filterChainMap.put("/admin/register", "anon");
  61.         filterChainMap.put("/textextraction/add", "anon");
  62.         filterChainMap.put("/**", "authc");
  63.         factoryBean.setFilterChainDefinitionMap(filterChainMap);
  64.     }
  65.     
  66.     @Bean
  67.     public EhCacheManager ehCacheManager(CacheManager cacheManager) {
  68.         EhCacheManager em = new EhCacheManager();
  69.         em.setCacheManager(cacheManager);
  70.         return em;
  71.     }

  72.     @Bean(name = "myShiroRealm")
  73.     public MyShiroRealm myShiroRealm(EhCacheManager ehCacheManager) {
  74.         MyShiroRealm realm = new MyShiroRealm();
  75.         realm.setCacheManager(ehCacheManager);
  76.         return realm;
  77.     }

  78.     @Bean(name = "lifecycleBeanPostProcessor")
  79.     public LifecycleBeanPostProcessor lifecycleBeanPostProcessor() {
  80.         return new LifecycleBeanPostProcessor();
  81.     }

  82.     @Bean
  83.     public DefaultAdvisorAutoProxyCreator defaultAdvisorAutoProxyCreator() {
  84.         DefaultAdvisorAutoProxyCreator creator = new DefaultAdvisorAutoProxyCreator();
  85.         creator.setProxyTargetClass(true);
  86.         return creator;
  87.     }

  88.     @Bean(name = "securityManager")
  89.     public DefaultWebSecurityManager defaultWebSecurityManager(MyShiroRealm realm, EhCacheManager ehCacheManager) {
  90.         DefaultWebSecurityManager securityManager = new DefaultWebSecurityManager();
  91.         securityManager.setRealm(realm);    // 设置realm
  92.         securityManager.setCacheManager(ehCacheManager);
  93.         return securityManager;
  94.     }

  95.     @Bean
  96.     public AuthorizationAttributeSourceAdvisor authorizationAttributeSourceAdvisor(
  97.             DefaultWebSecurityManager securityManager) {
  98.         AuthorizationAttributeSourceAdvisor advisor = new AuthorizationAttributeSourceAdvisor();
  99.         advisor.setSecurityManager(securityManager);
  100.         return advisor;
  101.     }

  102.     /*
  103.      * 1.LifecycleBeanPostProcessor,这是个DestructionAwareBeanPostProcessor的子类,负责org.
  104.      * apache.shiro.util.Initializable类型bean的生命周期的,初始化和销毁。主要是AuthorizingRealm类的子类,
  105.      * 以及EhCacheManager类。
  106.      * 2.HashedCredentialsMatcher,这个类是为了对密码进行编码的,防止密码在数据库里明码保存,当然在登陆认证的生活,
  107.      * 这个类也负责对form里输入的密码进行编码。
  108.      * 3.ShiroRealm,这是个自定义的认证类,继承自AuthorizingRealm,负责用户的认证和权限的处理,可以参考JdbcRealm的实现。
  109.      * 4.EhCacheManager,缓存管理,用户登陆成功后,把用户信息和权限信息缓存起来,然后每次用户请求时,放入用户的session中,
  110.      * 如果不设置这个bean,每个请求都会查询一次数据库。
  111.      * 5.SecurityManager,权限管理,这个类组合了登陆,登出,权限,session的处理,是个比较重要的类。
  112.      * 6.ShiroFilterFactoryBean,是个factorybean,为了生成ShiroFilter。它主要保持了三项数据,
  113.      * securityManager,filters,filterChainDefinitionManager。
  114.      * 7.DefaultAdvisorAutoProxyCreator,Spring的一个bean,由Advisor决定对哪些类的方法进行AOP代理。
  115.      * 8.AuthorizationAttributeSourceAdvisor,shiro里实现的Advisor类,
  116.      * 内部使用AopAllianceAnnotationsAuthorizingMethodInterceptor来拦截用以下注解的方法。
  117.      */

  118. }


阅读(571) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~