当项目启动时遇到:java.lang.IllegalAccessError:·····cannot access class sun.security.action.GetPropertyAction

文章讲述了在项目交接时检查JDK版本的重要性,尤其是在从JDK8迁移到JDK11时遇到的问题,如本地运行正常但服务器报错。特别提到解决NoSuchFieldError的方法是更新lombok至1.18.30版本。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

TIP:这里,特别提醒大家,在接手项目的时候,一定要检查是否本地的JDK版本和服务器的JDK版本一致。

其实提醒大家之后,大家肯定就有了答案,没错,这就是JDK版本问题导致的。

虽然甲骨文对JDK8已经不在进行更新了,但是,其实大家也都知道,各个公司使用最多的就是JDK8了,很少有公司会跟随JDK版本进行对应的项目更新。

而这个问题,就是由于JDK8版本的代码在JDK11版本的环境运行,就出现了本地运行没有问题,但是服务器端却一直有问题,报错导致无法启动成功。

希望大家引以为戒。

当然,在本地更换成JDK11的版本后,编译的时候你肯定也会出现一个问题:NoSuchFieldError: Class com.sun.tools.javac.tree.JCTree$JCImport does not have member field

其实这个问题,是JDK11对lombok的版本兼容问题,将lombok的版本修改为1.18.30版本即可。

### Java 中 `BootstrapMethodError` 和 `IllegalAccessError` 错误分析 #### 关于 `BootstrapMethodError` `BootstrapMethodError` 是一种在运行时发生的错误,通常发生在使用了新的字节码指令(如 invokedynamic),而 JVM 或类库未能正确解析这些新特性的情况。此错误可能由多种因素引起: - **JVM 版本不兼容**:如果应用程序使用了较新的 Java 字节码功能(例如 Lambda 表达式或方法句柄),但在较低版本的 JVM 上执行,则可能会遇到此类异常[^2]。 对于该问题的一个常见场景是在 Spark 应用程序中提交作业时报错——由于 Maven 构建工具配置不当导致项目依赖项中的 Scala 版本与集群环境所使用的 Scala 版本存在差异。这会使得某些特定操作无法正常工作,进而触发 `BootstrapMethodError` 异常。解决办法是调整 POM 文件内的依赖声明来匹配目标平台上的 Scala 发行版,并重新构建应用包后再部署至生产环境中。 ```xml <properties> <scala.version>2.12.10</scala.version> </properties> <dependencies> <!-- Ensure all scala dependencies match the specified version --> ... </dependencies> ``` #### 针对 `IllegalAccessError` 另一方面,`IllegalAccessError` 属于链接阶段产生的严重错误之一,表明尝试访问某个非法成员(字段、构造器或方法)。这类情况往往源于模块化系统的引入以及反射机制的应用不当所致;亦或是不同框架间相互作用引发冲突的结果。具体来说,在 Spring Boot 项目里启动过程中抛出 `java.lang.IllegalAccessError: javax/el/Util` 的情形下,可能是 Hibernate Validator 组件与其内部 EL 实现之间的协作出现了障碍。鉴于此,可以通过显式排除过高版本的验证器组件并替换为更稳定的替代品来进行修复[^4]。 ```xml <!-- Exclude problematic hibernate-validator from spring-boot-starter-web --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> <exclusions> <exclusion> <groupId>org.hibernate.validator</groupId> <artifactId>hibernate-validator</artifactId> </exclusion> </exclusions> </dependency> <!-- Optionally add a compatible validator dependency --> <dependency> <groupId>javax.validation</groupId> <artifactId>validation-api</artifactId> <version>${validation.api.version}</version> </dependency> ``` 上述措施有助于缓解因第三方库之间潜在的二进制接口变化所带来的影响,从而保障整个 Web 应用能够顺利初始化完成。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值