java报错-->java.lang.IllegalAccessError

1、前言

  在gradle中运行main方法突然出现如下错误

Exception in thread "main" java.lang.IllegalAccessError: class XXX.util.ImageBorderUtils (in unnamed module @0x4bd4bcd4) cannot access class sun.font.FontDesignMetrics (in module java.desktop) because module java.desktop does not export sun.font to unnamed module @0x4bd4bcd4
	at XXX.util.ImageBorderUtils.main(ImageBorderUtils.java:51)

看报错是资源访问不了,因为用了jdk9之后的jdk版本,会有访问问题,但是我写main方法又不是模块,知道要加jvm参数,但我用的gradle,就很迷茫,怎么设置参数。

2、环境

JDK:17
依赖管理工具:gradle
IDE:IDEA 2023.1.1

3、解决过程

在main方法上,点击Modify Run Configuration
在这里插入图片描述
点击Modify options
在这里插入图片描述
勾选Add VM options
在这里插入图片描述
增加参数:–add-exports java.desktop/sun.font=ALL-UNNAMED
在这里插入图片描述
将导包有问题的包,暴露为全部未命名模块的可访问(这里是翻译参数意思)。
最后点确定,应用配置,回去点运行即可,正常运行。

4、设置界面的模块表达

  这里主要解释一下idea表达当前是模块的一些说明。
他有一个no module的选项,虽然有,但是选择,下面的实现类变红,所以这个必选的。必须选一个模块module
在这里插入图片描述
前一个jdk版本,则默认选中模块声明的jdk
在这里插入图片描述
这种情况可能是我项目问题,我项目是个多模块的项目。

参考博客:
jdk11中获取Font类字体宽度
idea jdk8编译报错 Error:java: 无效的标记: --add-exports

### 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、付费专栏及课程。

余额充值