news 2026/6/9 22:24:20

Swagger

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Swagger

介绍

使用Swagger你只需要按照它的规范去定义接口及接口相关的信息,就可以做到生成接口文档,以及在线接口调试页面。官网: API Documentation & Design Tools for Teams | Swagger

Knife4j是为Java MVC框架集成Swagger生成Api文档的增强解决方案,对Swagger进行了封装,简化了相应的操作

使用方式

导入Knife4j的maven坐标

<dependency> <groupld>com.github.xiaoymin</groupld> <artifactld>knife4j-spring-boot-starter</artifactld> <version>3.0.2</version> </dependency>

在配置类中加入knife4j相关配置

/** * 通过knife4j生成接口文档 * @return */ @Bean public Docket docket1() { ApiInfo apiInfo = new ApiInfoBuilder() .title("苍穹外卖项目接口文档") .version("2.0") .description("苍穹外卖项目接口文档") .build(); Docket docket = new Docket(DocumentationType.SWAGGER_2) .groupName("管理端接口") .apiInfo(apiInfo) .select() // 指定生成接口需要扫描的包 .apis(RequestHandlerSelectors.basePackage("com.sky.controller.admin")) .paths(PathSelectors.any()) .build(); return docket; } @Bean public Docket docket2() { ApiInfo apiInfo = new ApiInfoBuilder() .title("苍穹外卖项目接口文档") .version("2.0") .description("苍穹外卖项目接口文档") .build(); Docket docket = new Docket(DocumentationType.SWAGGER_2) .groupName("用户端接口") .apiInfo(apiInfo) .select() .apis(RequestHandlerSelectors.basePackage("com.sky.controller.user")) .paths(PathSelectors.any()) .build(); return docket; }

设置静态资源映射,否则接口文档页面无法访问

/** * 设置静态资源映射 * @param registry */ protected void addResourceHandlers(ResourceHandlerRegistry registry) { registry.addResourceHandler("/doc.html").addResourceLocations("classpath:/META-INF/resources/"); registry.addResourceHandler("/webjars/**").addResourceLocations("classpath:/META-INF/resources/webjars/"); }

这个是重写的 WebMvcConfigurationSupport 父类的方法

使用

启动项目后,在浏览器中输入 localhost:8080/doc.html 就能进入查看接口页面

之后就能在这里进行调试了

常见注解

@Api

用在类上,例如Controller,表示对类的说明

@ApiModel

用在类上,例如entity、DTO、VO

@ApiModelProperty

用在属性上,描述属性信息

@ApiOperation

用在方法上,例如Controller的方法,说明方法的用途、作用

例:

/** * 员工管理 */ @RestController @RequestMapping("/admin/employee") @Slf4j @Api(tags = "员工相关接口") public class EmployeeController { @Autowired private EmployeeService employeeService; @Autowired private JwtProperties jwtProperties; /** * 登录 * * @param employeeLoginDTO * @return */ @PostMapping("/login") @ApiOperation("员工登录") public Result<EmployeeLoginVO> login(@RequestBody EmployeeLoginDTO employeeLoginDTO) { log.info("员工登录:{}", employeeLoginDTO); Employee employee = employeeService.login(employeeLoginDTO); //登录成功后,生成jwt令牌 Map<String, Object> claims = new HashMap<>(); claims.put(JwtClaimsConstant.EMP_ID, employee.getId()); String token = JwtUtil.createJWT( jwtProperties.getAdminSecretKey(), jwtProperties.getAdminTtl(), claims); EmployeeLoginVO employeeLoginVO = EmployeeLoginVO.builder() .id(employee.getId()) .userName(employee.getUsername()) .name(employee.getName()) .token(token) .build(); return Result.success(employeeLoginVO); } /** * 退出 * * @return */ @PostMapping("/logout") @ApiOperation("员工退出") public Result<String> logout() { return Result.success(); } /** * 新增员工 * @param employeeDTO * @return */ @PostMapping @ApiOperation("新增员工") public Result save(@RequestBody EmployeeDTO employeeDTO){ log.info("新增员工,员工数据:{}",employeeDTO); employeeService.save(employeeDTO); return Result.success(); } /** * 员工分页查询 * @param employeePageQueryDTO * @return */ @GetMapping("/page") @ApiOperation("员工分页查询") public Result page(EmployeePageQueryDTO employeePageQueryDTO){ log.info("员工分页查询:{}",employeePageQueryDTO); PageResult pageResult = employeeService.pageQuery(employeePageQueryDTO); return Result.success(pageResult); } /** * 启用禁用员工账号 * @param status * @param id * @return */ @PostMapping("/status/{status}") @ApiOperation("启用禁用员工账号") public Result startOrStop(@PathVariable Integer status, Long id){ log.info("员工状态:{},员工id:{}",status,id); employeeService.startOrStop(status,id); return Result.success(); } /** * 根据id查询员工信息 * @param id * @return */ @GetMapping("/{id}") @ApiOperation("根据id查询员工信息") public Result<Employee> getById(@PathVariable Long id){ log.info("根据id查询员工信息:{}",id); Employee employee = employeeService.getById(id); return Result.success(employee); } /** * 编辑员工信息 * @param employeeDTO * @return */ @PutMapping @ApiOperation("编辑员工信息") public Result update(@RequestBody EmployeeDTO employeeDTO){ log.info("编辑员工信息:{}",employeeDTO); employeeService.update(employeeDTO); return Result.success(); } }
@Data @ApiModel(description = "员工登录时传递的数据模型") public class EmployeeLoginDTO implements Serializable { @ApiModelProperty("用户名") private String username; @ApiModelProperty("密码") private String password; }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/9 20:54:04

Jetson Xavier NX快速上手:USB启动模式配置指南

Jetson Xavier NX 无卡启动实战&#xff1a;从零配置 USB 编程模式你有没有遇到过这样的场景&#xff1f;手头的 Jetson Xavier NX 开发板刚到货&#xff0c;兴冲冲插上 SD 卡准备刷机&#xff0c;结果系统写入失败、卡死在 U-Boot 阶段&#xff0c;甚至 TF 卡直接变砖。反复烧…

作者头像 李华
网站建设 2026/6/10 10:58:12

YOLOFuse 区块链代币支付设想:未来支持USDT结算

YOLOFuse 区块链代币支付设想&#xff1a;未来支持USDT结算 在智能安防、无人机巡检和夜间监控等现实场景中&#xff0c;单一可见光摄像头常常因光照不足或环境遮挡而失效。红外图像虽能穿透黑暗&#xff0c;却缺乏纹理细节&#xff0c;单独使用也难以精准识别目标类别。如何融…

作者头像 李华
网站建设 2026/6/9 23:52:03

Flink在大数据领域的安全机制与权限管理

Flink在大数据领域的安全机制与权限管理关键词&#xff1a;Flink、大数据、安全机制、权限管理、数据安全摘要&#xff1a;本文聚焦于Flink在大数据领域的安全机制与权限管理。首先介绍了Flink在大数据环境下安全保障的背景和重要性&#xff0c;接着深入剖析Flink的核心安全概念…

作者头像 李华
网站建设 2026/6/10 10:56:25

未知USB设备(设备描述)在工控安全中的风险与防范完整指南

当“未知USB设备(设备描述)”插入工控主机&#xff1a;一次被忽视的致命渗透 你有没有遇到过这样的场景&#xff1f; 一名现场工程师拿着U盘走到PLC编程电脑前&#xff0c;轻轻一插——系统右下角弹出提示&#xff1a;“ 未知USB设备(设备描述) ”。他皱了皱眉&#xff0c;…

作者头像 李华
网站建设 2026/6/10 10:56:15

Vivado使用教程:无线通信基带模块仿真指南

Vivado实战&#xff1a;手把手带你仿真无线通信基带模块你有没有遇到过这样的场景&#xff1f;写完一个QPSK调制器&#xff0c;心里没底——这代码上板后真能跑通吗&#xff1f;信号会不会乱码&#xff1f;星座图对不对得上&#xff1f;别急&#xff0c;仿真就是你的“数字示波…

作者头像 李华
网站建设 2026/6/10 10:53:48

复杂环境下目标检测新突破:YOLOFuse双流融合技术解析

复杂环境下目标检测新突破&#xff1a;YOLOFuse双流融合技术解析 在城市安防监控的深夜街头&#xff0c;一台普通摄像头画面漆黑一片&#xff0c;而旁边的红外传感器却清晰捕捉到一名可疑人员翻越围栏——但若没有智能算法将两者信息有效结合&#xff0c;这一关键线索仍可能被遗…

作者头像 李华