springboot3.X 无法解析parameter参数问题分析

 更新时间:2025年03月11日 10:56:47   作者:m0_74823471  
本文介绍了Spring Boot 3.2.1版本中调用接口时出现的参数解析问题,该错误是由Spring新版本加强的错误校验和报错提示导致的,在Spring 6.1之后,官方要求URL中的传参必须使用`@PathVariable`声明用于接收的变量,而不能省略`@RequestParam`注解,感兴趣的朋友一起看看吧
本文参考转载:https://oldmoon.top/post/191

简介

使用最新版的Springboot 3.2.1(我使用3.2.0)搭建开发环境进行开发,调用接口时出现奇怪的错。报错主要信息如下:

Name for argument of type [java.lang.String] not specified, and parameter name information not available via reflection. Ensure that the compiler uses the ‘-parameters’ flag.

原因分析

首先,这是Spring新版本导致的。为什么会出现这个问题呢?原来是Spring 6.1之后,官方加强了很多错误校验和报错提示,本文这个错也是其中之一。

Spring表示:URL中的传参,必须使用@PathVariable声明用于接收的变量,如:

@DeleteMapping("/employees/{employeeId}") 
public String deleteEmployee(@PathVariable int employeeId) { 
    ... 
} 
@PatchMapping("/employees/{id}/{firstName}") 
public String patchEmployee(@PathVariable Integer id, @PathVariable String firstName) { 
    ... 
}

官方说明中一直强调@PathVariable的使用,并没有提及@RequestParam,参考官方文档@RequestParam会发现最后有一句话:

