zoukankan      html  css  js  c++  java
  • Swagger 2.0 集成配置

    传统的API文档编写存在以下几个痛点:

    对API文档进行更新的时候,需要通知前端开发人员,导致文档更新交流不及时;

    API接口返回信息不明确

    大公司中肯定会有专门文档服务器对接口文档进行更新。

    缺乏在线接口测试,通常需要使用相应的API测试工具,比如postman、SoapUI等

    接口文档太多,不便于管理

    为了解决传统API接口文档维护的问题,为了方便进行测试后台Restful接口并实现动态的更新,因而引入Swagger接口工具。

    Swagger具有以下优点

    1.功能丰富:支持多种注解,自动生成接口文档界面,支持在界面测试API接口功能;

    2.及时更新:开发过程中花一点写注释的时间,就可以及时的更新API文档,省心省力;

    3.整合简单:通过添加pom依赖和简单配置,内嵌于应用中就可同时发布API接口文档界面,不需要部署独立服务。

    springboot集成

    Maven依赖信息

    <parent>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-parent</artifactId>
            <version>2.0.1.RELEASE</version>
        </parent>
        <!-- 管理依赖 -->
        <dependencyManagement>
            <dependencies>
                <dependency>
                    <groupId>org.springframework.cloud</groupId>
                    <artifactId>spring-cloud-dependencies</artifactId>
                    <version>Finchley.M7</version>
                    <type>pom</type>
                    <scope>import</scope>
                </dependency>
            </dependencies>
        </dependencyManagement>
        <dependencies>
            <!-- SpringBoot整合Web组件 -->
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-web</artifactId>
            </dependency>
            <!-- SpringBoot整合eureka客户端 -->
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
            </dependency>
            <!-- swagger2 -->
            <dependency>
                <groupId>io.springfox</groupId>
                <artifactId>springfox-swagger2</artifactId>
                <version>2.8.0</version>
            </dependency>
            <dependency>
                <groupId>io.springfox</groupId>
                <artifactId>springfox-swagger-ui</artifactId>
                <version>2.8.0</version>
            </dependency>
        </dependencies>
        <!-- 注意: 这里必须要添加, 否者各种依赖有问题 -->
        <repositories>
            <repository>
                <id>spring-milestones</id>
                <name>Spring Milestones</name>
                <url>https://repo.spring.io/libs-milestone</url>
                <snapshots>
                    <enabled>false</enabled>
                </snapshots>
            </repository>
        </repositories>

    SwaggerConfig

    @Configuration
    @EnableSwagger2
    public class SwaggerConfig {
    
        @Bean
        public Docket createRestApi() {
            return new Docket(DocumentationType.SWAGGER_2).apiInfo(apiInfo()).select()
                    // api扫包
                    .apis(RequestHandlerSelectors.basePackage("com.itmayiedu.api")).paths(PathSelectors.any()).build();
        }
    
        private ApiInfo apiInfo() {
            return new ApiInfoBuilder().title("电商系统").description("Java分布式")
                    .termsOfServiceUrl("http://www")
                    // .contact(contact)
                    .version("1.0").build();
        }
    
    }

    访问地址:http://localhost:8060/swagger-ui.html#/swagger-controller

    Zull整合Swagger管理微服务所有API

    会员和订单引入Maven依赖

            <!-- swagger-spring-boot -->
            <dependency>
                <groupId>com.spring4all</groupId>
                <artifactId>swagger-spring-boot-starter</artifactId>
                <version>1.7.0.RELEASE</version>
            </dependency>

    application.yml配置

    Api接口扫描范围

    swagger:
      base-package: com.itmayeidu.api

    ZuulGateway网关

    @SpringBootApplication
    @EnableEurekaClient
    @EnableZuulProxy
    @EnableSwagger2Doc
    public class AppGateWay {
    
        // @EnableZuulProxy 开启网关代理
    
        public static void main(String[] args) {
            SpringApplication.run(AppGateWay.class, args);
        }
    
        // zuul配置能够使用config实现实时更新
        @RefreshScope
        @ConfigurationProperties("zuul")
        public ZuulProperties zuulProperties() {
            return new ZuulProperties();
        }
    
        // 添加文档来源
        @Component
        @Primary
        class DocumentationConfig implements SwaggerResourcesProvider {
            @Override
            public List<SwaggerResource> get() {
                List resources = new ArrayList<>();
                // app-itmayiedu-order
                resources.add(swaggerResource("app-itmayiedu-member", "/api-member/v2/api-docs", "2.0"));
                resources.add(swaggerResource("app-itmayiedu-order", "/api-order/v2/api-docs", "2.0"));
                return resources;
            }
    
            private SwaggerResource swaggerResource(String name, String location, String version) {
                SwaggerResource swaggerResource = new SwaggerResource();
                swaggerResource.setName(name);
                swaggerResource.setLocation(location);
                swaggerResource.setSwaggerVersion(version);
                return swaggerResource;
            }
        }
    
    }

    Maven依赖信息

            <dependency>
                <groupId>com.spring4all</groupId>
                <artifactId>swagger-spring-boot-starter</artifactId>
                <version>1.7.0.RELEASE</version>
            </dependency>
  • 相关阅读:
    Gym 100818F Irrational Roots (数学)
    学习总结 for循环--冒泡排序
    学习总结 for循环语句的应用
    学习总结 条件语句的应用
    学习总结 运算符了解与应用
    学习记录 彻底搞清 C#中a++与++a的区别
    学习总结 数据类型的应用与转换
    学习总结 数据类型
    学习总结 二进制转换与应用
    学习总结 vs软件简单了解
  • 原文地址:https://www.cnblogs.com/a1304908180/p/10681918.html
Copyright © 2011-2022 走看看