SecurityConfig.java 7.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161
  1. package com.backendsys.modules.common.config.security;
  2. import cn.hutool.core.util.ArrayUtil;
  3. //import com.backendsys.modules.common.KLingAiConfig.security.filter.AnonymousFilter;
  4. import com.backendsys.modules.common.config.security.annotations.AnonymousProperties;
  5. import com.backendsys.modules.common.config.security.filter.CaptchaVerficationFilter;
  6. import com.backendsys.modules.common.config.security.filter.JwtAuthenticationFilter;
  7. import lombok.RequiredArgsConstructor;
  8. import org.springframework.beans.factory.annotation.Autowired;
  9. import org.springframework.beans.factory.annotation.Value;
  10. import org.springframework.context.annotation.Bean;
  11. import org.springframework.context.annotation.Configuration;
  12. import org.springframework.security.config.annotation.method.configuration.EnableMethodSecurity;
  13. import org.springframework.security.config.annotation.web.builders.HttpSecurity;
  14. import org.springframework.security.config.annotation.web.configuration.EnableWebSecurity;
  15. import org.springframework.security.config.annotation.web.configurers.AbstractHttpConfigurer;
  16. import org.springframework.security.config.http.SessionCreationPolicy;
  17. import org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder;
  18. import org.springframework.security.crypto.password.PasswordEncoder;
  19. import org.springframework.security.web.SecurityFilterChain;
  20. import org.springframework.security.web.authentication.UsernamePasswordAuthenticationFilter;
  21. @Configuration
  22. @EnableWebSecurity
  23. @RequiredArgsConstructor
  24. // @EnableGlobalMethodSecurity(prePostEnabled = true, securedEnabled = true)
  25. @EnableMethodSecurity(securedEnabled = true)
  26. public class SecurityConfig {
  27. private final JwtAuthenticationFilter jwtAuthenticationFilter;
  28. // private final AnonymousFilter anonymousFilter;
  29. @Bean
  30. public PasswordEncoder getPw() {
  31. return new BCryptPasswordEncoder();
  32. }
  33. @Bean
  34. public CaptchaVerficationFilter CaptchaVerficationFilter() {
  35. return new CaptchaVerficationFilter();
  36. }
  37. @Value("${MAXIMUM_SESSIONS}")
  38. private Integer MAXIMUM_SESSIONS;
  39. @Value("#{'${whitelist.static}'.split(',')}")
  40. private final String[] STATIC_WHITELIST;
  41. @Value("#{'${whitelist.jwt}'.split(',')}")
  42. private final String[] JWT_WHITELIST;
  43. // 获得配置文件中的白名单变量,注意首尾要去空格
  44. private String[] getWhiteUrls() {
  45. String [] result = ArrayUtil.addAll(JWT_WHITELIST, STATIC_WHITELIST);
  46. for (int i = 0; i < result.length; i++) {
  47. result[i] = result[i].trim();
  48. }
  49. return result;
  50. }
  51. // Spring-Security 更新日志文档 (升级版本是否对语法有影响):
  52. // https://docs.spring.io/spring-security/site/docs/current/api/org/springframework/security/config/web/server/ServerHttpSecurity.html
  53. @Autowired
  54. private AnonymousProperties anonymousProperties;
  55. @Bean
  56. public SecurityFilterChain securityFilterChain(HttpSecurity http) throws Exception {
  57. // 在配置文件中的 白名单地址
  58. String[] whiteUrls = getWhiteUrls();
  59. // System.out.println(Arrays.toString(whiteUrls));
  60. // 使用了 @Anonymous 注解的地址
  61. String[] anonymousUrls = anonymousProperties.getUrls();
  62. // System.out.println("(SecurityConfig) anonymousUrls:");
  63. // System.out.println(Arrays.toString(anonymousUrls));
  64. // 路径授权
  65. http
  66. // 禁用csrf(防止跨站请求伪造攻击)
  67. //.csrf(csrf -> csrf.disable())
  68. .csrf(AbstractHttpConfigurer::disable)
  69. // 设置白名单
  70. .authorizeHttpRequests((authorizeHttpRequests) ->
  71. authorizeHttpRequests
  72. // .requestMatchers("/api/**").permitAll()
  73. // .requestMatchers(whiteUrls).permitAll()
  74. // .requestMatchers(anonymousUrls).permitAll()
  75. // .anyRequest().authenticated()
  76. .anyRequest().permitAll() // 开放所有mvc页面
  77. )
  78. // "/api/auth/login",
  79. // 对于其他任何请求,都保护起来
  80. // 禁用缓存
  81. .sessionManagement((sessionManagement) ->
  82. sessionManagement
  83. .sessionConcurrency((sessionConcurrency) ->
  84. sessionConcurrency
  85. .maximumSessions(MAXIMUM_SESSIONS)
  86. // 限制用户会话并发数量 (防止恶意用户同时使用多个会话进行非法操作)
  87. //.expiredUrl("/login?expired")
  88. )
  89. .sessionCreationPolicy(SessionCreationPolicy.STATELESS)
  90. )
  91. // .addFilterBefore(anonymousFilter, UsernamePasswordAuthenticationFilter.class)
  92. .addFilterBefore(jwtAuthenticationFilter, UsernamePasswordAuthenticationFilter.class)
  93. ;
  94. // 使用无状态session,即不使用session缓存数据
  95. // .logout()
  96. // .logoutUrl("/api/auth/logout")
  97. // .addLogoutHandler(new CustomLogoutHandler())
  98. // .logoutSuccessHandler(((request, response, authentication) -> SecurityContextHolder.clearContext()));
  99. // .authorizeHttpRequests(
  100. // (requests) -> requests
  101. // // 放行路径 (6.0 下,antMatchers 已弃用,使用 requestMatchers 代替)
  102. // .requestMatchers("/", "/api/**").permitAll()
  103. // // 放行静态资源 (/resources/static/images/p1.jpg)
  104. // .requestMatchers("/*.ico", "/images/**").permitAll()
  105. // // ,
  106. // .anyRequest().authenticated()
  107. // )
  108. // .formLogin((form) ->
  109. // form
  110. // // 进入登录跳转页面
  111. // .loginPage("/login")
  112. //
  113. // // 自定义拦截器 (错误/成功)
  114. // .failureHandler(new CustomAuthenticationFailureHandler())
  115. // .successHandler(new CustomAuthenticationSuccessHandler())
  116. //
  117. // .permitAll()
  118. // ).logout((logout) ->
  119. // logout
  120. // // 退出登录后跳转页面
  121. // .logoutSuccessUrl("/")
  122. // .permitAll()
  123. // );
  124. // http.cors(); // 允许跨域
  125. return http.build();
  126. }
  127. // 跨域资源配置
  128. //@Bean
  129. //public CorsConfigurationSource corsConfigurationSource() {
  130. // CorsConfiguration configuration = new CorsConfiguration();
  131. // configuration.setAllowedOrigins(Collections.singletonList("*")); // Arrays.asList("*")
  132. // configuration.setAllowedMethods(Collections.singletonList("*"));
  133. // // "GET", "POST", "OPTIONS", "DELETE", "PUT", "PATCH"
  134. // configuration.setAllowedHeaders(Arrays.asList("authorization", "content-type", "x-auth-token"));
  135. // UrlBasedCorsConfigurationSource source = new UrlBasedCorsConfigurationSource();
  136. // source.registerCorsConfiguration("/**", configuration);
  137. // return source;
  138. //}
  139. }