Swagger测试Restful API
原创
©著作权归作者所有:来自51CTO博客作者全栈测试笔记的原创作品,请联系作者获取转载授权,否则将追究法律责任
swagger出现背景
我们构建Restful API的目的通常都是由于多终端的原因,这些终端会共用很多底层业务逻辑,因此我们会抽象出这样一层来同时服务于多个移动端或者Web前端,不同端由不同的团队或者小组负责,为了减少与其他团队平时开发期间的频繁沟通成本,传统做法我们会创建一份Restful API文档来记录所有接口细节,但是,由于接口多且复杂,这样的做法是很难执行的,且效果差。
而Swagger2可以轻松的整合到Spring Boot中,既可以减少我们创建文档的工作量,同时说明内容又整合入实现代码中,让维护文档和修改代码整合为一体,可以让我们在修改代码逻辑的同时方便的修改文档说明。另外Swagger2也提供了强大的页面测试功能来调试每个RESTful API。
Spring Boot集成swagger
待补充
修改Controller层
package com.qzcsbj.demo.controller;
import com.qzcsbj.demo.commons.ResultCode;
import com.qzcsbj.demo.commons.ResultCommon;
import com.qzcsbj.demo.mapper.UserMapper;
import com.qzcsbj.demo.pojo.User;
import com.qzcsbj.demo.service.UserService;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;
import javax.annotation.Resource;
import java.util.List;
/**
* @公众号 : 全栈测试笔记
* @描述 : <>
*/
@Api(tags = {"用户操作"})
@RestController
@RequestMapping("/v2")
public class UserController {
@Autowired
UserService userService;
// restful api:增
@ApiOperation(value = "添加用户", notes = "添加一个用户")
@PostMapping("/users")
public ResultCommon add(User user){
int n = userService.add(user);
if (n>0){
return ResultCommon.success(ResultCode.SUCCESS);
} else {
return ResultCommon.fail(ResultCode.FAIL);
}
}
// restful api:删
@ApiOperation(value = "根据id删除用户", notes = "根据id删除一个用户")
@DeleteMapping("/users/{id}")
public ResultCommon delete(@PathVariable("id") Integer id){
int n = userService.delete(id);
if (n>0){
return ResultCommon.success(ResultCode.SUCCESS);
} else {
return ResultCommon.fail(ResultCode.FAIL);
}
}
// restful api:改
@ApiOperation(value = "修改用户", notes = "根修改用户信息")
@PutMapping("/users")
public ResultCommon update(User user){
int n = userService.update(user);
if (n>0){
return ResultCommon.success(ResultCode.SUCCESS);
} else {
return ResultCommon.fail(ResultCode.FAIL);
}
}
// restful api:查
@ApiOperation(value = "根据id获取用户", notes = "根据id获取用户信息")
@GetMapping("/users/{id}")
// @RequestMapping(value = "/user/{id}", method=RequestMethod.GET)
public ResultCommon findById(@PathVariable("id") Integer id){
User user = userService.findById(id);
return ResultCommon.success(ResultCode.SUCCESS, user);
}
// restful api:查所有
@ApiOperation(value = "获取用户列表", notes = "获取所有用户")
@GetMapping("/users")
public ResultCommon findAll(){
List<User> users = userService.findAll();
return ResultCommon.success(ResultCode.SUCCESS, users);
}
}
效果
访问:http://localhost:8082/swagger-ui.html,端口根据实际情况修改即可。
data:image/s3,"s3://crabby-images/aaf9f/aaf9ff7bff0bac7fcfa48307e4e42d1223580035" alt="Swagger测试Restful API_java"
swagger上进行测试
这样就可以不用postman或者jmeter测试了
没有前端,可以通swagger模拟前端进行测试
增
id是自增的不用填,addtime是通过函数获取的也不用填
data:image/s3,"s3://crabby-images/1c34b/1c34b824ac262ed13bea00323d153628ff9bd44b" alt="Swagger测试Restful API_java_02"
data:image/s3,"s3://crabby-images/04656/04656eab68b8107840cad55e2eed34fe622107eb" alt="Swagger测试Restful API_java_03"
数据库中新增成功
data:image/s3,"s3://crabby-images/c460c/c460cdd4f01b21655a6785efd2a1c5773dcd3ba7" alt="Swagger测试Restful API_API_04"
删
data:image/s3,"s3://crabby-images/4d23a/4d23a8a6aa40702dc98de08fdb4f9c0e0cec1f98" alt="Swagger测试Restful API_java_05"
data:image/s3,"s3://crabby-images/70ffc/70ffcee7e8d986aef6a31fa0191c086d9e11fdb0" alt="Swagger测试Restful API_User_06"
数据库中删除成功
data:image/s3,"s3://crabby-images/9f4b3/9f4b356e19573e64c71e479e08825b7c701a373b" alt="Swagger测试Restful API_java_07"
改
修改前
data:image/s3,"s3://crabby-images/9ce1e/9ce1ed05b0ef5102a0f8e026f40b8611714156a6" alt="Swagger测试Restful API_User_08"
data:image/s3,"s3://crabby-images/52fb7/52fb77de3c8256924ce7ca43f34704ec7bf4ebda" alt="Swagger测试Restful API_User_09"
data:image/s3,"s3://crabby-images/11c85/11c85e162535722b9a9d80e2b900be74a1b98c28" alt="Swagger测试Restful API_java_10"
修改后
data:image/s3,"s3://crabby-images/ac5a4/ac5a44959c857b70abb29bd969dd1a779c94c80c" alt="Swagger测试Restful API_java_11"
查
data:image/s3,"s3://crabby-images/56ed3/56ed3a3bb3804e1c76be9f35168c7799e50d29a0" alt="Swagger测试Restful API_User_12"
data:image/s3,"s3://crabby-images/a9cd9/a9cd962e7732ee1413ee20e59f8e3b4348bae542" alt="Swagger测试Restful API_API_13"
查所有
data:image/s3,"s3://crabby-images/19c3e/19c3ea931a9241aaff26128f5a8b1c13dd035146" alt="Swagger测试Restful API_User_14"
data:image/s3,"s3://crabby-images/60230/60230f0ffef49e85218e0d26319696072f6e531d" alt="Swagger测试Restful API_java_15"
__EOF__
本文作者:持之以恒(韧)