前后端接口测试神器Swagger基本使用(下)

简介: 前后端接口测试神器Swagger基本使用

4. 自定义接口展示


主要就是定义我们想要展示那些接口给前端人员进行测试使用.

基本的语句就是

Docket(DocumentationType.SWAGGER_2)
                .apiInfo(apiInfo())
                .select()
    //这里面定义我们的扫描规则
                .build();

我们的扫描规则有两种

  • 通过api接口进行配置
    这种主要有下面几种方式
Docket(DocumentationType.SWAGGER_2)
                .apiInfo(apiInfo())
                .select()
//配置接口扫描方式
//basePackage:指定要扫描的包              //.apis(RequestHandlerSelectors.basePackage("com.rang.swaggerdemo.controller"))
//这里我们也可以通过splitor关键字来实现同时扫描多个包 
//.apis(RequestHandlerSelectors.basePackage("com.rang.swaggerdemo.controller"+splitor+"com.rang.test.controller"))
//扫描全部
//.apis(RequestHandlerSelectors.any())
//不扫描
//.apis(RequestHandlerSelectors.none())
//扫描类上的注解,参数是一个注解的反射对象              //.apis(RequestHandlerSelectors.withClassAnnotation(Configuration.class))
//扫描方法上的注解,参数是一个注解的反射对象             //.apis(RequestHandlerSelectors.withMethodAnnotation(GetMapping.class))             
                .build();

我们就来测试一下.apis(RequestHandlerSelectors.basePackage(“com.rang.swaggerdemo.controller”))

效果

20200926110211138.png

这样便会显示com.rang.swaggerdemo.controller包下面所有的接口

  • 通过path路径即url地址栏进行配置
    这个主要就是通过url地址栏来进行
    主要也是下面这几种方式:
Docket(DocumentationType.SWAGGER_2)
                .apiInfo(apiInfo())
                .select()
//直接根据url地址栏进行匹配
//.paths(PathSelectors.ant("/user/**"))
//将任何借口都匹配进来等同于上述apis的any方法
//.paths(PathSelectors.any())
//不匹配任何借口等同于上述apis的none方法
//.paths(PathSelectors.none())
//根据正则表达式进行匹配
//.paths(PathSelectors.regex(""))
                .build();


  • 这里我们还是测试一下.paths(PathSelectors.ant("/user/**"))
    效果:


2020092611023669.png


但是大家其实可以看到我们上面是有 /user/test 与 /user/getname 这两个方法,按道理这两个方法都应该出现的,但是我自己测试过之后发现,无论怎么实现,他都是只能匹配出最开的那一个,之后的就匹配不出来了.有知


5. 常用的注解


这里主要就是下面这几个注解


@ApiModel


这个注解主要是标注在实体类上面


@ApiModel("用户实体类")//默认填充的是value字段
public class User {
}

@ApiModelProperty

这个注解主要是标注在实体类的属性上面

@ApiModel("用户实体类")
public class User {
    @ApiModelProperty("用户名")//默认填充的是value字段
    private String username;
    @ApiModelProperty("密码")
    private String password;
}

效果

20200926110255302.png

@Api

这个注解主要是标注在controller上面

@RestController
@Api(tags = "测试的controller")//默认填充的是value字段,所以我们需要加上tags字段的名称
public class HelloController {
}


这里要注意因为默认填充的都是value字段,但是本身@Api注解有点不同的就是它显示的内容应该是tags字段,所以添加的时候需要加上该字段

效果

20200926110311920.png


@ApiOperation

这个注解主要是标注在接口上面


@RestController
@Api(tags = "测试的controller")
public class HelloController {
    @ApiOperation("用户测试")
    @PostMapping(value = "/user/test")
    public User user(){
        return new User();
    }
    @ApiOperation("获取用户的用户名")
    @PostMapping(value = "/uesr/getname")
    public String getname( User user){
        return user.getUsername();
    }
}

20200926110328990.png


@ApiParam

这个注解主要是标注在接口需要传入的参数上面

@RestController
@Api(tags = "测试的controller")
public class HelloController {
    @PostMapping(value = "/hello")
    public String hello(@ApiParam("名字") String name){
        return "hello"+name;
    }
    @ApiOperation("用户测试")
    @PostMapping(value = "/user/test")
    public User user(){
        return new User();
    }
    @ApiOperation("获取用户的用户名")
    @PostMapping(value = "/uesr/getname")
    public String getname( User user){
        return user.getUsername();
    }
}


效果

20200926110345449.png


6. 配置多个分组


当有多个开发人员的时候我们就能够通过配置多个分组来实现接口文档的整体一致性.

这里我们主要是通过注入多个Docket对象来实现


    @Bean
    public Docket docket1(){
        return new Docket(DocumentationType.SWAGGER_2)
                .groupName("小明");
    }
    @Bean
    public Docket docket2(){
        return new Docket(DocumentationType.SWAGGER_2)
                .groupName("小王");
    }
    @Bean
    public Docket docket3(){
        return new Docket(DocumentationType.SWAGGER_2)
                .groupName("小李");
    }

效果

20200926110401986.png

这样也能够方便我们能够快速的查找到相应开发人员开发的接口,同时也能够查看每个人的开发进度,防止组员摸鱼.


7. 在线测试


