微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

如何解决“org.slf4j.impl.StaticLoggerBinder”错误以运行我的 Javalin Web 应用程序?

如何解决如何解决“org.slf4j.impl.StaticLoggerBinder”错误以运行我的 Javalin Web 应用程序?

我正在使用 IntelliJ IDE,我在其中创建了一个 Maven 项目来构建网站。我正在尝试使用 Javalin,因为它是一个轻量级的框架。根据 Javalin 的文档,我的 pom.xml 文件是:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>org.example</groupId>
    <artifactId>Web-App</artifactId>
    <version>1.0-SNAPSHOT</version>
    <dependencies>
        <dependency>
            <groupId>io.javalin</groupId>
            <artifactId>javalin</artifactId>
            <version>3.13.6</version>
        </dependency>
    </dependencies>

    <properties>
        <maven.compiler.source>15</maven.compiler.source>
        <maven.compiler.target>15</maven.compiler.target>
    </properties>

</project>

在 src/main/java 下,我创建了一个 HelloWorld.java 来运行我的 web 应用程序。代码是:

import io.javalin.Javalin;

public class HelloWorld {
    public static void main(String[] args) {
        Javalin app = Javalin.create().start(7000);
        app.get("/",ctx -> ctx.result("Hello World"));
    }
}

当我运行时,出现如下错误

SLF4J: Failed to load class "org.slf4j.impl.StaticLoggerBinder".
SLF4J: Defaulting to no-operation (nop) logger implementation
SLF4J: See http://www.slf4j.org/codes.html#StaticLoggerBinder for further details.
Exception in thread "main" java.lang.NoClassDefFoundError: kotlin/NowhenBranchMatchedException
    at io.javalin.core.JavalinConfig$Inner.<init>(JavalinConfig.java:73)
    at io.javalin.core.JavalinConfig.<init>(JavalinConfig.java:63)
    at io.javalin.Javalin.<init>(Javalin.java:52)
    at io.javalin.Javalin.create(Javalin.java:88)
    at io.javalin.Javalin.create(Javalin.java:76)
    at HelloWorld.main(HelloWorld.java:5)
Caused by: java.lang.classNotFoundException: kotlin.NowhenBranchMatchedException
    at java.base/jdk.internal.loader.BuiltinClassLoader.loadClass(BuiltinClassLoader.java:606)
    at java.base/jdk.internal.loader.ClassLoaders$AppClassLoader.loadClass(ClassLoaders.java:168)
    at java.base/java.lang.classLoader.loadClass(ClassLoader.java:522)
    ... 6 more

在这种情况下。这背后可能是我的错误是什么?

提前致谢。

解决方法

您缺少日志记录实现。我建议你使用这个“javalin-bundle”依赖:

<dependency>
    <groupId>io.javalin</groupId>
    <artifactId>javalin-bundle</artifactId>
    <version>3.13.6</version>
</dependency>

它包含一些额外的库,包括日志库,如果您只使用 <artifactId>javalin</artifactId>,则缺少这些库。

(您还获得了 Jackson,Javalin 在幕后使用它来处理 JSON 资源 - 例如 ctx.json(obj)。)

您不必使用捆绑包 - 您可以提供自己的 logging implementation

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。