ShiroConfig.java 2.7KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. package com.yunzhi.demo.shiro;
  2. import com.yunzhi.demo.shiro.filters.JWTFilter;
  3. import com.yunzhi.demo.shiro.matcher.JWTCredentialsMatcher;
  4. import com.yunzhi.demo.shiro.realms.manager.IManagerService;
  5. import com.yunzhi.demo.shiro.realms.manager.ManagerRealm;
  6. import org.apache.shiro.mgt.DefaultSessionStorageEvaluator;
  7. import org.apache.shiro.mgt.DefaultSubjectDAO;
  8. import org.apache.shiro.spring.web.ShiroFilterFactoryBean;
  9. import org.apache.shiro.web.mgt.DefaultWebSecurityManager;
  10. import org.springframework.beans.factory.annotation.Autowired;
  11. import org.springframework.beans.factory.annotation.Value;
  12. import org.springframework.context.annotation.Bean;
  13. import org.springframework.context.annotation.Configuration;
  14. import javax.servlet.Filter;
  15. import java.util.HashMap;
  16. import java.util.Map;
  17. @Configuration
  18. public class ShiroConfig {
  19. @Autowired
  20. IManagerService iManagerService;
  21. @Value("${shiro.unauthorizedUrl}")
  22. private String unauthorizedUrl;
  23. @Value("#{${shiro.filterRuleMap}}")
  24. private Map<String, String> filterRuleMap;
  25. @Bean
  26. public ManagerRealm managerRealm() {
  27. ManagerRealm realm = new ManagerRealm();
  28. realm.setManagerService(iManagerService);
  29. realm.setCredentialsMatcher(new JWTCredentialsMatcher());
  30. return realm;
  31. }
  32. @Bean("shiroFilterFactoryBean")
  33. public ShiroFilterFactoryBean factory(DefaultWebSecurityManager securityManager) {
  34. ShiroFilterFactoryBean factoryBean = new ShiroFilterFactoryBean();
  35. // 手动加入 JWTFilter
  36. JWTFilter jwtFilter = new JWTFilter();
  37. jwtFilter.setUnauthorizedUrl(unauthorizedUrl);
  38. Map<String, Filter> filterMap = new HashMap<>();
  39. filterMap.put("jwt", jwtFilter);
  40. factoryBean.setFilters(filterMap);
  41. factoryBean.setSecurityManager(securityManager);
  42. factoryBean.setUnauthorizedUrl(unauthorizedUrl);
  43. factoryBean.setFilterChainDefinitionMap(filterRuleMap);
  44. return factoryBean;
  45. }
  46. @Bean("securityManager")
  47. public DefaultWebSecurityManager securityManager() {
  48. DefaultWebSecurityManager manager = new DefaultWebSecurityManager();
  49. // Use your own realm
  50. manager.setRealm(managerRealm());
  51. /*
  52. * 禁用 session
  53. */
  54. DefaultSubjectDAO subjectDAO = new DefaultSubjectDAO();
  55. DefaultSessionStorageEvaluator defaultSessionStorageEvaluator = new DefaultSessionStorageEvaluator();
  56. defaultSessionStorageEvaluator.setSessionStorageEnabled(false);
  57. subjectDAO.setSessionStorageEvaluator(defaultSessionStorageEvaluator);
  58. manager.setSubjectDAO(subjectDAO);
  59. return manager;
  60. }
  61. }