JJWT 依赖混淆

Jas*_*son 5 java jwt jjwt

我继承了一个在 POM.xml 中有这个的 java 项目:

<properties>
    <jjwt.version>0.11.1</jjwt.version>
</properties>

// from https://github.com/jwtk/jjwt#maven
<dependency>
    <groupId>io.jsonwebtoken</groupId>
    <artifactId>jjwt-api</artifactId>
    <version>${jjwt.version}</version>
</dependency>
<dependency>
    <groupId>io.jsonwebtoken</groupId>
    <artifactId>jjwt-impl</artifactId>
    <version>${jjwt.version}</version>
    <scope>runtime</scope>
</dependency>
<dependency>
    <groupId>io.jsonwebtoken</groupId>
    <artifactId>jjwt-jackson</artifactId> <!-- or jjwt-gson if Gson is preferred -->
    <version>${jjwt.version}</version>
    <scope>runtime</scope>
</dependency>

// what is this "jjwt" dep, and why might it be using a different version?
<dependency>
    <groupId>io.jsonwebtoken</groupId>
    <artifactId>jjwt</artifactId>
    <version>0.9.1</version> 
</dependency>
Run Code Online (Sandbox Code Playgroud)

这个“jjwt”dep 是什么,为什么它可能使用不同的版本?

我在https://github.com/jwtk/jjwt 上没有看到任何提及

但它在这里:https : //mvnrepository.com/artifact/io.jsonwebtoken

Ale*_*rov 7

在 JJWT 0.10.0 版本之前,API 和实现都打包为一个工件,io.jsonwebtoken:jjwt.

从 0.10.0 版本开始,API 和实现分为两个不同的工件。

摘自JJWT 发行说明,版本 0.10.0

JJWT 的新模块化设计利用了编译依赖项和运行时依赖项之间的区别,以确保您只依赖可以在应用程序中安全使用的公共 API。所有内部/私有实现类都已移至新的 jjwt-impl 运行时依赖项。

如果您过去依赖任何内部实现类,则有两种选择:

  • 重构您的代码以使用 jjwt-api .jar 中的公共 API 类和接口。您可能在内部实现中使用的任何功能都应该通过该 .jar 中更新的更清晰的接口和帮助程序类提供。

  • 指定新的 jjwt-impl .jar 不是作为运行时依赖,而是作为编译依赖。这将使您升级到 JJWT 0.10.0 完全向后兼容,但您需要自担风险。JJWT 将在 jjwt-impl .jar 中做出无语义版本兼容性保证。然而,在所有其他 JJWT 依赖项中将非常小心地遵守语义版本控制。


我的猜测是您的项目团队没有完成从 JJWT <= 0.9 到 JJWT >= 0.10 的升级。