其实说实话,有了这个功能,postman工具你基本上也用不到了,可以网页直接测试,又何必再开一个单独的软件来进行呢?


这里的操作过程其实就和之前我们接触过的接口测试工具是一样的,操作也是十分的简单,也能支持比较多的参数格式,既能支持form表单数据测试,也能支持json数据的测试


效果

20200926110418522.png

20200926110432630.png





相关文章
|
9天前
|
JSON 算法 数据可视化
测试专项笔记(一): 通过算法能力接口返回的检测结果完成相关指标的计算(目标检测)
这篇文章是关于如何通过算法接口返回的目标检测结果来计算性能指标的笔记。它涵盖了任务描述、指标分析(包括TP、FP、FN、TN、精准率和召回率),接口处理,数据集处理,以及如何使用实用工具进行文件操作和数据可视化。文章还提供了一些Python代码示例,用于处理图像文件、转换数据格式以及计算目标检测的性能指标。
18 0
测试专项笔记(一): 通过算法能力接口返回的检测结果完成相关指标的计算(目标检测)
|
1月前
|
移动开发 JSON Java
Jmeter实现WebSocket协议的接口测试方法
WebSocket协议是HTML5的一种新协议,实现了浏览器与服务器之间的全双工通信。通过简单的握手动作,双方可直接传输数据。其优势包括极小的头部开销和服务器推送功能。使用JMeter进行WebSocket接口和性能测试时,需安装特定插件并配置相关参数,如服务器地址、端口号等,还可通过CSV文件实现参数化,以满足不同测试需求。
167 7
Jmeter实现WebSocket协议的接口测试方法
|
1月前
|
JSON 移动开发 监控
快速上手|HTTP 接口功能自动化测试
HTTP接口功能测试对于确保Web应用和H5应用的数据正确性至关重要。这类测试主要针对后台HTTP接口,通过构造不同参数输入值并获取JSON格式的输出结果来进行验证。HTTP协议基于TCP连接,包括请求与响应模式。请求由请求行、消息报头和请求正文组成,响应则包含状态行、消息报头及响应正文。常用的请求方法有GET、POST等,而响应状态码如2xx代表成功。测试过程使用Python语言和pycurl模块调用接口,并通过断言机制比对实际与预期结果,确保功能正确性。
159 3
快速上手|HTTP 接口功能自动化测试
|
18天前
|
JavaScript 前端开发 API
vue尚品汇商城项目-day02【9.Home组件拆分+10.postman测试接口】
vue尚品汇商城项目-day02【9.Home组件拆分+10.postman测试接口】
32 0
|
1月前
|
JavaScript 前端开发 测试技术
ChatGPT与接口测试
ChatGPT与接口测试,测试通过
36 5
|
2月前
|
网络协议 测试技术 网络安全
Python进行Socket接口测试的实现
在现代软件开发中,网络通信是不可或缺的一部分。无论是传输数据、获取信息还是实现实时通讯,都离不开可靠的网络连接和有效的数据交换机制。而在网络编程的基础中,Socket(套接字)技术扮演了重要角色。 Socket 允许计算机上的程序通过网络进行通信,它是网络通信的基础。Python 提供了强大且易于使用的 socket 模块,使开发者能够轻松地创建客户端和服务器应用,实现数据传输和交互。 本文将深入探讨如何利用 Python 编程语言来进行 Socket 接口测试。我们将从基础概念开始介绍,逐步引导大家掌握创建、测试和优化 socket 接口的关键技能。希望本文可以给大家的工作带来一些帮助~
|
2月前
|
网络协议 测试技术 网络安全
Python进行Socket接口测试的实现
在现代软件开发中,网络通信是不可或缺的一部分。无论是传输数据、获取信息还是实现实时通讯,都离不开可靠的网络连接和有效的数据交换机制。而在网络编程的基础中,Socket(套接字)技术扮演了重要角色。 Socket 允许计算机上的程序通过网络进行通信,它是网络通信的基础。Python 提供了强大且易于使用的 socket 模块,使开发者能够轻松地创建客户端和服务器应用,实现数据传输和交互。 本文将深入探讨如何利用 Python 编程语言来进行 Socket 接口测试。我们将从基础概念开始介绍,逐步引导大家掌握创建、测试和优化 socket 接口的关键技能。希望本文可以给大家的工作带来一些帮助~
|
2月前
|
SQL Java 测试技术
SpringBoot单元测试快速写法问题之PorkService 接口中的 getPork 方法的作用如何解决
SpringBoot单元测试快速写法问题之PorkService 接口中的 getPork 方法的作用如何解决
|
2月前
|
Web App开发 JSON 测试技术
精通Postman接口测试:关联技术与自动化实践指南
这篇文章详细介绍了如何使用Postman进行接口测试,包括关联技术、自动化实践,以及如何通过环境变量和全局变量解决接口之间的关联性问题。
70 0
精通Postman接口测试:关联技术与自动化实践指南
|
2月前
|
JSON jenkins 测试技术
Python接口自动化测试框架(工具篇)-- 接口测试工具HTTPRUNNER
本文介绍了Python接口自动化测试框架HTTPRunner,包括其安装、使用方法,并通过实际操作演示了如何利用HTTPRunner进行接口测试,同时还探讨了HTTPRunner作为接口自动化测试解决方案的可能性和实用性。
60 0