E:\jdk17\bin\java.exe -XX:TieredStopAtLevel=1 -Dspring.output.ansi.enabled=always -Dcom.sun.management.jmxremote -Dspring.jmx.enabled=true -Dspring.liveBeansView.mbeanDomain -Dspring.application.admin.enabled=true "-Dmanagement.endpoints.jmx.exposure.include=*" "-javaagent:E:\Java Web\IntelliJ IDEA 2023.3.1\lib\idea_rt.jar=55518:E:\Java Web\IntelliJ IDEA 2023.3.1\bin" -Dfile.encoding=UTF-8 -classpath "E:\web projects\StuInfoSystem-master\target\classes;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\webjars\bootstrap\4.0.0\bootstrap-4.0.0.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\webjars\npm\popper.js\1.11.1\popper.js-1.11.1.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\webjars\jquery\3.3.1\jquery-3.3.1.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\springframework\boot\spring-boot-starter-jdbc\2.6.1\spring-boot-starter-jdbc-2.6.1.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\springframework\boot\spring-boot-starter\2.6.1\spring-boot-starter-2.6.1.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\springframework\boot\spring-boot\2.6.1\spring-boot-2.6.1.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\springframework\boot\spring-boot-autoconfigure\2.6.1\spring-boot-autoconfigure-2.6.1.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\springframework\boot\spring-boot-starter-logging\2.6.1\spring-boot-starter-logging-2.6.1.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\ch\qos\logback\logback-classic\1.2.7\logback-classic-1.2.7.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\ch\qos\logback\logback-core\1.2.7\logback-core-1.2.7.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\apache\logging\log4j\log4j-to-slf4j\2.14.1\log4j-to-slf4j-2.14.1.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\apache\logging\log4j\log4j-api\2.14.1\log4j-api-2.14.1.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\slf4j\jul-to-slf4j\1.7.32\jul-to-slf4j-1.7.32.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\yaml\snakeyaml\1.29\snakeyaml-1.29.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\com\zaxxer\HikariCP\4.0.3\HikariCP-4.0.3.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\slf4j\slf4j-api\1.7.32\slf4j-api-1.7.32.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\springframework\spring-jdbc\5.3.13\spring-jdbc-5.3.13.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\springframework\spring-beans\5.3.13\spring-beans-5.3.13.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\springframework\spring-tx\5.3.13\spring-tx-5.3.13.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\mysql\mysql-connector-java\8.0.11\mysql-connector-java-8.0.11.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\springframework\boot\spring-boot-starter-thymeleaf\2.6.1\spring-boot-starter-thymeleaf-2.6.1.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\thymeleaf\thymeleaf-spring5\3.0.9.RELEASE\thymeleaf-spring5-3.0.9.RELEASE.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\thymeleaf\thymeleaf\3.0.9.RELEASE\thymeleaf-3.0.9.RELEASE.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\attoparser\attoparser\2.0.4.RELEASE\attoparser-2.0.4.RELEASE.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\unbescape\unbescape\1.1.5.RELEASE\unbescape-1.1.5.RELEASE.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\thymeleaf\extras\thymeleaf-extras-java8time\3.0.4.RELEASE\thymeleaf-extras-java8time-3.0.4.RELEASE.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\com\alibaba\druid\1.1.8\druid-1.1.8.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\net\minidev\json-smart\2.2.1\json-smart-2.2.1.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\net\minidev\accessors-smart\1.1\accessors-smart-1.1.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\ow2\asm\asm\5.0.3\asm-5.0.3.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\springframework\boot\spring-boot-starter-web\2.6.1\spring-boot-starter-web-2.6.1.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\springframework\boot\spring-boot-starter-json\2.6.1\spring-boot-starter-json-2.6.1.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\com\fasterxml\jackson\core\jackson-databind\2.13.0\jackson-databind-2.13.0.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\com\fasterxml\jackson\core\jackson-annotations\2.13.0\jackson-annotations-2.13.0.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\com\fasterxml\jackson\core\jackson-core\2.13.0\jackson-core-2.13.0.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\com\fasterxml\jackson\datatype\jackson-datatype-jdk8\2.13.0\jackson-datatype-jdk8-2.13.0.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\com\fasterxml\jackson\datatype\jackson-datatype-jsr310\2.13.0\jackson-datatype-jsr310-2.13.0.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\com\fasterxml\jackson\module\jackson-module-parameter-names\2.13.0\jackson-module-parameter-names-2.13.0.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\springframework\spring-web\5.3.13\spring-web-5.3.13.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\springframework\spring-webmvc\5.3.13\spring-webmvc-5.3.13.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\springframework\spring-aop\5.3.13\spring-aop-5.3.13.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\springframework\spring-context\5.3.13\spring-context-5.3.13.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\mybatis\spring\boot\mybatis-spring-boot-starter\1.3.1\mybatis-spring-boot-starter-1.3.1.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\mybatis\spring\boot\mybatis-spring-boot-autoconfigure\1.3.1\mybatis-spring-boot-autoconfigure-1.3.1.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\mybatis\mybatis\3.4.5\mybatis-3.4.5.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\mybatis\mybatis-spring\1.3.1\mybatis-spring-1.3.1.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\springframework\boot\spring-boot-starter-tomcat\2.6.1\spring-boot-starter-tomcat-2.6.1.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\jakarta\annotation\jakarta.annotation-api\1.3.5\jakarta.annotation-api-1.3.5.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\apache\tomcat\embed\tomcat-embed-core\9.0.55\tomcat-embed-core-9.0.55.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\apache\tomcat\embed\tomcat-embed-el\9.0.55\tomcat-embed-el-9.0.55.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\apache\tomcat\embed\tomcat-embed-websocket\9.0.55\tomcat-embed-websocket-9.0.55.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\hamcrest\hamcrest\2.2\hamcrest-2.2.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\springframework\spring-core\5.3.13\spring-core-5.3.13.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\springframework\spring-jcl\5.3.13\spring-jcl-5.3.13.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\junit\junit\4.12\junit-4.12.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\hamcrest\hamcrest-core\2.2\hamcrest-core-2.2.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\springframework\boot\spring-boot-configuration-processor\2.6.1\spring-boot-configuration-processor-2.6.1.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\apache\ibatis\ibatis-core\3.0\ibatis-core-3.0.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\javax\servlet\javax.servlet-api\3.1.0\javax.servlet-api-3.1.0.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\springframework\spring-expression\4.3.16.RELEASE\spring-expression-4.3.16.RELEASE.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\springframework\boot\spring-boot-starter-validation\2.6.1\spring-boot-starter-validation-2.6.1.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\hibernate\validator\hibernate-validator\6.2.0.Final\hibernate-validator-6.2.0.Final.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\jakarta\validation\jakarta.validation-api\2.0.2\jakarta.validation-api-2.0.2.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\org\jboss\logging\jboss-logging\3.4.2.Final\jboss-logging-3.4.2.Final.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\com\fasterxml\classmate\1.5.1\classmate-1.5.1.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\com\github\pagehelper\pagehelper-spring-boot-starter\1.2.10\pagehelper-spring-boot-starter-1.2.10.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\com\github\pagehelper\pagehelper-spring-boot-autoconfigure\1.2.10\pagehelper-spring-boot-autoconfigure-1.2.10.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\com\github\pagehelper\pagehelper\5.1.8\pagehelper-5.1.8.jar;E:\Java Web\javawebb\maven\apache-maven-3.9.9\maven-repo\com\github\jsqlparser\jsqlparser\1.2\jsqlparser-1.2.jar" com.lc.demo.DemoApplication . ____ _ __ _ _ /\\ / ___'_ __ _ _(_)_ __ __ _ \ \ \ \ ( ( )\___ | '_ | '_| | '_ \/ _` | \ \ \ \ \\/ ___)| |_)| | | | | || (_| | ) ) ) ) ' |____| .__|_| |_|_| |_\__, | / / / / =========|_|==============|___/=/_/_/_/ :: Spring Boot :: (v2.6.1) 2025-06-16 21:38:40.465 INFO 17588 --- [ main] com.lc.demo.DemoApplication : Starting DemoApplication using Java 17.0.11 on Cui with PID 17588 (E:\web projects\StuInfoSystem-master\target\classes started by 19811 in E:\web projects\StuInfoSystem-master) 2025-06-16 21:38:40.468 INFO 17588 --- [ main] com.lc.demo.DemoApplication : No active profile set, falling back to default profiles: default 2025-06-16 21:38:40.584 WARN 17588 --- [ main] ConfigServletWebServerApplicationContext : Exception encountered during context initialization - cancelling refresh attempt: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'org.springframework.context.annotation.internalConfigurationAnnotationProcessor': Cannot resolve reference to bean 'org.springframework.boot.autoconfigure.internalCachingMetadataReaderFactory' while setting bean property 'metadataReaderFactory'; nested exception is org.springframework.beans.factory.BeanExpressionException: Expression parsing failed; nested exception is java.lang.NoSuchMethodError: 'void org.springframework.expression.spel.support.StandardTypeConverter.<init>(java.util.function.Supplier)' 2025-06-16 21:38:40.898 ERROR 17588 --- [ main] o.s.b.d.LoggingFailureAnalysisReporter : *************************** APPLICATION FAILED TO START *************************** Description: An attempt was made to call a method that does not exist. The attempt was made from the following location: org.springframework.context.expression.StandardBeanExpressionResolver.evaluate(StandardBeanExpressionResolver.java:160) The following method did not exist: 'void org.springframework.expression.spel.support.StandardTypeConverter.<init>(java.util.function.Supplier)' The calling method's class, org.springframework.context.expression.StandardBeanExpressionResolver, was loaded from the following location: jar:file:/E:/Java%20Web/javawebb/maven/apache-maven-3.9.9/maven-repo/org/springframework/spring-context/5.3.13/spring-context-5.3.13.jar!/org/springframework/context/expression/StandardBeanExpressionResolver.class The called method's class, org.springframework.expression.spel.support.StandardTypeConverter, is available from the following locations: jar:file:/E:/Java%20Web/javawebb/maven/apache-maven-3.9.9/maven-repo/org/springframework/spring-expression/4.3.16.RELEASE/spring-expression-4.3.16.RELEASE.jar!/org/springframework/expression/spel/support/StandardTypeConverter.class The called method's class hierarchy was loaded from the following locations: org.springframework.expression.spel.support.StandardTypeConverter: file:/E:/Java%20Web/javawebb/maven/apache-maven-3.9.9/maven-repo/org/springframework/spring-expression/4.3.16.RELEASE/spring-expression-4.3.16.RELEASE.jar Action: Correct the classpath of your application so that it contains compatible versions of the classes org.springframework.context.expression.StandardBeanExpressionResolver and org.springframework.expression.spel.support.StandardTypeConverter 进程已结束,退出代码为 1
时间: 2025-08-01 12:38:25 浏览: 14
<think>我们面临的问题是SpringBoot启动时因`spring-context`和`spring-expression`版本不兼容导致的`NoSuchMethodError`。具体错误信息是:`NoSuchMethodError:voidorg.springframework.expression.spel.support.StandardTypeConverter.<init>(java.util.function.Supplier)`根据引用[1]和引用[2]的信息,这类问题通常是由于不同版本的Spring模块之间不兼容导致的。引用[1]提到在SPEL(SpringExpressionLanguage)的使用中,将版本从5.x降低到4.x解决了问题。引用[2]则指出NoSuchMethodError通常是由于版本冲突引起的。###问题分析-错误信息指向`StandardTypeConverter`的构造函数,该构造函数在`spring-expression`模块中。-你当前使用的版本:-`spring-context:5.3.13`-`spring-expression:4.3.16`这两个版本分别属于SpringFramework5.3和4.3,它们之间存在不兼容。在SpringFramework5.x中,`StandardTypeConverter`的构造函数发生了变化。在5.x版本中,它接受一个`java.util.function.Supplier`参数,而在4.x版本中,它的构造函数参数是不同的。因此,当`spring-context`5.3.13尝试使用`spring-expression`4.3.16中的`StandardTypeConverter`类时,找不到匹配的构造函数,从而抛出`NoSuchMethodError`。###解决方案核心思路:统一Spring相关模块的版本,确保所有Spring模块使用相同的版本。####1.使用SpringBoot的依赖管理(推荐)SpringBoot的`spring-boot-starter-parent`或`spring-boot-dependencies`已经管理了Spring相关模块的版本,因此我们不应该单独指定Spring模块的版本,而是继承或导入SpringBoot的版本管理。**步骤**:1.确保你的项目使用SpringBoot的父POM或导入BOM(BillofMaterials)。-使用父POM:```xml<parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.5.8</version><!--请选择与你的项目兼容的版本,例如2.5.8对应SpringFramework5.3.13--><relativePath/><!--lookupparentfromrepository--></parent>```-或者,在依赖管理部分导入BOM:```xml<dependencyManagement><dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-dependencies</artifactId><version>2.5.8</version><type>pom</type><scope>import</scope></dependency></dependencies></dependencyManagement>```2.移除`spring-expression`和`spring-context`的显式版本声明,让SpringBoot管理版本。```xml<dependencies><!--其他依赖--><dependency><groupId>org.springframework</groupId><artifactId>spring-context</artifactId></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-expression</artifactId></dependency></dependencies>```####2.手动对齐版本(如果无法使用SpringBoot的依赖管理)如果你不能使用SpringBoot的依赖管理,那么需要手动将`spring-expression`的版本升级到与`spring-context`相同的版本(5.3.13):```xml<dependency><groupId>org.springframework</groupId><artifactId>spring-expression</artifactId><version>5.3.13</version><!--与spring-context版本一致--></dependency>```####3.检查依赖树,排除冲突版本使用Maven命令检查依赖树,查看是否有其他依赖引入了旧版本的`spring-expression`:```bashmvndependency:tree```如果发现其他依赖传递引入了旧版本,可以排除它:```xml<dependency><groupId>some.group</groupId><artifactId>some-artifact</artifactId><version>...</version><exclusions><exclusion><groupId>org.springframework</groupId><artifactId>spring-expression</artifactId></exclusion></exclusions></dependency>```###验证执行以下步骤验证问题是否解决:1.清理项目:`mvnclean`2.重新构建:`mvninstall`3.启动应用,观察是否还有`NoSuchMethodError`。###总结Spring框架的不同模块必须保持版本一致。通过使用SpringBoot的依赖管理,可以避免大部分版本冲突问题。如果出现类似错误,首先检查相关模块的版本是否一致,然后通过依赖树分析冲突来源并排除[^1][^2]。§§相关问题§§1.如何查看Maven项目的依赖树以排查版本冲突?2.SpringBoot的起步依赖(starter)是如何管理传递依赖版本的?3.在SpringBoot项目中如何覆盖起步依赖管理的组件版本?</think>### 解决 Spring Boot 启动时版本不兼容导致的 NoSuchMethodError 问题
#### 问题分析
当 `spring-context-5.3.13` 和 `spring-expression-4.3.16` 同时存在时,会出现以下错误:
```java
NoSuchMethodError: void org.springframework.expression.spel.support.StandardTypeConverter.<init>(java.util.function.Supplier)
```
**根本原因**:
- `spring-expression` 4.x 版本中的 `StandardTypeConverter` 类缺少 Spring 5.x 要求的构造函数[^1]
- `spring-context` 5.3.13 尝试调用新构造函数,但 `spring-expression` 4.3.16 未实现该方法
- 版本跨度太大导致 API 不兼容(Spring 4.x → 5.x 有重大变更)[^2]
#### 解决方案
##### 1. 统一版本号(推荐)
在 `pom.xml` 中强制指定兼容版本:
```xml
<properties>
<!-- 统一使用 Spring 5.3.x 系列 -->
<spring.version>5.3.13</spring.version>
</properties>
<dependencies>
<!-- 显式指定版本 -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-expression</artifactId>
<version>${spring.version}</version> <!-- 关键:必须与上下文版本一致 -->
</dependency>
</dependencies>
```
##### 2. 依赖排除法
如果某个依赖强制引入了旧版本:
```xml
<dependency>
<groupId>problematic.group</groupId>
<artifactId>problematic-artifact</artifactId>
<exclusions>
<!-- 排除旧版 spring-expression -->
<exclusion>
<groupId>org.springframework</groupId>
<artifactId>spring-expression</artifactId>
</exclusion>
</exclusions>
</dependency>
<!-- 然后显式引入正确版本 -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-expression</artifactId>
<version>5.3.13</version>
</dependency>
```
##### 3. 使用 Spring Boot 的依赖管理
通过 Spring Boot BOM 自动管理版本:
```xml
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-dependencies</artifactId>
<version>2.5.6</version> <!-- 此版本包含 Spring 5.3.13 -->
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
```
#### 验证步骤
1. **检查依赖树**:
```bash
mvn dependency:tree | grep "spring-expression"
```
输出应显示统一版本:
```
[INFO] | \- org.springframework:spring-expression:jar:5.3.13:compile
```
2. **清理并重建**:
```bash
mvn clean install -U
```
3. **检查构造函数兼容性**:
在反编译工具中验证 `StandardTypeConverter` 类包含:
```java
// Spring 5.x 必须存在的构造函数
public StandardTypeConverter(Supplier<TypeConverter> typeConverterSupplier) {
this.typeConverter = (TypeConverter)ConcurrentReferenceHashMap.soft(typeConverterSupplier);
}
```
#### 版本兼容对照表
| Spring Boot 版本 | Spring Framework 版本 | 是否兼容 |
|------------------|------------------------|----------|
| 2.1.x - 2.4.x | 5.1.x - 5.3.x | ✅ 兼容 |
| 1.5.x | 4.3.x - 4.4.x | ❌ 不兼容 |
| 2.5.x+ | 5.3.x | ✅ 兼容 |
> **关键提示**:Spring 5.x 重构了表达式解析器实现,4.x 到 5.x 是**不兼容升级**。切勿混用大版本[^1][^2]。
阅读全文