Loading [MathJax]/jax/output/CommonHTML/config.js
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >Jetty17 --add选项不起作用,java.lang.IllegalAccessError

Jetty17 --add选项不起作用,java.lang.IllegalAccessError
EN

Stack Overflow用户
提问于 2022-05-06 05:54:21
回答 1查看 1.6K关注 0票数 0

我在Jetty11.0.9中使用Java 17。我使用以下命令启动Jetty

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
java --add-opens=java.base/java.lang=ALL-UNNAMED -jar start.jar

然后我将面临例外情况。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
2022-05-06 16:40:45.314:WARN :oejw.WebAppContext:main: Failed startup of context o.e.j.w.WebAppContext@593aaf41{vte.cx (alpha),/vtecx,file:///usr/local/jetty-home-11.0.9/webapps/vtecx/,UNAVAILABLE}{/usr/local/jetty-home-11.0.9/webapps/vtecx}
java.lang.IllegalAccessError: class jdk.internal.reflect.ConstructorAccessorImpl loaded by javassist.Loader @46292372 cannot access jdk/internal/reflect superclass jdk.internal.reflect.MagicAccessorImpl
    at java.base/java.lang.ClassLoader.defineClass1(Native Method)
    at java.base/java.lang.ClassLoader.defineClass(ClassLoader.java:1012)
    at java.base/java.lang.ClassLoader.defineClass(ClassLoader.java:874)
    at javassist.Loader.findClass(Loader.java:419)
    at javassist.Loader.loadClass(Loader.java:350)
    at java.base/java.lang.ClassLoader.loadClass(ClassLoader.java:520)
    at java.base/java.lang.ClassLoader.defineClass1(Native Method)
    at java.base/java.lang.System$2.defineClass(System.java:2303)
    at java.base/jdk.internal.reflect.ClassDefiner.defineClass(ClassDefiner.java:66)
    at java.base/jdk.internal.reflect.MethodAccessorGenerator$1.run(MethodAccessorGenerator.java:401)
    at java.base/jdk.internal.reflect.MethodAccessorGenerator$1.run(MethodAccessorGenerator.java:395)
    at java.base/java.security.AccessController.doPrivileged(AccessController.java:318)
    at java.base/jdk.internal.reflect.MethodAccessorGenerator.generate(MethodAccessorGenerator.java:394)
    at java.base/jdk.internal.reflect.MethodAccessorGenerator.generateConstructor(MethodAccessorGenerator.java:92)
    at java.base/jdk.internal.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:65)
    at java.base/jdk.internal.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45)
    at java.base/java.lang.reflect.Constructor.newInstanceWithCaller(Constructor.java:499)
    at java.base/java.lang.reflect.ReflectAccess.newInstance(ReflectAccess.java:128)
    at java.base/jdk.internal.reflect.ReflectionFactory.newInstance(ReflectionFactory.java:347)
    at java.base/java.lang.Class.newInstance(Class.java:645)
    at org.msgpack.template.builder.ReflectionTemplateBuilder$ReflectionClassTemplate.read(ReflectionTemplateBuilder.java:132)
    at org.msgpack.template.AbstractTemplate.read(AbstractTemplate.java:31)
    at org.msgpack.template.ListTemplate.read(ListTemplate.java:66)
    at org.msgpack.template.ListTemplate.read(ListTemplate.java:27)
    at org.msgpack.template.builder.ReflectionTemplateBuilder$FieldTemplateImpl.read(ReflectionTemplateBuilder.java:70)
    at org.msgpack.template.builder.ReflectionTemplateBuilder$ReflectionClassTemplate.read(ReflectionTemplateBuilder.java:143)
    at org.msgpack.template.AbstractTemplate.read(AbstractTemplate.java:31)
    at org.msgpack.MessagePack.read(MessagePack.java:388)
    at org.msgpack.MessagePack.read(MessagePack.java:371)
    at jp.reflexworks.atom.mapper.FeedTemplateMapper.fromMessagePack(FeedTemplateMapper.java:1014)

