SwaggerConfig.java 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124
  1. package com.ruoyi.framework.config;
  2. import java.util.ArrayList;
  3. import java.util.List;
  4. import org.springframework.beans.factory.annotation.Autowired;
  5. import org.springframework.beans.factory.annotation.Value;
  6. import org.springframework.context.annotation.Bean;
  7. import org.springframework.context.annotation.Configuration;
  8. import io.swagger.annotations.ApiOperation;
  9. import springfox.documentation.builders.ApiInfoBuilder;
  10. import springfox.documentation.builders.PathSelectors;
  11. import springfox.documentation.builders.RequestHandlerSelectors;
  12. import springfox.documentation.service.ApiInfo;
  13. import springfox.documentation.service.ApiKey;
  14. import springfox.documentation.service.AuthorizationScope;
  15. import springfox.documentation.service.Contact;
  16. import springfox.documentation.service.SecurityReference;
  17. import springfox.documentation.spi.DocumentationType;
  18. import springfox.documentation.spi.service.contexts.SecurityContext;
  19. import springfox.documentation.spring.web.plugins.Docket;
  20. import springfox.documentation.swagger2.annotations.EnableSwagger2;
  21. /**
  22. * Swagger2的接口配置
  23. *
  24. * @author ruoyi
  25. */
  26. @Configuration
  27. @EnableSwagger2
  28. public class SwaggerConfig
  29. {
  30. /** 系统基础配置 */
  31. @Autowired
  32. private RuoYiConfig ruoyiConfig;
  33. /** 是否开启swagger */
  34. @Value("${swagger.enabled}")
  35. private boolean enabled;
  36. /** 设置请求的统一前缀 */
  37. @Value("${swagger.pathMapping}")
  38. private String pathMapping;
  39. /**
  40. * 创建API
  41. */
  42. @Bean
  43. public Docket createRestApi()
  44. {
  45. return new Docket(DocumentationType.SWAGGER_2)
  46. // 是否启用Swagger
  47. .enable(enabled)
  48. // 用来创建该API的基本信息,展示在文档的页面中(自定义展示的信息)
  49. .apiInfo(apiInfo())
  50. // 设置哪些接口暴露给Swagger展示
  51. .select()
  52. // 扫描所有有注解的api,用这种方式更灵活
  53. .apis(RequestHandlerSelectors.withMethodAnnotation(ApiOperation.class))
  54. // 扫描指定包中的swagger注解
  55. // .apis(RequestHandlerSelectors.basePackage("com.ruoyi.project.tool.swagger"))
  56. // 扫描所有 .apis(RequestHandlerSelectors.any())
  57. .paths(PathSelectors.any())
  58. .build()
  59. /* 设置安全模式,swagger可以设置访问token */
  60. .securitySchemes(securitySchemes())
  61. .securityContexts(securityContexts())
  62. .pathMapping(pathMapping);
  63. }
  64. /**
  65. * 安全模式,这里指定token通过Authorization头请求头传递
  66. */
  67. private List<ApiKey> securitySchemes()
  68. {
  69. List<ApiKey> apiKeyList = new ArrayList<ApiKey>();
  70. apiKeyList.add(new ApiKey("Authorization", "Authorization", "header"));
  71. return apiKeyList;
  72. }
  73. /**
  74. * 安全上下文
  75. */
  76. private List<SecurityContext> securityContexts()
  77. {
  78. List<SecurityContext> securityContexts = new ArrayList<>();
  79. securityContexts.add(
  80. SecurityContext.builder()
  81. .securityReferences(defaultAuth())
  82. .forPaths(PathSelectors.regex("^(?!auth).*$"))
  83. .build());
  84. return securityContexts;
  85. }
  86. /**
  87. * 默认的安全上引用
  88. */
  89. private List<SecurityReference> defaultAuth()
  90. {
  91. AuthorizationScope authorizationScope = new AuthorizationScope("global", "accessEverything");
  92. AuthorizationScope[] authorizationScopes = new AuthorizationScope[1];
  93. authorizationScopes[0] = authorizationScope;
  94. List<SecurityReference> securityReferences = new ArrayList<>();
  95. securityReferences.add(new SecurityReference("Authorization", authorizationScopes));
  96. return securityReferences;
  97. }
  98. /**
  99. * 添加摘要信息
  100. */
  101. private ApiInfo apiInfo()
  102. {
  103. // 用ApiInfoBuilder进行定制
  104. return new ApiInfoBuilder()
  105. // 设置标题
  106. .title("标题:若依管理系统_接口文档")
  107. // 描述
  108. .description("描述:用于管理集团旗下公司的人员信息,具体包括XXX,XXX模块...")
  109. // 作者信息
  110. .contact(new Contact(ruoyiConfig.getName(), null, null))
  111. // 版本
  112. .version("版本号:" + ruoyiConfig.getVersion())
  113. .build();
  114. }
  115. }