感谢 Stéphane - 您问题末尾的编辑帮助我“解决”了同样的问题。对于其他也遇到此问题的人-这是一个扩展的答案。这就是你需要在你的 pom 中“修复”一些东西(直到 Eclipse 正确修复这些东西):
<!-- See https://stackoverflow.com/q/45870753 -->
<dependency>
<groupId>org.eclipse.persistence</groupId>
<artifactId>eclipselink</artifactId>
<version>2.7.0</version>
<exclusions>
<exclusion>
<groupId>org.eclipse.persistence</groupId>
<artifactId>javax.persistence</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.eclipse.persistence</groupId>
<artifactId>javax.persistence</artifactId>
<version>2.1.1</version>
</dependency>
这会引入eclipselink,但会排除它尝试引入的javax.persistence 依赖项,并将其替换为不存在签名问题的早期版本的javax.persistence。
除此之外:javax.persistence 版本 2.2.0 在原始问题中显示的 pom 片段中被显式拉入,尽管它已经是 eclipselink 的传递依赖项。
说明
总结 - eclipselink 工件依赖于 javax.persistence 并且两者都包含包 javax.persistence 中的类。但是,javax.persistence jar 已签名,而 eclipselink 未签名。因此,当从 eclipselink jar 中的包 javax.persistence 加载类时,Java 运行时会抱怨它缺少签名与已经从 javax.persistence jar 中的同一包中加载的类不匹配。
详细信息 - 如果我在 java.util.concurrent.ConcurrentHashMap.putIfAbsent(K, V) 中放置一个断点,条件为 "javax.persistence".equals(arg0),那么我看到 javax.persistence 映射到以下 CodeSource 值:
(file:/Users/georgehawkins/.m2/repository/org/eclipse/persistence/javax.persistence/2.2.0/javax.persistence-2.2.0.jar [
[
Version: V3
Subject: CN="Eclipse Foundation, Inc.", OU=IT, O="Eclipse Foundation, Inc.", L=Ottawa, ST=Ontario, C=CA
Signature Algorithm: SHA256withRSA, OID = 1.2.840.113549.1.1.11
...
即javax.persistence-2.2.0.jar 由 Eclipse 基金会签名,包含 javax.persistence 包中的类。当我的应用程序的某些部分(实际上是 Spring 逻辑中的某些内容)尝试加载 javax.persistence.EntityManagerFactory 时,这个 jar 被拉入。
如果我在throw new SecurityException 行的java.lang.ClassLoader.checkCerts(String, CodeSource) 中放置一个断点,那么当传入的CodeSource 是:
(file:/Users/georgehawkins/.m2/repository/org/eclipse/persistence/eclipselink/2.7.0/eclipselink-2.7.0.jar <no signer certificates>)
即eclipselink-2.7.0.jar 还包含 javax.persistence 包中的类,但它是未签名的,因此会发生冲突,导致抛出 SecurityException。当某些东西(也在 Spring 逻辑中)尝试加载 javax.persistence.PersistenceUtil 时,就会发生这种情况。
如果我查看mvn dependency:tree 的输出,我发现这种不匹配似乎归结为eclipselink 本身——它正在拉入org.eclipse.persistence:javax.persistence:jar:2.2.0 本身。 IE。它与其他依赖项没有冲突:
[INFO] | \- org.eclipse.persistence:eclipselink:jar:2.7.0:compile
[INFO] | +- org.eclipse.persistence:javax.persistence:jar:2.2.0:compile
[INFO] | +- org.eclipse.persistence:commonj.sdo:jar:2.1.1:compile
[INFO] | +- javax.validation:validation-api:jar:1.1.0.Final:compile
[INFO] | \- org.glassfish:javax.json:jar:1.0.4:compile
我现在在 bugs.eclipse.org 上记录了这个 - 请参阅错误 525457。