我已经确认它在一个非servlet独立的环境中工作得很好。--add-opens参数在servlet环境中正确工作吗?或者可能是其他原因造成的,比如javassist?

单元测试确实成功。它在Jetty上也没有完全失败,它似乎被正确地处理到了中间点。看起来,在线程中运行多个运行时也会发生错误。

-列表-配置如下

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
$ java -jar start.jar --list-config

Enabled Modules:
----------------
  0) bytebufferpool            transitive provider of bytebufferpool for server
                               ini template available with --add-module=bytebufferpool
  1) resources                 transitive provider of resources for logging-jetty
  2) logging/slf4j             transitive provider of logging/slf4j for logging-jetty
                               dynamic dependency of logging-jetty
  3) logging-jetty             transitive provider of logging for threadpool
                               transitive provider of logging for server
  4) threadpool                transitive provider of threadpool for server
                               ini template available with --add-module=threadpool
  5) server                    ${jetty.base}/start.d/server.ini
  6) jndi                      transitive provider of jndi for plus
  7) security                  transitive provider of security for webapp
                               transitive provider of security for plus
  8) servlet                   transitive provider of servlet for webapp
  9) webapp                    transitive provider of webapp for plus
                               transitive provider of webapp for deploy
                               ini template available with --add-module=webapp
 10) plus                      transitive provider of plus for annotations
 11) annotations               transitive provider of annotations for websocket-jetty
 12) client                    transitive provider of client for websocket-jakarta
 13) deploy                    ${jetty.base}/start.d/deploy.ini
 14) http                      ${jetty.base}/start.d/http.ini
 15) ssl                       ${jetty.base}/start.d/ssl.ini
 16) https                     ${jetty.base}/start.d/https.ini
 17) rewrite                   ${jetty.base}/start.d/rewrite.ini
 18) websocket-jakarta         transitive provider of websocket-jakarta for websocket
 19) websocket-jetty           transitive provider of websocket-jetty for websocket
 20) websocket                 ${jetty.base}/start.d/websocket.ini

Java Environment:
-----------------
 java.home = /Library/Java/JavaVirtualMachines/jdk-17.0.3.jdk/Contents/Home
 java.vm.vendor = Oracle Corporation
 java.vm.version = 17.0.3+8-LTS-111
 java.vm.name = Java HotSpot(TM) 64-Bit Server VM
 java.vm.info = mixed mode, sharing
 java.runtime.name = Java(TM) SE Runtime Environment
 java.runtime.version = 17.0.3+8-LTS-111
 java.io.tmpdir = /var/folders/jd/sclp7v4j4fxgmx00hw47q1vm0000gn/T/
 user.dir = /usr/local/jetty-home-11.0.9
 user.language = ja
 user.country = JP

Jetty Environment:
------------------
 jetty.version = 11.0.9
 jetty.tag.version = jetty-11.0.9
 jetty.build = 243a48a658a183130a8c8de353178d154ca04f04
 jetty.home = /usr/local/jetty-home-11.0.9
 jetty.base = /usr/local/jetty-home-11.0.9

Config Search Order:
--------------------
 <command-line>
 ${jetty.base} -> /usr/local/jetty-home-11.0.9
 ${jetty.home} -> /usr/local/jetty-home-11.0.9

System Properties:
------------------
 (no system properties specified)

Properties:
-----------
 java.version = 17.0.3
 java.version.major = 17
 java.version.micro = 3
 java.version.minor = 0
 java.version.platform = 17
 jetty.base = /usr/local/jetty-home-11.0.9
 jetty.base.uri = file:///usr/local/jetty-home-11.0.9
 jetty.home = /usr/local/jetty-home-11.0.9
 jetty.home.uri = file:///usr/local/jetty-home-11.0.9
 jetty.sslContext.keyStorePassword = OBF:xxxxxxxxxx
 jetty.webapp.addServerClasses = org.eclipse.jetty.logging.,${jetty.home.uri}/lib/logging/,org.slf4j.
 runtime.feature.alpn = true
 slf4j.version = 2.0.0-alpha6

