news 2026/5/16 14:55:19

【knife4j】接口分组配置;登录拦截器放行;登录拦截器配置token;给全局异常处理类添加注解;解决上传文件不显示文件域;参数扁平化;@Parameter

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【knife4j】接口分组配置;登录拦截器放行;登录拦截器配置token;给全局异常处理类添加注解;解决上传文件不显示文件域;参数扁平化;@Parameter

@Parameter

@Parameter是用来为 API 接口参数添加元数据(描述信息)的注解,这些信息最终会生成到 OpenAPI 规范的文档中,供 Knife4j/Swagger UI 等工具展示

简单来说:它让 API 的使用者能清楚地知道每个参数的含义、是否必填、格式要求等

@Operation(summary = "查询指定课程的学习记录") @GetMapping("/course/{courseId}") public LearningLessonDTO queryLearningRecordByCourse( @PathVariable @Parameter(description = "课程id", example = "2") Long courseId){ return recordService.queryLearningRecordByCourse(courseId); }

参数扁平化

springdoc: default-flat-param-object: true

效果:

没有添加配置效果:

接口分组配置

088-尚庭公寓-项目开发-后台管理-初始配置-Knife4j_哔哩哔哩_bilibili

后台管理系统和移动端接口不同

web

@Configuration public class Knife4jConfiguration { // 配置了接口文档的基本信息 @Bean public OpenAPI customOpenAPI() { return new OpenAPI() .info(new Info() .title("后台管理系统API") .version("1.0") .description("后台管理系统API"); } // 下面的Bean对应一个个的接口分组 // @Bean public GroupedOpenApi systemAPI() { return GroupedOpenApi.builder().group("系统信息管理"). pathsToMatch( "/admin/system/**" ). build(); } @Bean public GroupedOpenApi loginAPI() { return GroupedOpenApi.builder().group("登录管理"). pathsToMatch( "/admin/login/**", "/admin/info"). build(); } @Bean public GroupedOpenApi apartmentAPI() { return GroupedOpenApi.builder().group("公寓信息管理"). pathsToMatch( "/admin/apartment/**", "/admin/room/**", "/admin/label/**", "/admin/facility/**", "/admin/fee/**", "/admin/attr/**", "/admin/payment/**", "/admin/region/**", "/admin/term/**", "/admin/file/**" ).build(); } @Bean public GroupedOpenApi leaseAPI() { return GroupedOpenApi.builder().group("租赁信息管理"). pathsToMatch( "/admin/appointment/**", "/admin/agreement/**" ).build(); } @Bean public GroupedOpenApi userAPI() { return GroupedOpenApi.builder().group("平台用户管理"). pathsToMatch( "/admin/user/**" ).build(); } }

app

@Configuration public class Knife4jConfiguration { @Bean public OpenAPI customOpenAPI() { return new OpenAPI() .info(new Info() .title("APP接口") .version("1.0") .description("用户端APP接口");+ } @Bean public GroupedOpenApi userAPI() { return GroupedOpenApi.builder().group("用户信息"). pathsToMatch("/app/user/**"). build(); } @Bean public GroupedOpenApi loginAPI() { return GroupedOpenApi.builder().group("登录信息"). pathsToMatch("/app/login/**", "/app/info"). build(); } @Bean public GroupedOpenApi personAPI() { return GroupedOpenApi.builder().group("个人信息"). pathsToMatch( "/app/history/**", "/app/appointment/**", "/app/agreement/**" ). build(); } @Bean public GroupedOpenApi lookForRoomAPI() { return GroupedOpenApi.builder().group("找房信息"). pathsToMatch( "/app/apartment/**", "/app/room/**", "/app/payment/**", "/app/region/**", "/app/term/**" ). build(); } }

登录拦截器放行

3.5 访问权限控制 | Knife4j

这些是knife4j需要的路径

给登录拦截器放行

@Configuration @RequiredArgsConstructor public class WebConfig implements WebMvcConfigurer { private final LoginInterceptor loginInterceptor; @Override public void addInterceptors(InterceptorRegistry registry) { // 将拦截器注册到Spring MVC的拦截器链中 registry.addInterceptor(loginInterceptor) .addPathPatterns("/**") .excludePathPatterns( "/v3/api-docs/**", "/doc.html", "/swagger-ui/**", "/swagger-resources/**" ); } }

让接口文档带上token

146-尚庭公寓-项目开发-后台管理-系统管理-登录管理-拦截器_哔哩哔哩_bilibili

让接口文档在发送测试请求时,带上token

之后就能通过拦截器的验证

这个全局参数只对当前分组生效,有多个分组要设置多次

参数名称和前端约定好

参数值获取真实的token

如果是自己生成token,为了方便可以调整有效期

生成完后,再恢复成一小时的有效期

需要给全局异常处理类添加注解

关于异常java.lang.NoSuchMethodError: ‘void org.springframework.web.method.ControllerAdviceBean.<init>(ja_java.lang.nosuchmethoderror: 'void org.springframe-CSDN博客

使用@Hidden,不然接口文档报错

// common模块/exception /** * 全局异常处理器 * Knife4j(Swagger)全局异常添加@Hidden防止报错 */ @Hidden @ControllerAdvice public class GlobalExceptionHandler { @ExceptionHandler(Exception.class) @ResponseBody public Result handle(Exception e){ e.printStackTrace(); return Result.fail(); } }

解决上传文件不显示文件域

【Knife4j】解决SpringBoot整合Knife4j 3.0.3 文件上传不显示文件域_knife4j调试文件传参,选不了文件-CSDN博客

使用@RequestPart,我之前使用了@RequestParam,没用

@Tag(name = "文件管理") @RequestMapping("/file") @RestController @RequiredArgsConstructor public class FileUploadController { private final FileService fileService; @Operation(summary = "上传文件") @PostMapping("upload") public Result<String> upload(@RequestPart("file") MultipartFile file) throws ServerException, InsufficientDataException, ErrorResponseException, IOException, NoSuchAlgorithmException, InvalidKeyException, InvalidResponseException, XmlParserException, InternalException { String url = fileService.uploadFile(file); return Result.ok(url); } }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/16 14:54:20

知乎API开发完全指南:从零开始构建你的数据采集系统

知乎API开发完全指南&#xff1a;从零开始构建你的数据采集系统 【免费下载链接】zhihu-api Zhihu API for Humans 项目地址: https://gitcode.com/gh_mirrors/zh/zhihu-api 你是否曾想批量获取知乎上的优质内容&#xff1f;或是自动化处理知乎上的日常操作&#xff1f;…

作者头像 李华
网站建设 2026/5/16 14:51:07

观察Taotoken账单明细如何帮助精准核算项目AI调用成本

&#x1f680; 告别海外账号与网络限制&#xff01;稳定直连全球优质大模型&#xff0c;限时半价接入中。 &#x1f449; 点击领取海量免费额度 观察Taotoken账单明细如何帮助精准核算项目AI调用成本 在将大模型能力集成到产品或服务中的过程中&#xff0c;除了技术实现&#…

作者头像 李华
网站建设 2026/5/16 14:51:07

Codex和ChatGPT合体!补上24小时干活的最后一块拼图

西风 发自 凹非寺量子位 | 公众号 QbitAI刚刚&#xff0c;手机和Codex打通了&#xff01;OpenAI宣布“ChatGPT移动APP中的Codex”开启内测预览。现在&#xff0c;打开手机或iPad上的ChatGPT APP&#xff0c;就能直接给Codex开新任务、查看生成结果、把控执行流程、确认下一步操…

作者头像 李华