ShiroConfig.java 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139
  1. package org.jeecg.config;
  2. import java.util.HashMap;
  3. import java.util.LinkedHashMap;
  4. import java.util.Map;
  5. import javax.servlet.Filter;
  6. import org.apache.shiro.mgt.DefaultSessionStorageEvaluator;
  7. import org.apache.shiro.mgt.DefaultSubjectDAO;
  8. import org.apache.shiro.mgt.SecurityManager;
  9. import org.apache.shiro.spring.LifecycleBeanPostProcessor;
  10. import org.apache.shiro.spring.security.interceptor.AuthorizationAttributeSourceAdvisor;
  11. import org.apache.shiro.spring.web.ShiroFilterFactoryBean;
  12. import org.apache.shiro.web.mgt.DefaultWebSecurityManager;
  13. import org.jeecg.common.exception.JeecgBootException;
  14. import org.jeecg.common.util.ProductAuthUtil;
  15. import org.jeecg.modules.shiro.authc.MyRealm;
  16. import org.jeecg.modules.shiro.authc.aop.JwtFilter;
  17. import org.jeecg.modules.shiro.authc.aop.ResourceCheckFilter;
  18. import org.springframework.aop.framework.autoproxy.DefaultAdvisorAutoProxyCreator;
  19. import org.springframework.context.annotation.Bean;
  20. import org.springframework.context.annotation.Configuration;
  21. import org.springframework.context.annotation.DependsOn;
  22. /**
  23. * @author: Scott
  24. * @date: 2018/2/7
  25. * @description: shiro 配置类
  26. */
  27. @Configuration
  28. public class ShiroConfig {
  29. /**
  30. * Filter Chain定义说明
  31. *
  32. * 1、一个URL可以配置多个Filter,使用逗号分隔
  33. * 2、当设置多个过滤器时,全部验证通过,才视为通过
  34. * 3、部分过滤器可指定参数,如perms,roles
  35. */
  36. @Bean("shiroFilter")
  37. public ShiroFilterFactoryBean shiroFilter(SecurityManager securityManager) {
  38. ShiroFilterFactoryBean shiroFilterFactoryBean = new ShiroFilterFactoryBean();
  39. shiroFilterFactoryBean.setSecurityManager(securityManager);
  40. if (!ProductAuthUtil.verify()) {
  41. throw new JeecgBootException("程序异常,请联系供应商");
  42. }
  43. // 拦截器
  44. Map<String, String> filterChainDefinitionMap = new LinkedHashMap<String, String>();
  45. // 配置不会被拦截的链接 顺序判断
  46. filterChainDefinitionMap.put("/sys/login", "anon"); //登录接口排除
  47. filterChainDefinitionMap.put("/auth/2step-code", "anon");//登录验证码
  48. filterChainDefinitionMap.put("/workingStatistics/fbsWorkingStatistics/**", "anon"); //工时接口
  49. filterChainDefinitionMap.put("/fbs**/**/**", "anon"); //工时接口
  50. filterChainDefinitionMap.put("/test/jeecgDemo/**", "anon"); //测试接口
  51. filterChainDefinitionMap.put("/test/jeecgOrderMain/**", "anon"); //测试接口
  52. filterChainDefinitionMap.put("/**/exportXls", "anon"); //导出接口
  53. filterChainDefinitionMap.put("/**/importExcel", "anon"); //导入接口
  54. filterChainDefinitionMap.put("/sys/common/view/**", "anon");//图片预览不限制token
  55. filterChainDefinitionMap.put("/sys/common/downloadFile/**", "anon");//文件下载不限制token
  56. filterChainDefinitionMap.put("/", "anon");
  57. filterChainDefinitionMap.put("/**/*.js", "anon");
  58. filterChainDefinitionMap.put("/**/*.css", "anon");
  59. filterChainDefinitionMap.put("/**/*.html", "anon");
  60. filterChainDefinitionMap.put("/**/*.svg", "anon");
  61. filterChainDefinitionMap.put("/**/*.jpg", "anon");
  62. filterChainDefinitionMap.put("/**/*.png", "anon");
  63. filterChainDefinitionMap.put("/**/*.ico", "anon");
  64. filterChainDefinitionMap.put("/druid/**", "anon");
  65. filterChainDefinitionMap.put("/swagger-ui.html", "anon");
  66. filterChainDefinitionMap.put("/swagger**/**", "anon");
  67. filterChainDefinitionMap.put("/webjars/**", "anon");
  68. filterChainDefinitionMap.put("/v2/**", "anon");
  69. //性能监控
  70. filterChainDefinitionMap.put("/actuator/metrics/**", "anon");
  71. filterChainDefinitionMap.put("/actuator/httptrace/**", "anon");
  72. filterChainDefinitionMap.put("/redis/**", "anon");
  73. //TODO 排除Online请求
  74. filterChainDefinitionMap.put("/auto/cgform/**", "anon");
  75. filterChainDefinitionMap.put("/online/cgreport/api/exportXls/**", "anon");
  76. // 添加自己的过滤器并且取名为jwt
  77. Map<String, Filter> filterMap = new HashMap<String, Filter>(1);
  78. filterMap.put("jwt", new JwtFilter());
  79. shiroFilterFactoryBean.setFilters(filterMap);
  80. // <!-- 过滤链定义,从上向下顺序执行,一般将/**放在最为下边
  81. filterChainDefinitionMap.put("/**", "jwt");
  82. // 未授权界面;
  83. shiroFilterFactoryBean.setUnauthorizedUrl("/403");
  84. shiroFilterFactoryBean.setFilterChainDefinitionMap(filterChainDefinitionMap);
  85. return shiroFilterFactoryBean;
  86. }
  87. @Bean("securityManager")
  88. public DefaultWebSecurityManager securityManager(MyRealm myRealm) {
  89. DefaultWebSecurityManager securityManager = new DefaultWebSecurityManager();
  90. securityManager.setRealm(myRealm);
  91. /*
  92. * 关闭shiro自带的session,详情见文档
  93. * http://shiro.apache.org/session-management.html#SessionManagement-
  94. * StatelessApplications%28Sessionless%29
  95. */
  96. DefaultSubjectDAO subjectDAO = new DefaultSubjectDAO();
  97. DefaultSessionStorageEvaluator defaultSessionStorageEvaluator = new DefaultSessionStorageEvaluator();
  98. defaultSessionStorageEvaluator.setSessionStorageEnabled(false);
  99. subjectDAO.setSessionStorageEvaluator(defaultSessionStorageEvaluator);
  100. securityManager.setSubjectDAO(subjectDAO);
  101. return securityManager;
  102. }
  103. /**
  104. * 下面的代码是添加注解支持
  105. * @return
  106. */
  107. @Bean
  108. @DependsOn("lifecycleBeanPostProcessor")
  109. public DefaultAdvisorAutoProxyCreator defaultAdvisorAutoProxyCreator() {
  110. DefaultAdvisorAutoProxyCreator defaultAdvisorAutoProxyCreator = new DefaultAdvisorAutoProxyCreator();
  111. defaultAdvisorAutoProxyCreator.setProxyTargetClass(true);
  112. return defaultAdvisorAutoProxyCreator;
  113. }
  114. @Bean
  115. public LifecycleBeanPostProcessor lifecycleBeanPostProcessor() {
  116. return new LifecycleBeanPostProcessor();
  117. }
  118. @Bean
  119. public AuthorizationAttributeSourceAdvisor authorizationAttributeSourceAdvisor(DefaultWebSecurityManager securityManager) {
  120. AuthorizationAttributeSourceAdvisor advisor = new AuthorizationAttributeSourceAdvisor();
  121. advisor.setSecurityManager(securityManager);
  122. return advisor;
  123. }
  124. }