- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想在 1.16.3 中编写 Minecraft 模组。我已经在 1.12.2 中制作了一个 mod,但我没有这个问题。我只是下载 1.16.3 forge Mdk 并为 Eclipse 构建它(在 cmd 中使用“gradlew eclipse”)但是当我尝试运行 mod 时(使用“runClient.launch”)。它给出了一个错误:
java.lang.NoClassDefFoundError: jdk/nashorn/api/scripting/NashornScriptEngineFactory.
我尝试修改主文件和包以支持不必要的代码,但是当我开始时。它给了我同样的错误。
我的主文件:
package fr.luzog78.newmod;
import net.minecraft.block.Blocks;
import net.minecraftforge.common.MinecraftForge;
import net.minecraftforge.fml.common.Mod;
import net.minecraftforge.fml.event.lifecycle.FMLClientSetupEvent;
import net.minecraftforge.fml.event.lifecycle.FMLCommonSetupEvent;
import net.minecraftforge.fml.javafmlmod.FMLJavaModLoadingContext;
import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;
@Mod("newmod")
public class NewMod {
private static final Logger LOGGER = LogManager.getLogger();
public NewMod() {
FMLJavaModLoadingContext.get().getModEventBus().addListener(this::setup);
FMLJavaModLoadingContext.get().getModEventBus().addListener(this::doClientStuff);
MinecraftForge.EVENT_BUS.register(this);
}
private void setup(final FMLCommonSetupEvent event) {
LOGGER.info("HELLO FROM PREINIT");
LOGGER.info("DIRT BLOCK >> {}", Blocks.DIRT.getRegistryName());
}
private void doClientStuff(final FMLClientSetupEvent event) {
}
// @SubscribeEvent
// public void onServerStarting(FMLServerStartingEvent event) {
// // do something when the server starts
// LOGGER.info("HELLO from server starting");
// }
//
// // You can use EventBusSubscriber to automatically subscribe events on the contained class (this is subscribing to the MOD
// // Event bus for receiving Registry Events)
// @Mod.EventBusSubscriber(bus=Mod.EventBusSubscriber.Bus.MOD)
// public static class RegistryEvents {
// @SubscribeEvent
// public static void onBlocksRegistry(final RegistryEvent.Register<Block> blockRegistryEvent) {
// // register a new block here
// LOGGER.info("HELLO from Register Block");
// }
// }
}
还有堆栈跟踪:
Exception in thread "main" [13:16:47] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]: java.lang.NoClassDefFoundError: jdk/nashorn/api/scripting/NashornScriptEngineFactory
[13:16:47] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]: at net.minecraftforge.coremod.CoreModEngine.loadCoreMod(CoreModEngine.java:48)
[13:16:47] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]: at net.minecraftforge.coremod.CoreModProvider.addCoreMod(CoreModProvider.java:12)
[13:16:47] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]: at java.base/java.util.stream.ForEachOps$ForEachOp$OfRef.accept(ForEachOps.java:183)
[13:16:47] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]: at java.base/java.util.ArrayList$ArrayListSpliterator.forEachRemaining(ArrayList.java:1625)
[13:16:47] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]: at java.base/java.util.stream.ReferencePipeline$Head.forEach(ReferencePipeline.java:658)
[13:16:47] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]: at java.base/java.util.stream.ReferencePipeline$7$1.accept(ReferencePipeline.java:274)
[13:16:47] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]: at java.base/java.util.stream.ReferencePipeline$3$1.accept(ReferencePipeline.java:195)
[13:16:47] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]: at java.base/java.util.stream.ReferencePipeline$3$1.accept(ReferencePipeline.java:195)
[13:16:47] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]: at java.base/java.util.ArrayList$ArrayListSpliterator.forEachRemaining(ArrayList.java:1625)
[13:16:47] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]: at java.base/java.util.stream.AbstractPipeline.copyInto(AbstractPipeline.java:484)
[13:16:47] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]: at java.base/java.util.stream.AbstractPipeline.wrapAndCopyInto(AbstractPipeline.java:474)
[13:16:47] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]: at java.base/java.util.stream.ForEachOps$ForEachOp.evaluateSequential(ForEachOps.java:150)
[13:16:47] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]: at java.base/java.util.stream.ForEachOps$ForEachOp$OfRef.evaluateSequential(ForEachOps.java:173)
[13:16:47] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]: at java.base/java.util.stream.AbstractPipeline.evaluate(AbstractPipeline.java:234)
[13:16:47] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]: at java.base/java.util.stream.ReferencePipeline.forEach(ReferencePipeline.java:497)
[13:16:47] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]: at net.minecraftforge.fml.loading.LoadingModList.addCoreMods(LoadingModList.java:85)
[13:16:47] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]: at net.minecraftforge.fml.loading.moddiscovery.ModDiscoverer.discoverMods(ModDiscoverer.java:129)
[13:16:47] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]: at net.minecraftforge.fml.loading.FMLLoader.beginModScan(FMLLoader.java:213)
[13:16:47] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]: at net.minecraftforge.fml.loading.FMLServiceProvider.runScan(FMLServiceProvider.java:107)
[13:16:47] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]: at cpw.mods.modlauncher.TransformationServiceDecorator.runScan(TransformationServiceDecorator.java:114)
[13:16:47] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]: at cpw.mods.modlauncher.TransformationServicesHandler.lambda$runScanningTransformationServices$8(TransformationServicesHandler.java:115)
[13:16:47] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]: at java.base/java.util.stream.ReferencePipeline$7$1.accept(ReferencePipeline.java:271)
[13:16:47] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]: at java.base/java.util.HashMap$ValueSpliterator.forEachRemaining(HashMap.java:1766)
[13:16:47] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]: at java.base/java.util.stream.AbstractPipeline.copyInto(AbstractPipeline.java:484)
[13:16:47] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]: at java.base/java.util.stream.AbstractPipeline.wrapAndCopyInto(AbstractPipeline.java:474)
[13:16:47] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]: at java.base/java.util.stream.ReduceOps$ReduceOp.evaluateSequential(ReduceOps.java:913)
[13:16:47] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]: at java.base/java.util.stream.AbstractPipeline.evaluate(AbstractPipeline.java:234)
[13:16:47] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]: at java.base/java.util.stream.ReferencePipeline.collect(ReferencePipeline.java:578)
[13:16:47] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]: at cpw.mods.modlauncher.TransformationServicesHandler.runScanningTransformationServices(TransformationServicesHandler.java:116)
[13:16:47] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]: at cpw.mods.modlauncher.TransformationServicesHandler.initializeTransformationServices(TransformationServicesHandler.java:63)
[13:16:47] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]: at cpw.mods.modlauncher.Launcher.run(Launcher.java:76)
[13:16:47] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]: at cpw.mods.modlauncher.Launcher.main(Launcher.java:66)
[13:16:47] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]: at net.minecraftforge.userdev.LaunchTesting.main(LaunchTesting.java:105)
[13:16:47] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1057]: Caused by: java.lang.ClassNotFoundException: jdk.nashorn.api.scripting.NashornScriptEngineFactory
[13:16:47] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1057]: at java.base/jdk.internal.loader.BuiltinClassLoader.loadClass(BuiltinClassLoader.java:606)
[13:16:47] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1057]: at java.base/jdk.internal.loader.ClassLoaders$AppClassLoader.loadClass(ClassLoaders.java:168)
[13:16:47] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1057]: at java.base/java.lang.ClassLoader.loadClass(ClassLoader.java:522)
[13:16:47] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1057]: ... 33 more
最佳答案
您使用的 Minecraft 代码似乎取决于 Nashorn 脚本引擎。纳肖恩是 removed from the JDK在 Java 15 中,您似乎正在运行它。
降级到 JDK 14 或更早版本。
关于java.lang.NoClassDefFoundError : jdk/nashorn/api/scripting/NashornScriptEngineFactory,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/64834307/
我正在尝试使用 graal + nashorn 互操作来编写与 Java 交互的 nodejs。我从 node --jvm --jvm.Xss2m --jvm.Dtruffle.js.NashornJ
我正在尝试向我们的系统添加一个脚本功能,不受信任的用户可以在其中编写简单的脚本并让它们在服务器端执行。我正在尝试使用 Nashorn 作为脚本引擎。 不幸的是,他们为 Nashorn 添加了一些非标准
我正在尝试迁移/更新我的项目以使用 Rhino 中的 Nashorn。我有一些用 Java 实现的全局实用函数,并将其添加到目标脚本引擎的全局范围中,典型的示例是 log(message)。 在Rhi
我使用 eclipse luna 作为 IDE。我在网络应用程序中工作。当我用 javascript 编写代码时,有时我会忘记输入分号,但如果我的 javascript 在浏览器中运行,一切仍然正常。
我想检索 JS 中生成的对象,将它们存储在 Java 中,然后调用它们的方法。这适用于 Java 7,现在使用 Java 8 我得到一个异常: Exception in thread "main" j
我正在将 Eclipse RCP 迁移到使用 JDK 8,并且大量使用 JS ScriptEngine。现在引入了 Nashorn,我必须添加以下行才能使 importClass 和 importPa
我试图通过 Nashorn 解析这个 Javascript: function someFunction() { return b + 1 }; 并导航到所有语句。这包括函数内部的语句。 下面的代码只
Nashorn java 脚本引擎具有内置分析器,可以像这样调用: jjs -pcs profiled_script.js。 此探查器会生成一个名为 NashornProfile.txt 的文件。以下
我在我的项目中使用 nashorn。我想从 json 中获取属性,但属性可能没有值(value)。 在 javascript 中,如果属性为 null,则使用可选链接并设置一个值;但在 nashorn
如果下面的代码可以在多线程应用程序中运行,你能帮帮我吗? 这是我的 Java 脚本,将由 Nashorn 评估 var Thread = Java.type("java.lang.Thread");
我在 nashron 和浏览器中使用独立的 js 脚本。为什么在 nashron 我得到 javax.script.ScriptException: TypeError: Cannot read pr
下面我分享了我的代码,我在其中尝试使用线程安全的 Nashorn 作为脚本引擎来评估简单的数学公式。公式类似于“a*b/2”,其中 a 和 b 将从 map 对象中获取。 public class E
如何将代码添加到 javascript 类的构造函数中。Java代码非常简单: public class MyObject extends SomeAbstractObject { public
当我尝试加载 Rhino 的 Nashorn 兼容性文件 (load("nashorn:mozilla_compat.js")) 时,出现以下错误: java.lang.RuntimeExceptio
我正在尝试使用Nashorn来解析网页的JS内容。我使用以下代码来初始化 Nashorn 并加载页面: ScriptEngineManager manager = new ScriptEngineMa
有没有一种方法可以缓存在 Nashorn 中评估的脚本以避免两次评估相同的脚本? 例如,我有一些 js 库可以做一些事情。我想评估 Library 一次,然后在我想要的每个文件上重复使用它。 publ
我正在使用 nashorn 进行一些体验。 为此,我在 java 中编写了这个简单的代码,我想在其中使用我定义的自定义对象。 ScriptEngine engine = new
假设有这样的文件 (function () { function change() { print('test'); } function test() {
我知道您可以在 Nashorn 中使用 Java 数组,并且有很多示例说明如何执行此操作。对我来说,标准方法的问题是它使 javascript 代码明确知道它的运行时环境。目前我有一个使用 Rhino
我使用 Rhino 作为图形内部的脚本组件。项目中大约有200个独立运行的小脚本。启动应用程序时,脚本应立即全速运行。 Rhino 的性能足够,但由于 Oracle 建议迁移到 Nashorn,我面临
我是一名优秀的程序员,十分优秀!