SpringBoot从零到全栈商城(一)swagger接口文档自动化

1,048 阅读1分钟

介绍

记录SpringBoot从零到实现一整个商城后端的过程。

项目组成及技术栈

  • 接口 SpingBoot + JPA + mySql
  • 后台 vue + vue-element-admin
  • 移动端 uniapp + colorui + vuex + scss

备注

搭建springboot项目就不介绍了,直接从项目通用功能开始记录,swagger文档自动化,jwt用户认证


swagger接口文档自动化

导入pom依赖

<dependency>
  	<groupId>io.springfox</groupId>
  	<artifactId>springfox-swagger2</artifactId>
  	<version>2.9.2</version>
</dependency>
<dependency>
	<groupId>com.github.xiaoymin</groupId>
    <artifactId>swagger-bootstrap-ui</artifactId>
    <version>1.8.2</version>
</dependency>

创建配置文件

SwaggerConfig

package com.smxy.mall.config;

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import springfox.documentation.builders.ApiInfoBuilder;
import springfox.documentation.builders.ParameterBuilder;
import springfox.documentation.builders.PathSelectors;
import springfox.documentation.builders.RequestHandlerSelectors;
import springfox.documentation.schema.ModelRef;
import springfox.documentation.service.ApiInfo;
import springfox.documentation.service.Contact;
import springfox.documentation.service.Parameter;
import springfox.documentation.spi.DocumentationType;
import springfox.documentation.spring.web.plugins.Docket;
import springfox.documentation.swagger2.annotations.EnableSwagger2;

import java.util.ArrayList;
import java.util.List;

@Configuration
@EnableSwagger2
public class SwaggerConfig {
    @Bean
    public Docket createRestApi() {
        return new Docket(DocumentationType.SWAGGER_2)
                .pathMapping("/")
                .globalOperationParameters(getGlobalOperationParameters()) //全局参数
                .select()
                .apis(RequestHandlerSelectors.basePackage("com.smxy.mall.controller"))  //扫描项目所有的controller
                .paths(PathSelectors.any())
                .build()
                .apiInfo(apiInfo());
    }

    private List<Parameter> getGlobalOperationParameters() {
        List<Parameter> pars = new ArrayList<>();
        ParameterBuilder parameterBuilder = new ParameterBuilder();
        // 添加header参数,为了测试方便,添加一个默认token
        parameterBuilder.name("token")
                .defaultValue("eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJ0eXBlIjoiMiIsInVzZXJJZCI6MzIsInBob25lIjoiMTU3MTYwMjIzOTMiLCJzdWIiOiIzMiIsImlzcyI6IjA5OGY2YmNkNDYyMWQzNzNjYWRlNGU4MzI2MjdiNGY2IiwiaWF0IjoxNTk2MDgwODQ1LCJhdWQiOiJyZXN0YXBpdXNlciIsImV4cCI6MTU5NjY4NTY0NSwibmJmIjoxNTk2MDgwODQ1fQ.RaMy_L0Sa3UKFG7L7iDvmX47dAfrwEocQO7lJKDux8U")
                .modelRef(new ModelRef("string"))
                .parameterType("header")
                .required(false);
        pars.add(parameterBuilder.build());
        return pars;
    }

    private ApiInfo apiInfo() {
        return new ApiInfoBuilder()
                .title("接口文档")
                .description("springboot+vue")
                .version("1.0")
                .contact(new Contact("帅小黑x","blog.csdn.net","aaa@gmail.com"))
                .license("The Apache License")
                .licenseUrl("http://www.baidu.com")
                .build();
    }

}

访问

项目端口+/doc.html 例如: http://localhost:8083/doc.html