news 2026/4/16 9:17:26

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/4/8 20:05:20

ModbusTCP协议详解:报文结构深度剖析

ModbusTCP协议详解&#xff1a;报文结构深度剖析从工业现场到IP网络&#xff1a;为什么Modbus没有被淘汰&#xff1f;在智能制造和工业物联网&#xff08;IIoT&#xff09;席卷全球的今天&#xff0c;你可能以为那些诞生于上世纪70年代的通信协议早已被边缘化。但现实是——Mod…

作者头像 李华
网站建设 2026/4/15 16:07:32

YOLOFuse macOS M1芯片适配进展通报

YOLOFuse macOS M1芯片适配进展通报 在智能安防、自动驾驶和工业视觉检测日益依赖多模态感知的今天&#xff0c;如何在复杂光照条件下稳定识别目标&#xff0c;成为算法落地的关键挑战。可见光图像在夜间或烟雾环境中容易失效&#xff0c;而红外成像能捕捉热辐射信息&#xff0…

作者头像 李华
网站建设 2026/4/2 13:41:24

YOLOFuse Slack 工作区邀请:企业级协作沟通平台

YOLOFuse Slack 工作区邀请&#xff1a;企业级协作沟通平台 在智能监控系统日益复杂的今天&#xff0c;如何让AI模型在夜间、烟雾或强光干扰下依然“看得清”&#xff0c;已成为安防与工业检测领域的核心挑战。单一的可见光摄像头在低光照环境中表现乏力&#xff0c;而红外图像…

作者头像 李华
网站建设 2026/4/15 11:41:03

YOLOFuse VR 交互演示开发:沉浸式体验多模态融合

YOLOFuse VR 交互演示开发&#xff1a;沉浸式体验多模态融合 在深夜的监控中心&#xff0c;屏幕上的可见光摄像头画面一片漆黑&#xff0c;只能隐约看到模糊轮廓。而隔壁房间的消防演练现场&#xff0c;浓烟弥漫&#xff0c;传统视觉系统几乎“失明”。这时&#xff0c;如果有一…

作者头像 李华
网站建设 2026/4/11 1:36:19

YOLOFuse命令行参数配置:自定义学习率与batch size方法

YOLOFuse命令行参数配置&#xff1a;自定义学习率与batch size方法 在智能监控、夜间巡检和自动驾驶等现实场景中&#xff0c;单一可见光摄像头常常“力不从心”——昏暗环境、强逆光或烟雾遮挡下&#xff0c;目标几乎无法辨识。这时候&#xff0c;红外&#xff08;IR&#xf…

作者头像 李华
网站建设 2026/4/15 5:48:54

YOLOFuse适合GPU算力用户:高效利用显存资源进行训练

YOLOFuse&#xff1a;让普通GPU也能高效训练多模态目标检测 在安防监控摄像头深夜模糊失焦、自动驾驶车辆因浓雾误判前方障碍物的现实场景中&#xff0c;单一可见光图像的局限性暴露无遗。即便最先进的YOLOv8&#xff0c;在完全黑暗或强遮挡环境下也会“失明”。这时候&#xf…

作者头像 李华