Note that use of@RequestParamis optional (for example, to set its attributes). By default, any argument that is a simple value type (as determined by BeanUtils#isSimpleProperty) and is not resolved by any other argument resolver, is treated as if it were annotated with@RequestParam.

翻译一下大概是:

注意@RequestParam的使用是可选的(例如,设置其属性)。 默认情况下,任何简单值类型(由 BeanUtils#isSimpleProperty 确定)且未由任何其他参数解析器解析的参数都将被视为使用@RequestParam注解。

根据原文及翻译,这自然让我认为,@RequestParam依然是可以省略的。

然而奇怪的是,当Springboot 3.2.1使用Maven管理项目时,如果不使用spring-boot-starter-parent作为父工程,那么接口中必须显式声明@RequestParam("name"),缺了其中的name也会报错。我清晰地记得我在旧版本的 Springboot 中经常省略 @RequestParam(“name”) 这种写法。

但如果不使用spring-boot-starter-parent作为父工程,好像@RequestParam变成了不可省略注解。大家搭建微服务和多模块时候,通常不会使用spring-boot-starter-parent作为父工程吧?还是只有我不用?。。。 还是尽量不要尝试新版本,会少踩很多坑

错误代码

当请求URL中有正常参数时,如:http://localhost:8080/user/hello?name=zhangsan,其中name为一个参数,你的Controller代码大概如下所示:

@GetMapping("/hello") 
public RespPack<?> hello(String name) { 
    return null; 
}

主要pom.xml

  <dependencyManagement> 
      <dependencies> 
          <dependency> 
          <groupId>org.springframework.boot</groupId> 
          <artifactId>spring-boot-dependencies</artifactId> 
          <version>${boot.version}</version> 
          <type>pom</type> 
          <scope>import</scope> 
          </dependency> 
      </dependencies> 
  </dependencyManagement> 
  <dependencies> 
      <dependency> 
          <groupId>org.springframework.boot</groupId> 
          <artifactId>spring-boot-starter-web</artifactId> 
      </dependency> 
  </dependencies>

解决

这种现象不知道是不是官方的BUG,但目前我发现几种解决方案:

  • 在参数上使用@RequestParam("name")
  • 使用spring-boot-starter-parent
<!-- 将spring-boot-starter-parent作为父工程在pom.xml中引入 --> 
<parent> 
    <groupId>org.springframework.boot</groupId> 
    <artifactId>spring-boot-starter-parent</artifactId> 
    <version>3.2.1</version> 
    <relativePath/> 
</parent>

maven-compiler-plugin

网友提除解决方案:父pom或本身pom中添加maven-compiler-plugin的配置:

<build> 
    <plugin> 
    <groupId>org.apache.maven.plugins</groupId> 
    <artifactId>maven-compiler-plugin</artifactId> 
    <version>3.12.0</version>
    <configuration> 
        <parameters>true</parameters> 
    </configuration> 
    </plugin>
</build> 

这可确保使用-parameters标志编译代码,从而使参数名称在运行时可用。

到此这篇关于springboot3.X 无法解析parameter参数问题的文章就介绍到这了,更多相关springboot无法解析parameter参数内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Java多线程之锁学习(增强版)

    Java多线程之锁学习(增强版)

    这篇文章主要为大家详细介绍了Java多线程中锁的相关知识,文中的示例代码讲解详细,对我们了解线程有一定帮助,需要的可以参考一下
    2023-02-02
  • 一文精通Spring Boot序列化与反序列化(告别数据混乱)

    一文精通Spring Boot序列化与反序列化(告别数据混乱)

    本篇文章主要介绍了序列化与反序列化的概念,以及在SpringBoot中的应用,文章通过通俗易懂的语言和比喻,深入浅出地解释了这两个过程,并展示了SpringBoot如何通过SpringMVC和Jackson库简化数据格式转换,感兴趣的朋友跟随小编一起看看吧
    2026-03-03
  • DoytoQuery中的关联查询方案示例详解

    DoytoQuery中的关联查询方案示例详解

    这篇文章主要为大家介绍了DoytoQuery中的关联查询方案示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-12-12
  • Java实现Linux下双守护进程

    Java实现Linux下双守护进程

    这篇文章主要介绍了Java实现Linux下双守护进程的思路、原理以及具体实现方式,非常的详细,希望对大家有所帮助
    2014-10-10
  • 从 Spring Boot 3+Java 21 到 Spring Boot 4+Java 25迁移全指南与注意事项

    从 Spring Boot 3+Java 21 到 Spri

    本文介绍了从SpringBoot3+Java21升级到SpringBoot4+Java25的具体步骤与注意事项,主要包含环境与依赖自查、代码适配、进阶优化、测试与验证以及迁移checklist等内容,感兴趣的朋友跟随小编一起看看吧
    2026-04-04
  • JAVA解析XML字符串简单方法代码案例

    JAVA解析XML字符串简单方法代码案例

    这篇文章主要介绍了JAVA解析XML字符串简单方法代码案例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-09-09
  • Spring Cloud Ribbon配置详解

    Spring Cloud Ribbon配置详解

    这篇文章主要介绍了Spring Cloud Ribbon配置详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-01-01
  • mybatis-generator 修改表结构后实体不更新问题及解决方法

    mybatis-generator 修改表结构后实体不更新问题及解决方法

    本文主要介绍了如何在MyBatis Generator中修改表结构后更新实体类的问题,并提供了解决方案,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
    2025-04-04
  • Java查搜索文件内容实现方式

    Java查搜索文件内容实现方式

    用户为解决无法搜索文件内容的问题,编写了一个支持单文件、文件夹及多层递归查找的工具,具备字符串匹配及忽略大小写功能,并计划扩展日期、创建人等组合搜索条件,最终打包成exe便于快速查找所有文件内容
    2025-09-09
  • JAVA基础之数组和集合区别对比分析

    JAVA基础之数组和集合区别对比分析

    文章主要介绍了Java中数组和集合的基本概念、使用方法以及它们之间的区别,文章还探讨了不可变集合的创建方式及其线程安全和不可篡改的优势,感兴趣的朋友跟随小编一起看看吧
    2025-11-11

最新评论