Spring Boot使用Swagger

Spring Boot Swagger

Swagger介绍

Swagger是一个规范和完整的框架,用于生成、描述、调用和可视化 Restful 风格的 Web 服务。总体目标是使客户端和文件系统作为服务器以同样的速度来更新。文件的方法、参数和模型紧密集成到服务器端的代码,允许API来始终保持同步。

Swagger是最流行的API开发工具,它遵循OpenAPI Specification(OpenAPI规范,简称OAS),有了它,可以不用PostMan测试接口了

Swagger可以贯穿于整个API生态,如API的设计、编写API文档、测试和部署。本文查看Swagger如何用于接口文档在线生成以及功能测试。

1. pom.xml引入相关jar包

<!-- swagger-ui -->
<dependency>
    <groupId>io.springfox</groupId>
    <artifactId>springfox-swagger-ui</artifactId>
    <version>2.8.0</version>
</dependency>
<!-- swagger -->
<dependency>
    <groupId>io.springfox</groupId>
    <artifactId>springfox-swagger2</artifactId>
    <version>2.8.0</version>
</dependency>

2. 编写相关配置类

@Api(value = "/api", description = "swagger示例接口", tags = "example")
@RestController
@RequestMapping(value = "/api", produces = {"application/json"})
public class Swagger2Configuration {
    @Bean
    public Docket api() {
        return new Docket(DocumentationType.SWAGGER_2)
                .select()
                .apis(RequestHandlerSelectors.any())//api的配置路径
                .paths(PathSelectors.any())//扫描路径选择
                .build()
                .apiInfo(apiInfo());
    }

    private ApiInfo apiInfo() {
        return new ApiInfoBuilder()
                .title("title") //文档标题
                .description("description")//接口概述
                .version("1.0") //版本号
                .termsOfServiceUrl(String.format("url"))//服务的域名
                //.license("LICENSE")//证书
                //.licenseUrl("http://www.guangxu.com")//证书的url
                .build();
    }
}

3. Controller引入相关注解

@Api(description = "学生接口 ")
@RestController
@RequestMapping(value = "/student")
public class StudentController {

    /** 学生服务 */
    @Autowired
    private StudentService studentService;

    @ApiOperation(value = "登录")
    @ApiImplicitParams({@ApiImplicitParam(name = "userId", value = "用户名", required = true, dataType = "String"),
            @ApiImplicitParam(name = "password", value = "密码", required = true, dataType = "String")})
    @PostMapping("/login")
    public Student login(String userId, String password){
        return studentService.query(userId, password);
    }

}

4. Application加入注解

@SpringBootApplication
@EnableSwagger2//一定要记得添加当前注解
public class SwaggerApplication {

    public static void main(String[] args) {
        SpringApplication.run(SwaggerApplication.class, args);
    }

}

5. 运行并访问如下链接, 即可进行查看和测试

http://localhost:8080/swagger-ui.html

选择待测试接口

点击创建


Try it out

输入相关的值,点击创建


创建

查看执行结果


结果

6. 代码参考

SpringBoot_Swagger

Swagger注解说明

官方文档参考 https://editor.swagger.io/

常用的注解

  • @Api:用在类上,说明该类的作用
  • @ApiOperation:给API增加方法说明
  • @ApiImplicitParams : 用在方法上包含多个参数说明
  • @ApiImplicitParam:用在方法上包含一个参数说明
  • @ApiModel:描述一个Model的信息(一般用在请求参数无法使用@ApiImplicitParam注解进行描述的时候)
  • @ApiModelProperty:描述一个model的属性
    参数说明:
paramType:指定参数放在哪个地方。
name:参数名
dataType:参数类型
required:参数是否必须传
value:说明参数
defaultValue:参数的默认值

paramType类型

header:请求参数放置于Request Header,使用@RequestHeader 获取。
query:请求参数放置于请求地址,使用@RequestParam获取
path:用于restful接口。
@PathVariable:获取请求参数。
body
form
  • @ApiResponses:用于表示一组响应。
  • @ApiResponse:用在@ApiResponses中,一般用于表达一个错误的响应信息。
code:数字,例如200
message:信息,例如"缺少请求参数"。
response:抛出异常的类
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。