SpringBoot 快速集成 Swagger

场景与定义

没有API文档工具之前,大家都是手写API文档的(维护起来相当困难),在什么地方书写的都有,有在confluence上写的,有在对应的项目目录下readme.md上写的,每个公司都有每个公司的玩法,无所谓好坏。

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

操作步骤

配置pom.xml

<!-- Swagger -->
        <dependency>
            <groupId>io.springfox</groupId>
            <artifactId>springfox-swagger2</artifactId>
            <version>2.9.2</version>
        </dependency>
        <dependency>
            <groupId>io.springfox</groupId>
            <artifactId>springfox-swagger-ui</artifactId>
            <version>2.9.2</version>
        </dependency>
        <dependency>
            <groupId>com.github.caspar-chen</groupId>
            <artifactId>swagger-ui-layer</artifactId>
            <version>1.1.3</version>
        </dependency>

这里没有使用swagger 默认的ui,用一个第三方ui 替换。

添加Swagger配置类

忽略(因为其实不配置也是可以用的)

如果需要自定义一些东西,就需要修改配置文件。

启动类

@SpringBootApplication
@EnableSwagger2
public class Application {

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

}

在启动类中添加注解

配置controller

@RestController
@RequestMapping(value = "/hello")
@Api(value = "/hello",tags = "DEMO")
public class HelloController {

    @Resource
    HelloService helloService;


    @GetMapping("/hello")
    @ApiOperation(value = "你好")
    public String say(){
        return "Hello Steven!";
    }
  • 在每个controller类中加上注解 @Api(tags = "这里写这一类接口作用")
  • 在每个接口上加上注解 @ApiOperation(value = "这里写这一个接口的作用")
  • 如果需要写每一个参数的描述,加上注解 @ApiImplicitParams

Test

接口完成后访问路径为 http://localhost:8080/docs.html#/ (端口号默认8080)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值