java丝袜_SpringBoot项目使用Swagger2(丝袜哥)实现接口测试管理

本文主要是介绍java丝袜_SpringBoot项目使用Swagger2(丝袜哥)实现接口测试管理,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

案例如下:

安装步骤,在写完的项目中,添加swagger的相关依赖

使用官方依赖

1、在pom.xml文件中添加swagger相关依赖

io.springfox

springfox-swagger2

2.7.0

io.springfox

springfox-swagger-ui

2.7.0

也可以:

2.7.0

io.springfox

springfox-swagger2

${swagger.version}

io.springfox

springfox-swagger-ui

${swagger.version}

第一个是API获取的包,第二是官方给出的一个ui界面。这个界面可以自定义,默认是官方的,对于安全问题,以及ui路由设置需要着重思考。

2、swagger的configuration

需要特别注意的是swagger scan base package,这是扫描注解的配置,即你的API接口位置。

packagecn.xnol.user;importorg.springframework.boot.autoconfigure.condition.ConditionalOnProperty;importorg.springframework.context.annotation.Bean;importorg.springframework.context.annotation.Configuration;importspringfox.documentation.builders.ApiInfoBuilder;importspringfox.documentation.builders.PathSelectors;importspringfox.documentation.builders.RequestHandlerSelectors;importspringfox.documentation.service.ApiInfo;importspringfox.documentation.service.Contact;importspringfox.documentation.spi.DocumentationType;importspringfox.documentation.spring.web.plugins.Docket;importspringfox.documentation.swagger2.annotations.EnableSwagger2;//swagger2的配置文件,在项目的启动类的同级文件建立

@Configuration

@EnableSwagger2//是否开启swagger,正式环境一般是需要关闭的(避免不必要的漏洞暴露!),可根据springboot的多环境配置进行设置

@ConditionalOnProperty(name = "swagger.enable", havingValue = "true")public classSwagger2 {//swagger2的配置文件,这里可以配置swagger2的一些基本的内容,比如扫描的包等等

@BeanpublicDocket createRestApi() {return newDocket(DocumentationType.SWAGGER_2)

.apiInfo(apiInfo())

.select()//为当前包路径

.apis(RequestHandlerSelectors.basePackage("cn.xnol.user.controller")).paths(PathSelectors.any())

.build();//.pathMapping("/stu");//在这里可以设置请求的统一前缀

}//构建 api文档的详细信息函数,注意这里的注解引用的是哪个

privateApiInfo apiInfo() {return newApiInfoBuilder()//页面标题

.title("SpringBoot基于Swagger2构建RESTful API接口测试")//描述

.description("API接口描述")//创建人信息

.contact(new Contact("Agoly", "https://www.cnblogs.com/qmfsun/", ""))//版本号

.version("1.0")

.build();

}

}

20200726002716891429.png

20200726002717088702.png

swagger.enable=truespringfox.documentation.swagger.v2.path= /user/api-docs

在controller中的接口路由中添加接口说明信息

packagecn.xnol.user.controller;importcn.xnol.user.entry.User;importcn.xnol.user.service.UserService;importio.swagger.annotations.Api;importio.swagger.annotations.ApiOperation;importorg.springframework.beans.factory.annotation.Autowired;importorg.springframework.data.domain.Page;import org.springframework.web.bind.annotation.*;importjavax.servlet.http.HttpServletResponse;importjava.util.List;//用于类;表示标识这个类是swagger的资源//tags:说明,如果有多个tags,则会以list形式展示//value: 说明,可以使用tags替代

@Api(value = "测试Controller" , tags = "用户服务")

@RestController

@RequestMapping("/user")public classUserController {

@Autowired

UserService userService;/*** 添加学生

*@paramuser 要添加的用户对象

*@return

*/@ApiOperation(value="新增用户")

@PostMapping("/add")publicUser save(User user){returnuserService.save(user);

}/*** 修改学生

*@paramuser

*@return

*/@ApiOperation(value= "修改用户", notes = "修改用户信息")

@PostMapping("/update")publicUser update(User user){returnuserService.save(user);

}/*** 删除用户

*@paramid 要删除的用户id

*@return

*/@ApiOperation(value= "根据id删除用户", notes = "删除用户")

@GetMapping("/del/{id}")public String del(@PathVariable intid){

userService.delete(id);return "yes";

}/*** 通过姓名找到信息

*@paramname

*@return

*/@ApiOperation(value= "根据用户名查询", notes="用户名查询")

@GetMapping("/findByName/{name}")public ListfindByName(@PathVariable String name){returnuserService.findUserByName(name);

}/*** 利用分页查找全部信息

*@parampage

*@paramresponse

*@return

*/@ApiOperation(value= "分页查询", notes="默认5条记录显示页")

@GetMapping("/query")public PagefindByPage(Integer page, HttpServletResponse response){//异步请求使用

response.setHeader("Access-Control-Allow-Origin","*");if(page==null || page<=0){

page= 0;

}else{

page-= 1;

}return userService.findAll(page,5);

}

}