Jetty Server Classpath:
-----------------------
Version Information on 36 entries in the classpath.
Note: order presented here is how they would appear on the classpath.
      changes to the --module=name command line options will be reflected here.
 0:                    (dir) | ${jetty.base}/resources
 1:             2.0.0-alpha6 | ${jetty.base}/lib/logging/slf4j-api-2.0.0-alpha6.jar
 2:                   11.0.9 | ${jetty.base}/lib/logging/jetty-slf4j-impl-11.0.9.jar
 3:                    5.0.2 | ${jetty.base}/lib/jetty-jakarta-servlet-api-5.0.2.jar
 4:                   11.0.9 | ${jetty.base}/lib/jetty-http-11.0.9.jar
 5:                   11.0.9 | ${jetty.base}/lib/jetty-server-11.0.9.jar
 6:                   11.0.9 | ${jetty.base}/lib/jetty-xml-11.0.9.jar
 7:                   11.0.9 | ${jetty.base}/lib/jetty-util-11.0.9.jar
 8:                   11.0.9 | ${jetty.base}/lib/jetty-io-11.0.9.jar
 9:                   11.0.9 | ${jetty.base}/lib/jetty-jndi-11.0.9.jar
10:                   11.0.9 | ${jetty.base}/lib/jetty-security-11.0.9.jar
11:                   11.0.9 | ${jetty.base}/lib/jetty-servlet-11.0.9.jar
12:                   11.0.9 | ${jetty.base}/lib/jetty-webapp-11.0.9.jar
13:                   11.0.9 | ${jetty.base}/lib/jetty-plus-11.0.9.jar
14:                    2.0.0 | ${jetty.base}/lib/jakarta.transaction-api-2.0.0.jar
15:                   11.0.9 | ${jetty.base}/lib/jetty-annotations-11.0.9.jar
16:                      9.2 | ${jetty.base}/lib/annotations/asm-9.2.jar
17:                      9.2 | ${jetty.base}/lib/annotations/asm-analysis-9.2.jar
18:                      9.2 | ${jetty.base}/lib/annotations/asm-commons-9.2.jar
19:                      9.2 | ${jetty.base}/lib/annotations/asm-tree-9.2.jar
20:                    2.0.0 | ${jetty.base}/lib/annotations/jakarta.annotation-api-2.0.0.jar
21:                   11.0.9 | ${jetty.base}/lib/jetty-client-11.0.9.jar
22:                   11.0.9 | ${jetty.base}/lib/jetty-alpn-client-11.0.9.jar
23:                   11.0.9 | ${jetty.base}/lib/jetty-deploy-11.0.9.jar
24:                   11.0.9 | ${jetty.base}/lib/jetty-rewrite-11.0.9.jar
25:                   11.0.9 | ${jetty.base}/lib/websocket/websocket-core-common-11.0.9.jar
26:                   11.0.9 | ${jetty.base}/lib/websocket/websocket-core-client-11.0.9.jar
27:                   11.0.9 | ${jetty.base}/lib/websocket/websocket-core-server-11.0.9.jar
28:                   11.0.9 | ${jetty.base}/lib/websocket/websocket-servlet-11.0.9.jar
29:                    2.0.0 | ${jetty.base}/lib/websocket/jetty-jakarta-websocket-api-2.0.0.jar
30:                   11.0.9 | ${jetty.base}/lib/websocket/websocket-jakarta-client-11.0.9.jar
31:                   11.0.9 | ${jetty.base}/lib/websocket/websocket-jakarta-common-11.0.9.jar
32:                   11.0.9 | ${jetty.base}/lib/websocket/websocket-jakarta-server-11.0.9.jar
33:                   11.0.9 | ${jetty.base}/lib/websocket/websocket-jetty-api-11.0.9.jar
34:                   11.0.9 | ${jetty.base}/lib/websocket/websocket-jetty-common-11.0.9.jar
35:                   11.0.9 | ${jetty.base}/lib/websocket/websocket-jetty-server-11.0.9.jar

