接口文档生成工具Swagger2
前言:
在当下前后端分离
开发和微服务大行其道的情况下,微服务及前后端分离后,前后端并行开发,这样沟通成本就增加了。所以一款强大的RESTful API
文档就至关重要。而目前在后端领域,
基本上是Swagger
的天下了。
什么是Swagger?
Swagger 是一个规范和完整的框架,用于生成、描述、调用和可视化 RESTful 风格的 Web 服务。总体目标是使客户端和文件系统作为服务器以同样的速度来更新。
文件的方法,参数和模型紧密集成到服务器端的代码,允许API来始终保持同步。
可以解决什么问题?
1、创建文档成本高:由于接口众多,并且细节复杂(需要考虑不同的HTTP请求类型、HTTP头部信息、HTTP请求内容等)。
2、维护文档成本高:修改接口实现的时候必须同步修改接口文档,而文档与代码可能存储于两个不同的媒介,除非有严格的管理机制,否则易导致不一致现象。
3、沟通成本高:文档更新时,若不能及时交流,前端不能及时获取最新的接口信息。
4、接口返回结果不明确,不能直接在线测试,通常需使用另外的工具,如:postman等。
作用:
1、接口的文档在线自动生成。
2、功能测试。
Swagger2常用注解有哪些?
swagger通过注解表明该接口会生成文档,包括接口名、请求方法、参数、返回信息的等等。
- @Api:修饰整个类,描述Controller的作用
- @ApiOperation:描述一个类的一个方法,或者说一个接口
- @ApiParam:单个参数描述
- @ApiModel:用对象来接收参数
- @ApiProperty:用对象接收参数时,描述对象的一个字段
- @ApiResponse:HTTP响应其中1个描述
- @ApiResponses:HTTP响应整体描述
- @ApiIgnore:使用该注解忽略这个API
- @ApiError :发生错误返回的信息
- @ApiImplicitParam:一个请求参数
- @ApiImplicitParams:多个请求参数
如何使用?(SpringBoot集成)
1)添加Maven依赖
1 2 3 4 5 6 7 8 9 10 11 | <!--swagger2 --> <dependency> <groupId>io.springfox</groupId> <artifactId>springfox-swagger2</artifactId> <version> 2.8 . 0 </version> </dependency> <dependency> <groupId>io.springfox</groupId> <artifactId>springfox-swagger-ui</artifactId> <version> 2.8 . 0 </version> </dependency> |
2)创建配置类,并添加注解 @Configuration和定义Docket的bean类
注意:在与spring boot 集成时,放在与application.java 同级的目录下
通过@Configuration注解,让spring来加载该配置
用@Configuration注解该类,等价于XML中配置beans;用@Bean标注方法等价于XML中配置bean。
再通过@EnableSwagger2注解来启动Swagger2
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 | @Configuration public class Swagger2Config { //是否开启swagger,正式环境一般是需要关闭的,可根据springboot的多环境配置进行设置 @Value (value = "${swagger.enabled}" ) Boolean swaggerEnabled; @Bean public Docket createRestApi() { return new Docket(DocumentationType.SWAGGER_2).apiInfo(apiInfo()) // 是否开启 .enable(swaggerEnabled).select() // 扫描的路径包 .apis(RequestHandlerSelectors.basePackage( "com.jack.springboot.controller" )) // 指定路径处理PathSelectors.any()代表所有的路径 .paths(PathSelectors.any()).build().pathMapping( "/" ); } private ApiInfo apiInfo() { return new ApiInfoBuilder() .title( "SpringBoot-Swagger2示例" ) .description( "jacking0325" ) // 作者信息 .contact( new Contact( "jacking0325" , "https://blog.jack0325.cn/" , "111111111@qq.com" )) .version( "1.0.0" ) .build(); } } |
3)Application.class 加上注解@EnableSwagger2 表示开启Swagger
1 2 3 4 5 6 7 8 | @SpringBootApplication @EnableSwagger2 public class SpringbootSwagger2Application { public static void main(String[] args) { SpringApplication.run(SpringbootSwagger2Application. class , args); } } |
4)RESTful接口(基础打好,开始在代码中使用)
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 | @RestController public class UserController { // 创建线程安全的Map static Map<Integer, User> users = Collections.synchronizedMap( new HashMap<Integer, User>()); /** * 根据ID查询用户 * @param id * @return */ @ApiOperation (value= "获取用户详细信息" , notes= "根据url的id来获取用户详细信息" ) @ApiImplicitParam (name = "id" , value = "用户ID" , required = true , dataType = "Integer" , paramType = "path" ) @RequestMapping (value = "user/{id}" , method = RequestMethod.GET) public ResponseEntity<JsonResult> getUserById ( @PathVariable (value = "id" ) Integer id){ JsonResult r = new JsonResult(); try { User user = users.get(id); r.setResult(user); r.setStatus( "ok" ); } catch (Exception e) { r.setResult(e.getClass().getName() + ":" + e.getMessage()); r.setStatus( "error" ); e.printStackTrace(); } return ResponseEntity.ok(r); } /** * 查询用户列表 * @return */ @ApiOperation (value= "获取用户列表" , notes= "获取用户列表" ) @RequestMapping (value = "users" , method = RequestMethod.GET) public ResponseEntity<JsonResult> getUserList (){ JsonResult r = new JsonResult(); try { List<User> userList = new ArrayList<User>(users.values()); r.setResult(userList); r.setStatus( "ok" ); } catch (Exception e) { r.setResult(e.getClass().getName() + ":" + e.getMessage()); r.setStatus( "error" ); e.printStackTrace(); } return ResponseEntity.ok(r); } /** * 添加用户 * @param user * @return */ @ApiOperation (value= "创建用户" , notes= "根据User对象创建用户" ) @ApiImplicitParam (name = "user" , value = "用户详细实体user" , required = true , dataType = "User" ) @RequestMapping (value = "user" , method = RequestMethod.POST) public ResponseEntity<JsonResult> add ( @RequestBody User user){ JsonResult r = new JsonResult(); try { users.put(user.getId(), user); r.setResult(user.getId()); r.setStatus( "ok" ); } catch (Exception e) { r.setResult(e.getClass().getName() + ":" + e.getMessage()); r.setStatus( "error" ); e.printStackTrace(); } return ResponseEntity.ok(r); } /** * 根据id删除用户 * @param id * @return */ @ApiOperation (value= "删除用户" , notes= "根据url的id来指定删除用户" ) @ApiImplicitParam (name = "id" , value = "用户ID" , required = true , dataType = "Long" , paramType = "path" ) @RequestMapping (value = "user/{id}" , method = RequestMethod.DELETE) public ResponseEntity<JsonResult> delete ( @PathVariable (value = "id" ) Integer id){ JsonResult r = new JsonResult(); try { users.remove(id); r.setResult(id); r.setStatus( "ok" ); } catch (Exception e) { r.setResult(e.getClass().getName() + ":" + e.getMessage()); r.setStatus( "error" ); e.printStackTrace(); } return ResponseEntity.ok(r); } /** * 根据id修改用户信息 * @param user * @return */ @ApiOperation (value= "更新信息" , notes= "根据url的id来指定更新用户信息" ) @ApiImplicitParams ({ @ApiImplicitParam (name = "id" , value = "用户ID" , required = true , dataType = "Long" ,paramType = "path" ), @ApiImplicitParam (name = "user" , value = "用户实体user" , required = true , dataType = "User" ) }) @RequestMapping (value = "user/{id}" , method = RequestMethod.PUT) public ResponseEntity<JsonResult> update ( @PathVariable ( "id" ) Integer id, @RequestBody User user){ JsonResult r = new JsonResult(); try { User u = users.get(id); u.setUsername(user.getUsername()); u.setAge(user.getAge()); users.put(id, u); r.setResult(u); r.setStatus( "ok" ); } catch (Exception e) { r.setResult(e.getClass().getName() + ":" + e.getMessage()); r.setStatus( "error" ); e.printStackTrace(); } return ResponseEntity.ok(r); } @ApiIgnore //使用该注解忽略这个API @RequestMapping (value = "/hi" , method = RequestMethod.GET) public String jsonTest() { return " hi you!" ; } } |
5)Json格式输出类 JsonResult.class
1 2 3 4 5 6 7 8 | public class JsonResult { private String status = null ; private Object result = null ; // Getter Setter } |
6)Swagger访问与使用
启动springBoot项目,访问api首页路径:http://localhost:8080/swagger-ui.html
建议在生产环境关闭Swagger2!
@RestControllerpublic
class UserController {
// 创建线程安全的Map
static Map<Integer, User> users = Collections.synchronizedMap(new HashMap<Integer, User>());
/**
* 根据ID查询用户 * @param id * @return
*/
@ApiOperation(value = "获取用户详细信息", notes = "根据url的id来获取用户详细信息")
@ApiImplicitParam(name = "id", value = "用户ID", required = true, dataType = "Integer", paramType = "path")
@RequestMapping(value = "user/{id}", method = RequestMethod.GET)
public ResponseEntity<JsonResult> getUserById(@PathVariable(value = "id") Integer id) {
JsonResult r = new JsonResult();
try {
User user = users.get(id);
r.setResult(user);
r.setStatus("ok");
} catch (Exception e) {
r.setResult(e.getClass().getName() + ":" + e.getMessage());
r.setStatus("error");
e.printStackTrace();
}
return ResponseEntity.ok(r);
}
/**
* 查询用户列表 * @return
*/
@ApiOperation(value = "获取用户列表", notes = "获取用户列表")
@RequestMapping(value = "users", method = RequestMethod.GET)
public ResponseEntity<JsonResult> getUserList() {
JsonResult r = new JsonResult();
try {
List<User> userList = new ArrayList<User>(users.values());
r.setResult(userList);
r.setStatus("ok");
} catch (Exception e) {
r.setResult(e.getClass().getName() + ":" + e.getMessage());
r.setStatus("error");
e.printStackTrace();
}
return ResponseEntity.ok(r);
}
/**
* 添加用户 * @param user * @return
*/
@ApiOperation(value = "创建用户", notes = "根据User对象创建用户")
@ApiImplicitParam(name = "user", value = "用户详细实体user", required = true, dataType = "User")
@RequestMapping(value = "user", method = RequestMethod.POST)
public ResponseEntity<JsonResult> add(@RequestBody User user) {
JsonResult r = new JsonResult();
try {
users.put(user.getId(), user);
r.setResult(user.getId());
r.setStatus("ok");
} catch (Exception e) {
r.setResult(e.getClass().getName() + ":" + e.getMessage());
r.setStatus("error");
e.printStackTrace();
}
return ResponseEntity.ok(r);
}
/**
* 根据id删除用户 * @param id * @return
*/
@ApiOperation(value = "删除用户", notes = "根据url的id来指定删除用户")
@ApiImplicitParam(name = "id", value = "用户ID", required = true, dataType = "Long", paramType = "path")
@RequestMapping(value = "user/{id}", method = RequestMethod.DELETE)
public ResponseEntity<JsonResult> delete(@PathVariable(value = "id") Integer id) {
JsonResult r = new JsonResult();
try {
users.remove(id);
r.setResult(id);
r.setStatus("ok");
} catch (Exception e) {
r.setResult(e.getClass().getName() + ":" + e.getMessage());
r.setStatus("error");
e.printStackTrace();
}
return ResponseEntity.ok(r);
}
/**
* 根据id修改用户信息 * @param user * @return
*/
@ApiOperation(value = "更新信息", notes = "根据url的id来指定更新用户信息")
@ApiImplicitParams({@ApiImplicitParam(name = "id", value = "用户ID", required = true, dataType = "Long", paramType = "path"), @ApiImplicitParam(name = "user", value = "用户实体user", required = true, dataType = "User")})
@RequestMapping(value = "user/{id}", method = RequestMethod.PUT)
public ResponseEntity<JsonResult> update(@PathVariable("id") Integer id, @RequestBody User user) {
JsonResult r = new JsonResult();
try {
User u = users.get(id);
u.setUsername(user.getUsername());
u.setAge(user.getAge());
users.put(id, u);
r.setResult(u);
r.setStatus("ok");
} catch (Exception e) {
r.setResult(e.getClass().getName() + ":" + e.getMessage());
r.setStatus("error");
e.printStackTrace();
}
return ResponseEntity.ok(r);
}
@ApiIgnore//使用该注解忽略这个API
@RequestMapping(value = "/hi", method = RequestMethod.GET)
public String jsonTest() { return " hi you!"; }
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构