|  |  | 
 |  |  | package com.genersoft.iot.vmp.conf.security; | 
 |  |  |  | 
 |  |  | import com.genersoft.iot.vmp.conf.UserSetting; | 
 |  |  | import org.slf4j.Logger; | 
 |  |  | import org.slf4j.LoggerFactory; | 
 |  |  | import org.springframework.beans.factory.annotation.Autowired; | 
 |  |  | import org.springframework.context.annotation.Bean; | 
 |  |  | import org.springframework.context.annotation.Configuration; | 
 |  |  | 
 |  |  | import org.springframework.security.config.annotation.web.configuration.WebSecurityConfigurerAdapter; | 
 |  |  | import org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder; | 
 |  |  |  | 
 |  |  | import java.util.List; | 
 |  |  |  | 
 |  |  | /** | 
 |  |  |  * 配置Spring Security | 
 |  |  |  */ | 
 |  |  | 
 |  |  | @EnableWebSecurity | 
 |  |  | @EnableGlobalMethodSecurity(prePostEnabled = true) | 
 |  |  | public class WebSecurityConfig extends WebSecurityConfigurerAdapter { | 
 |  |  |  | 
 |  |  |     private final static Logger logger = LoggerFactory.getLogger(WebSecurityConfig.class); | 
 |  |  |  | 
 |  |  |     @Autowired | 
 |  |  |     private UserSetting userSetting; | 
 |  |  |  | 
 |  |  |     @Autowired | 
 |  |  |     private DefaultUserDetailsServiceImpl userDetailsService; | 
 |  |  | 
 |  |  |      **/ | 
 |  |  |     @Override | 
 |  |  |     public void configure(WebSecurity web) { | 
 |  |  |         // 可以直接访问的静态数据 | 
 |  |  |         web.ignoring() | 
 |  |  |                 .antMatchers("/") | 
 |  |  |                 .antMatchers("/css/**") | 
 |  |  |                 .antMatchers("/img/**") | 
 |  |  |                 .antMatchers("/fonts/**") | 
 |  |  |                 .antMatchers("/index.html") | 
 |  |  |                 .antMatchers("/doc.html") // "/webjars/**", "/swagger-resources/**", "/v3/api-docs/**" | 
 |  |  |                 .antMatchers("/webjars/**") | 
 |  |  |                 .antMatchers("/swagger-resources/**") | 
 |  |  |                 .antMatchers("/v3/api-docs/**") | 
 |  |  |                 .antMatchers("/js/**"); | 
 |  |  |  | 
 |  |  |         if (!userSetting.isInterfaceAuthentication()) { | 
 |  |  |             web.ignoring().antMatchers("**"); | 
 |  |  |         }else { | 
 |  |  |             // 可以直接访问的静态数据 | 
 |  |  |             web.ignoring() | 
 |  |  |                     .antMatchers("/") | 
 |  |  |                     .antMatchers("/#/**") | 
 |  |  |                     .antMatchers("/static/**") | 
 |  |  |                     .antMatchers("/index.html") | 
 |  |  |                     .antMatchers("/doc.html") // "/webjars/**", "/swagger-resources/**", "/v3/api-docs/**" | 
 |  |  |                     .antMatchers("/webjars/**") | 
 |  |  |                     .antMatchers("/swagger-resources/**") | 
 |  |  |                     .antMatchers("/v3/api-docs/**") | 
 |  |  |                     .antMatchers("/js/**"); | 
 |  |  |             List<String> interfaceAuthenticationExcludes = userSetting.getInterfaceAuthenticationExcludes(); | 
 |  |  |             for (String interfaceAuthenticationExclude : interfaceAuthenticationExcludes) { | 
 |  |  |                 if (interfaceAuthenticationExclude.split("/").length < 4 ) { | 
 |  |  |                     logger.warn("{}不满足两级目录,已忽略", interfaceAuthenticationExclude); | 
 |  |  |                 }else { | 
 |  |  |                     web.ignoring().antMatchers(interfaceAuthenticationExclude); | 
 |  |  |                 } | 
 |  |  |  | 
 |  |  |             } | 
 |  |  |         } | 
 |  |  |     } | 
 |  |  |  | 
 |  |  |     /** | 
 |  |  | 
 |  |  |     @Override | 
 |  |  |     protected void configure(HttpSecurity http) throws Exception { | 
 |  |  |         http.cors().and().csrf().disable(); | 
 |  |  |         // 设置允许添加静态文件 | 
 |  |  |         http.headers().contentTypeOptions().disable(); | 
 |  |  |         http.authorizeRequests() | 
 |  |  |                 // 放行接口 | 
 |  |  |                 .antMatchers("/api/user/login","/index/hook/**").permitAll() |