SpringBoot整合Swagger2

SpringBoot整合Swagger2

一.配置

  1. 导入依赖


    io.springfox
    springfox-swagger2
    2.6.1

        <dependency>
            <groupId>io.springfox</groupId>
            <artifactId>springfox-swagger-ui</artifactId>
            <version>2.6.1</version>
    

  2. 配置类的编写

    @Configuration
    @EnableSwagger2
    public class SwaggerConfig {

    @Bean
    public Docket createRestApi() {
        return new Docket(DocumentationType.SWAGGER_2)
                .apiInfo(apiInfo())
                .select()
                // 扫描指定包中的swagger注解
                .apis(RequestHandlerSelectors.basePackage("com.zy.controller"))
                //这种方式就是指定到一个具体类.扫描其注解
                //.apis(RequestHandlerSelectors.withMethodAnnotation(ApiOperation.class))
    
                .paths(PathSelectors.any())
                .build();
    }
    private ApiInfo apiInfo() {
        return new ApiInfoBuilder()
                .title("springboot利用swagger构建api文档-zy")
                .description("哈哈哈哈easy_report试水")
                .termsOfServiceUrl("www.baidu.com")
                .version("1.0")
                .build();
    }
    

    }

二.注解

swagger通过注解表明该接口会生成文档,包括接口名、请求方法、参数、返回信息的等等。

  • @Api:修饰整个类,描述Controller的作用
  • @ApiOperation:描述一个类的一个方法,或者说一个接口
  • @ApiParam:单个参数描述
  • @ApiModel:用对象来接收参数
  • @ApiProperty:用对象接收参数时,描述对象的一个字段
  • @ApiResponse:HTTP响应其中1个描述
  • @ApiResponses:HTTP响应整体描述
  • @ApiIgnore:使用该注解忽略这个API
  • @ApiError :发生错误返回的信息
  • @ApiParamImplicitL:一个请求参数
  • @ApiParamsImplicit 多个请求参数

    @ApiOperation(value=”更新信息”, notes=”根据url的id来指定更新图书信息”)
    @ApiImplicitParams({
    @ApiImplicitParam(name = “id”, value = “图书ID”, required = true, dataType = “Long”,paramType = “path”),
    @ApiImplicitParam(name = “book”, value = “图书实体book”, required = true, dataType = “Book”)
    })
    @RequestMapping(value=”/{id}”, method= RequestMethod.PUT)
    public String putUser(@PathVariable Long id, @RequestBody Book book) {
    Book book1 = books.get(id);
    book1.setName(book.getName());
    book1.setPrice(book.getPrice());
    books.put(id, book1);
    return “success”;
    }

注意:如果是取路径上的参数,@ApiImplicitParam后要加paramType = “path”

 @ApiIgnore//使用该注解忽略这个API
    @RequestMapping(value = "/hi", method = RequestMethod.GET)
    public String  jsonTest() {
        return " hi you!";
    }

三.启动

启动工程,访问:http://localhost:8080/swagger-ui.html ,就看到swagger-ui:

四.UI升级

替换UI包

<dependency>
    <groupId>com.github.xiaoymin</groupId>
    <artifactId>swagger-bootstrap-ui</artifactId>
    <version>1.6</version>
</dependency>

访问路径

http://localhost:8080/doc.html 即可

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值