Jetty Active XMLs:
------------------
 ${jetty.base}/etc/jetty-bytebufferpool.xml
 ${jetty.base}/etc/jetty-threadpool.xml
 ${jetty.base}/etc/jetty.xml
 ${jetty.base}/etc/jetty-webapp.xml
 ${jetty.base}/etc/jetty-deploy.xml
 ${jetty.base}/etc/jetty-http.xml
 ${jetty.base}/etc/jetty-ssl.xml
 ${jetty.base}/etc/jetty-ssl-context.xml
 ${jetty.base}/etc/jetty-https.xml
 ${jetty.base}/etc/jetty-rewrite.xml
 ${jetty.base}/etc/rewrite-rules.xml
EN

回答 1

Stack Overflow用户

发布于 2022-05-09 04:36:58

在Java 11+上运行时,您的javassist版本与Servlet类加载器的要求不兼容。

您需要等待javAssist3.29发行版(它还不存在),它将javassist.Loader修复为忽略jdk.internal.*类。

请参阅:https://github.com/jboss-javassist/javassist/commit/b9a24bf129ef8b3295f99fdd43131301c1da8132

您需要使用上面提交的版本。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/72142649

复制
相关文章
为什么我总写 Bug ?
写代码的过程中,难免会出现各种各样的 Bug。但实际上,很多 Bug 产生的原因是类似的。于是我总结了一些自己学编程时写 Bug 的诱因,希望大家引以为戒,在以后写代码的时候能更多注意。
程序员鱼皮
2021/09/15
7000
高数 下总复习 完结
参数方程–>曲线积分 曲线积分 第二类曲线积分 (对面积的) 此时可以不用 上限大于下限 三 格林公式 及其应用 2 .积分与路径无关 如果不封闭 曲面积分 对于 dyd
CaesarChang张旭
2021/01/26
4090
高数 下总复习  完结
缺陷定位 | 测试发现了Bug,还要分析定位Bug?(一)
hello今天分享的内容,可能会有很多朋友持不同观点,或被很多同行朋友diss,不过没关系,即使被喷被diss,我依然会坚持我的观点,把最真实的干货分享给大家,希望得到支持。
王大力测试进阶之路
2022/03/14
6350
PyTorch(总)---PyTorch遇到令人迷人的BUG与记录
BUG1 在使用NLLLoss()激活函数时,NLLLoss用来做n类分类的,一般最后一层网络为LogSoftmax,如果其他的则需要使用CrossEntropyLoss。其使用格式为:loss(m(
zenRRan
2018/04/10
2.8K0
PyTorch(总)---PyTorch遇到令人迷人的BUG与记录
一个BUG的发现、定位和解决
前言 在iOS 11发布之后,出现了一系列适配相关的问题,UIScrollView在pagingEnabled=YES时滑动手势不灵敏,UITableView的滑动删除功能变动,UIImagePickerViewController的取消按钮点击区域变小等,本文介绍其中一个UIAlertView问题,分享其发现、定位和解决。 正文 1、问题产生 问题的最初,是iOS 11正式版发布后不久,测试的同学提了一个iOS 11相关的BUG,表现是:在直播间内发送聊天信息,如果被禁言,会弹出“被禁言”提示,键盘收回去
落影
2018/04/27
1.5K0
一个BUG的发现、定位和解决
发现了一个vscode的bug
被一个BUG折磨了3个小时。我知道引起这个BUG的原因,是因为项目中某些配置文件中配置的程序包引用路径出错了,要解决这个问题很简单,只需要将这些配置文件中错误的程序包引用路径找出来并修改之就可以了。
用户1608022
2018/08/01
5870
BUG赏金 | 当我发现iFrame注入时的利用
iFrame注入是一种非常常见的跨站脚本攻击。它包括已插入到网页或文章内容的一个或多个iframe代码,或一般下载一个可执行程序或进行其他动作使网站访客的电脑妥协。在最好的情况下,谷歌可能会标注该网站“恶意”。最糟糕的情况是,站点所有者和访问者最终使用了受恶意软件感染的计算机。
Timeline Sec
2019/12/26
1.3K0
根据原理撸一个带bug的PromiKit
之前我们说了PromiseKit今天就带领大家来分析一下这个PromiseKit,之后我们再根据PromiseKit的思想剥茧抽丝的简易的撸一个微型的PromiseKit。
大话swift
2019/07/03
6620
根据原理撸一个带bug的PromiKit
只要发现bug,就必须要提吗
大家好,我是乐天派阿常,一位有着8年管理经验的软件测试人,今天我和大家分享职场思考,发现bug是否要记录。
程序媛淼淼
2022/09/01
2830
解Bug之路-Druid的Bug 原
笔者很热衷于解决Bug,同时比较擅长(网络/协议)部分,所以经常被唤去解决一些网络IO方面的Bug。现在就挑一个案例出来,写出分析思路,以飨读者,希望读者在以后的工作中能够少踩点坑。
无毁的湖光-Al
2018/08/14
1.1K0
解Bug之路-Druid的Bug                                                                       原
探索TiDB Lightning的源码来解决发现的bug
上一篇《记一次简单的Oracle离线数据迁移至TiDB过程》说到在使用Lightning导入csv文件到TiDB的时候发现了一个bug,是这样一个过程。
HOHO
2022/05/09
4140
探索TiDB Lightning的源码来解决发现的bug
万万没想到,这都能发现 Bug?!
大家好,我是鱼皮,昨天工作中遇到一个挺好玩儿的小 Bug,和大家分享下,小白可懂~
程序员鱼皮
2021/12/15
4040
谷歌源生bug发现与解决记录
1、进入拨号界面,输入 *#*#4636#*#* ,然后会进入手机测试界面。 2、点击第三栏 Wi-Fi information 。 3、进入Wi-Fi information 界面后,点击第一栏 Wi-Fi API 。 4、进入Wi-Fi API 界面后,点击 enableNetwork 。这时会弹出一个输入栏,如果你输入为空或者输入为非数字,如何点击 OK ,连续操作俩次,就会显示 Settings keeps stopping。
用户7557625
2020/07/15
5300
【改BUG】项目遇到的奇葩bug
今天,我的下级代理联系我说,我们的平台,应用服务批量导入后,用户密码含有“0”的都不显示,例如密码是“07121239”但是平台只显示“7121239”,今天做了下排查,本文仅记录一下今天排查的经历
德宏大魔王
2023/08/08
1970
【改BUG】项目遇到的奇葩bug
JDK 的这3个bug,你发现了吗?
如果两个变量中间隔了比较长的其它代码,很可能会导致开发人员将两者混淆,导致逻辑认知错误,从而写出或改出有问题的代码。
用户5224393
2019/06/18
5430
你能发现这段 Python 代码中的 bug 吗?
原文链接:https://dwrodri.gitlab.io/can-you-spot-the-bug-in-this-python-code/
腾讯云 CODING
2023/08/18
1370
你能发现这段 Python 代码中的 bug 吗?
为什么程序员发现不了自己的BUG?
最近在朋友圈流行了这样的一个小学数学题,当然结果是“出乎意料”。看似简单的结果,儿童一般能够做对,而大人却几乎很少有人做对,分析下来,原因无非是惯性思维下的粗心导致的完全错误。今天我们就一起来分析下思考过程。
编程范 源代码公司
2018/08/03
3570
为什么程序员发现不了自己的BUG?
伪随机数算法_伪随机数预测工具
转载内容,有更改,感谢原作者(http://www.cnblogs.com/softidea/p/5824240.html#3697214)
全栈程序员站长
2022/09/16
1K0
AI找Bug,一键快速预测
在程序开发中,程序员每天都要和 Bug 打交道,对新手程序员而言,debug 是一件非常让人头疼的事情。好不容易写完一段代码,一运行,全是红色,找了好几圈,被几个符号累瞎了眼。
AI科技大本营
2019/05/06
8880
AI找Bug,一键快速预测
点击加载更多

相似问题

SQL -计算每天打开的总bug数

54

rangeOfUnit每月返回“”数周(iOS7 bug)

13

C# RichTextBox发现() Bug?

13

在XPages中发现的Bug

21

FindBugs没有显示发现的bug

35
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文