|
|
@ -1,7 +1,7 @@ |
|
|
|
package org.jeecg.handler.swagger; |
|
|
|
package org.jeecg.handler.swagger; |
|
|
|
|
|
|
|
|
|
|
|
import org.springframework.beans.factory.annotation.Autowired; |
|
|
|
import org.springframework.beans.factory.annotation.Autowired; |
|
|
|
import org.springframework.context.ApplicationContext; |
|
|
|
import org.springframework.beans.factory.annotation.Value; |
|
|
|
import org.springframework.http.HttpStatus; |
|
|
|
import org.springframework.http.HttpStatus; |
|
|
|
import org.springframework.http.ResponseEntity; |
|
|
|
import org.springframework.http.ResponseEntity; |
|
|
|
import org.springframework.web.bind.annotation.RequestMapping; |
|
|
|
import org.springframework.web.bind.annotation.RequestMapping; |
|
|
@ -10,7 +10,6 @@ import springfox.documentation.swagger.web.*; |
|
|
|
|
|
|
|
|
|
|
|
import java.util.ArrayList; |
|
|
|
import java.util.ArrayList; |
|
|
|
import java.util.List; |
|
|
|
import java.util.List; |
|
|
|
import java.util.regex.Pattern; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/** |
|
|
|
/** |
|
|
|
* swagger聚合接口,三个接口都是 doc.html需要访问的接口 |
|
|
|
* swagger聚合接口,三个接口都是 doc.html需要访问的接口 |
|
|
@ -21,11 +20,11 @@ import java.util.regex.Pattern; |
|
|
|
@RequestMapping("/swagger-resources") |
|
|
|
@RequestMapping("/swagger-resources") |
|
|
|
public class SwaggerResourceController { |
|
|
|
public class SwaggerResourceController { |
|
|
|
private MySwaggerResourceProvider swaggerResourceProvider; |
|
|
|
private MySwaggerResourceProvider swaggerResourceProvider; |
|
|
|
|
|
|
|
/** |
|
|
|
@Autowired |
|
|
|
* 生产环境,关闭swagger文档 |
|
|
|
private ApplicationContext applicationContext; |
|
|
|
*/ |
|
|
|
// 生产环境profile配置模型
|
|
|
|
@Value("${knife4j.production:#{null}}") |
|
|
|
private static final String PRODUCTION_PROFILE_NAME = "prod*"; |
|
|
|
private Boolean production; |
|
|
|
|
|
|
|
|
|
|
|
@Autowired |
|
|
|
@Autowired |
|
|
|
public SwaggerResourceController(MySwaggerResourceProvider swaggerResourceProvider) { |
|
|
|
public SwaggerResourceController(MySwaggerResourceProvider swaggerResourceProvider) { |
|
|
@ -44,22 +43,10 @@ public class SwaggerResourceController { |
|
|
|
|
|
|
|
|
|
|
|
@RequestMapping |
|
|
|
@RequestMapping |
|
|
|
public ResponseEntity<List<SwaggerResource>> swaggerResources() { |
|
|
|
public ResponseEntity<List<SwaggerResource>> swaggerResources() { |
|
|
|
// 如果激活的profile带有生产环境的profile,则屏蔽swagger资源
|
|
|
|
// 是否开启生产环境屏蔽swagger
|
|
|
|
if (isProd()) { |
|
|
|
if (production != null && production) { |
|
|
|
return new ResponseEntity<>(new ArrayList<>(), HttpStatus.OK); |
|
|
|
return new ResponseEntity<>(new ArrayList<>(), HttpStatus.OK); |
|
|
|
} |
|
|
|
} |
|
|
|
return new ResponseEntity<>(swaggerResourceProvider.get(), HttpStatus.OK); |
|
|
|
return new ResponseEntity<>(swaggerResourceProvider.get(), HttpStatus.OK); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
private boolean isProd() { |
|
|
|
|
|
|
|
String[] profiles = applicationContext.getEnvironment().getActiveProfiles(); |
|
|
|
|
|
|
|
Pattern pattern = Pattern.compile(PRODUCTION_PROFILE_NAME); |
|
|
|
|
|
|
|
for (String profile : profiles) { |
|
|
|
|
|
|
|
if (pattern.matcher(profile).find()) { |
|
|
|
|
|
|
|
return true; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return false; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
} |