配置完成,启动项目,效果如下:

20200726002717193198.png

参考:

这篇关于java丝袜_SpringBoot项目使用Swagger2(丝袜哥)实现接口测试管理的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/371042

相关文章

SpringBoot应用中出现的Full GC问题的场景与解决

《SpringBoot应用中出现的FullGC问题的场景与解决》这篇文章主要为大家详细介绍了SpringBoot应用中出现的FullGC问题的场景与解决方法,文中的示例代码讲解详细,感兴趣的小伙伴可... 目录Full GC的原理与触发条件原理触发条件对Spring Boot应用的影响示例代码优化建议结论F

springboot项目中常用的工具类和api详解

《springboot项目中常用的工具类和api详解》在SpringBoot项目中,开发者通常会依赖一些工具类和API来简化开发、提高效率,以下是一些常用的工具类及其典型应用场景,涵盖Spring原生... 目录1. Spring Framework 自带工具类(1) StringUtils(2) Coll

Python虚拟环境终极(含PyCharm的使用教程)

《Python虚拟环境终极(含PyCharm的使用教程)》:本文主要介绍Python虚拟环境终极(含PyCharm的使用教程),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录一、为什么需要虚拟环境?二、虚拟环境创建方式对比三、命令行创建虚拟环境(venv)3.1 基础命令3

Python Transformer 库安装配置及使用方法

《PythonTransformer库安装配置及使用方法》HuggingFaceTransformers是自然语言处理(NLP)领域最流行的开源库之一,支持基于Transformer架构的预训练模... 目录python 中的 Transformer 库及使用方法一、库的概述二、安装与配置三、基础使用:Pi

关于pandas的read_csv方法使用解读

《关于pandas的read_csv方法使用解读》:本文主要介绍关于pandas的read_csv方法使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录pandas的read_csv方法解读read_csv中的参数基本参数通用解析参数空值处理相关参数时间处理相关

使用Node.js制作图片上传服务的详细教程

《使用Node.js制作图片上传服务的详细教程》在现代Web应用开发中,图片上传是一项常见且重要的功能,借助Node.js强大的生态系统,我们可以轻松搭建高效的图片上传服务,本文将深入探讨如何使用No... 目录准备工作搭建 Express 服务器配置 multer 进行图片上传处理图片上传请求完整代码示例

openCV中KNN算法的实现

《openCV中KNN算法的实现》KNN算法是一种简单且常用的分类算法,本文主要介绍了openCV中KNN算法的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录KNN算法流程使用OpenCV实现KNNOpenCV 是一个开源的跨平台计算机视觉库,它提供了各

SpringBoot条件注解核心作用与使用场景详解

《SpringBoot条件注解核心作用与使用场景详解》SpringBoot的条件注解为开发者提供了强大的动态配置能力,理解其原理和适用场景是构建灵活、可扩展应用的关键,本文将系统梳理所有常用的条件注... 目录引言一、条件注解的核心机制二、SpringBoot内置条件注解详解1、@ConditionalOn

Python中使用正则表达式精准匹配IP地址的案例

《Python中使用正则表达式精准匹配IP地址的案例》Python的正则表达式(re模块)是完成这个任务的利器,但你知道怎么写才能准确匹配各种合法的IP地址吗,今天我们就来详细探讨这个问题,感兴趣的朋... 目录为什么需要IP正则表达式?IP地址的基本结构基础正则表达式写法精确匹配0-255的数字验证IP地

OpenCV图像形态学的实现

《OpenCV图像形态学的实现》本文主要介绍了OpenCV图像形态学的实现,包括腐蚀、膨胀、开运算、闭运算、梯度运算、顶帽运算和黑帽运算,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起... 目录一、图像形态学简介二、腐蚀(Erosion)1. 原理2. OpenCV 实现三、膨胀China编程(