|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import java.util.ArrayList; | 
|---|
|  |  |  | import java.util.Arrays; | 
|---|
|  |  |  | import java.util.Collections; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 配置Spring Security | 
|---|
|  |  |  | 
|---|
|  |  |  | .authorizeRequests() | 
|---|
|  |  |  | .requestMatchers(CorsUtils::isPreFlightRequest).permitAll() | 
|---|
|  |  |  | .antMatchers(userSetting.getInterfaceAuthenticationExcludes().toArray(new String[0])).permitAll() | 
|---|
|  |  |  | .antMatchers("/api/user/login", "/index/hook/**", "/swagger-ui/**", "/doc.html").permitAll() | 
|---|
|  |  |  | .antMatchers("/api/user/login", "/index/hook/**","/index/hook/abl/**", "/swagger-ui/**", "/doc.html").permitAll() | 
|---|
|  |  |  | .anyRequest().authenticated() | 
|---|
|  |  |  | // 异常处理器 | 
|---|
|  |  |  | .and() | 
|---|
|  |  |  | 
|---|
|  |  |  | corsConfiguration.setAllowedHeaders(Arrays.asList("*")); | 
|---|
|  |  |  | corsConfiguration.setAllowedMethods(Arrays.asList("*")); | 
|---|
|  |  |  | corsConfiguration.setMaxAge(3600L); | 
|---|
|  |  |  | corsConfiguration.setAllowCredentials(true); | 
|---|
|  |  |  | corsConfiguration.setAllowedOrigins(userSetting.getAllowedOrigins()); | 
|---|
|  |  |  | if (userSetting.getAllowedOrigins() != null && !userSetting.getAllowedOrigins().isEmpty()) { | 
|---|
|  |  |  | corsConfiguration.setAllowCredentials(true); | 
|---|
|  |  |  | corsConfiguration.setAllowedOrigins(userSetting.getAllowedOrigins()); | 
|---|
|  |  |  | }else { | 
|---|
|  |  |  | corsConfiguration.setAllowCredentials(false); | 
|---|
|  |  |  | corsConfiguration.setAllowedOrigins(Collections.singletonList(CorsConfiguration.ALL)); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | corsConfiguration.setExposedHeaders(Arrays.asList(JwtUtils.getHeader())); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | UrlBasedCorsConfigurationSource url = new UrlBasedCorsConfigurationSource(); | 
|---|