Swagger的使用配置(一)

本文为swagger-ui的使用配置说明

pom的依赖:
<dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
</dependency>
<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>
依赖说明:

springfox-swagger-ui 将swagger用ui的形式展示出来,否则只能在http://ip:port/v2/api-docs路径下展示出来

常用Swagger注解使用说明:

@Api(tags="") -- 类上注解,用于说明类
@ApiOperation("") -- 方法上的注解,用于说明方法,如果不指定默认是value值
@ApiIgnore -- 方法上使用默认不展示被注解了的方法
@ApiModel -- 类上用于说明对象类
@ApiModelProperty -- 对象类上的属性描述(多用于接口参数说明)

@ApiResponses -- 类上的注解,表示一组响应
@ApiResponse -- 在@ApiResponses内使用,表示一个错误信息的使用

eg:@ApiResponses({@ApiResponse(code=500, message = "内部错误", response = MessageReturn.class)}),其中:

  • code:错误码
  • message :错误信息描述
  • response :错误返回信息的类型

@ApiImplicitParams -- 多用在方法上,指定一组请求参数的各个方面
@ApiImplicitParam -- 在@ApiImplicitParams内使用,指定一个请求参数的各个方面

eg:@ApiImplicitParams({@ApiImplicitParam(paramType="query", name = "id", value = "主键ID", required = true, dataType = "Long")})

  • paramType:参数放在那个地方
    • header:请求参数的获取:@RequestHeader
    • query:请求参数的获取:@RequestParam
    • path:请求路径中参数的获取:@PathVariable
    • body:(不常用)
    • form:(不常用)
  • name:参数的名称
  • value:参数的描述
  • dataType :参数的类型
  • defaultValue :参数的默认值
  • required :是否必填项

使用示例

@Api(tags="用户相关接口")
@RestController
@RequestMapping("/test/info")
public class InfoController {

    @Autowired
    public InfoService infoService;

    @ApiOperation("获取所有用户信息", notes = "方法描述")//默认是value
    @GetMapping("/find")
    public List<Info> findAll(){
        return infoService.list();
    }

    @ApiIgnore
    @ApiOperation("获取详细信息")
    @GetMapping("/detail")
    public Info detail(Long id){
        return infoService.getById(id);
    }
  
    @ApiOperation("删除详细信息")
    @DeleteMapping("/delete")
    public void deleted(Long id){
        this.infoService.removeById(id);
    }
}

标准版:

SwaggerConfig的配置:
@Configuration
@EnableSwagger2
public class SwaggerConfig {

    @Bean
    public Docket api(){
        return new Docket(DocumentationType.SWAGGER_2)
                .select()
                .apis(RequestHandlerSelectors.any())
                .paths(PathSelectors.any())
                .build()
                .apiInfo(apiInfo());
    }

    private ApiInfo apiInfo(){
        return new ApiInfoBuilder()
                .title("测试swagger2使用")
                .contact(new Contact("XXX","http://localhost","123@456"))
                .version("1.0")
                .build();
    }
}

其中:

@Configuration ---- 告诉 Spring Boot 需要加载这个配置类
@EnableSwagger2 ---- 启用 Swagger2
Springfox 提供了一个 Docket 对象,让我们可以灵活的配置 Swagger 的各项属性
通过创建一个 ApiInfo 对象,并且使用 Docket.appInfo() 方法来设置文档信息的描述

优化版:

@Configuration
@EnableSwagger2
public class SwaggerConfig {

    @Bean
    public Docket api(){
        return new Docket(DocumentationType.SWAGGER_2)
                .select()
                .apis(RequestHandlerSelectors.basePackage("xx.flower"))
                .paths(Predicates.or(PathSelectors.ant("/test/info/find"),
                        PathSelectors.ant("/test/info/delete")))//接口文档将只会展示 /test/info/find 和 /test/info/delete两个接口。
                .build()
                .apiInfo(apiInfo());
    }

    private ApiInfo apiInfo(){
        return new ApiInfoBuilder()
                .title("测试swagger2使用")
                .description("Swagger测试API描述")//加则展示,不加不展示描述信息
                .contact(new Contact("XXX","http://localhost","123@456"))
                .version("1.0")
                .build();
    }
}

其中:

apis() :这种方式我们可以通过指定包名的方式,让 Swagger 只去某些包下面扫描
paths() :这种方式可以通过筛选 API 的 url 来进行过滤

Swagger UI如下:

swagger-ui的展示界面
参考文献:

https://developer.ibm.com/zh/articles/j-using-swagger-in-a-spring-boot-project/
https://www.cnblogs.com/heroinss/p/9947978.html

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,723评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,003评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,512评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,825评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,874评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,841评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,812评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,582评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,033评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,309评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,450评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,158评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,789评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,409评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,609评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,440评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,357评论 2 352