sun.security.ssl.SSLSessionImpl 找不到

问题描述 投票:0回答:7

当我尝试使用

okhttp
javax.ws.rs.client.Client
时出现以下错误

java.lang.NoSuchMethodError: sun.security.ssl.SSLSessionImpl.(Lsun/security/ssl/ProtocolVersion;Lsun/security/ssl/CipherSuite;Ljava/util/Collection;Lsun/security/ssl/SessionId;Ljava/lang/String;I)V

在sun.security.ssl包中查找,没有SSLSessionImpl类

我使用的是 Mac OS 10.13.3 (17D102)

java -version
java version "1.8.0_162"
Java(TM) SE Runtime Environment (build 1.8.0_162-b12)
Java HotSpot(TM) 64-Bit Server VM (build 25.162-b12, mixed mode)

在 Glassfish 5.0 上运行我的战争

build.gradle

buildscript {
    ext.kotlin_version = '1.2.30'

    repositories {
        mavenCentral()
    }
    dependencies {
        classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version"
        classpath "org.jetbrains.kotlin:kotlin-noarg:$kotlin_version"
        classpath "org.jetbrains.kotlin:kotlin-allopen:$kotlin_version"
    }
}

group 'invoice-administration-api'
version '1.0-SNAPSHOT'

apply plugin: 'idea'
apply plugin: 'war'
apply plugin: 'kotlin'
apply plugin: 'kotlin-jpa'
apply plugin: 'kotlin-allopen'

repositories {
    mavenCentral()
}

dependencies {
    compile "org.jetbrains.kotlin:kotlin-stdlib-jdk8:$kotlin_version"
    compileOnly group: 'javax', name: 'javaee-api', version: '8.0'
    compile group: 'org.hibernate', name: 'hibernate-core', version: '5.2.13.Final'
    compile group: 'org.glassfish.jersey.media', name: 'jersey-media-json-jackson', version: '2.26'
}

allOpen {
    annotation('javax.ejb.Stateless')
}

compileKotlin {
    kotlinOptions.jvmTarget = "1.8"
}
compileTestKotlin {
    kotlinOptions.jvmTarget = "1.8"
}
java ssl kotlin glassfish
7个回答
16
投票

问题的出现是因为Glassfish将原生的

sun.*
类嵌入到
[glassfish5_home]/glassfish/modules/endorsed/grizzly-npn-bootstrap.jar
中,因此它与包含在
[JDK_HOME]/jre/lib/jsse.jar

中的其他类发生冲突

所以编辑

grizzly-npn-bootstrap.jar
(之前复制一份)文件并删除sun文件夹。


7
投票

编辑:因为这是“正确答案”,Java 1.8.0-151 可能会缺少安全补丁。我不建议降级到这么旧的 Java 版本。

请查看 Payara 项目或 Glassfish 的新版本。

--

尝试将Java版本降级到Java 1.8.0-151。它应该工作。

带有 Java 8 161 的 glassfish 5 中存在一个问题,创建了一个issue,但我昨天(3 月 19 日)检查过关于这个问题的夜间构建没有变化。


5
投票

上述错误可能导致在您的浏览器中显示:

The connection was reset The connection to the server was reset while the page was loading.
The site could be temporarily unavailable or too busy. Try again in a few moments.
If you are unable to load any pages, check your computer’s network connection.
If your computer or network is protected by a firewall or proxy, make sure that Firefox is permitted to access the Web.**

解决方案:

下载:http://central.maven.org/maven2/org/glassfish/grizzly/grizzly-npn-bootstrap/1.8.1/grizzly-npn-bootstrap-1.8.1.jar 并替换你的 galssfish/payara grizzly-npn-bootstrap.jar.

mv grizzly-npn-bootstrap-1.8.1.jar glassfish5/glassfish/modules/endorsed/grizzly-npn-bootstrap.jar

2
投票

java 1.8.0_161 中安全密码的变化破坏了 Glassfish 5,0 底层 Grizzly 服务器中的 SSL 功能。最后一个工作的 java 版本是 1.8.0_152 截至撰写本文时,我可以确认,java 1.8.0_202 可与 Glassfish 5.1(现在由 Eclipse.org 维护并可从 Eclipse.org 下载)一起使用,其中包含的 grizzly-npn-bootstrap 版本为 1.9.0。无需删除或更改任何内容。


2
投票

我刚刚遇到这个令人沮丧的问题,我确实想稍微扩展 Antoine 上面的答案 https://stackoverflow.com/a/52479362/4722577 这对我有用。

请注意,我有 Glassfish 5.0 和 Java

openjdk version "1.8.0_232"
OpenJDK Runtime Environment (build 1.8.0_232-8u232-b09-0ubuntu1~18.04.1-b09)
OpenJDK 64-Bit Server VM (build 25.232-b09, mixed mode)

  1. 正如安托万所说,我将

    grizzly-npn-bootstrap.jar
    复制到另一个位置作为备份。

  2. 我做了

    jar -xvf grizzly-npn-bootstrap.jar
    以查看 jar 中的确切类和文件夹位置。这给了我以下输出:

cduran@cduran-VirtualBox:~/Documents$ jar -xvf grizzly-npn-bootstrap.jar 
 inflated: META-INF/MANIFEST.MF
  created: META-INF/
  created: META-INF/maven/
  created: META-INF/maven/org.glassfish.grizzly/
  created: META-INF/maven/org.glassfish.grizzly/grizzly-npn-bootstrap/
 inflated: META-INF/maven/org.glassfish.grizzly/grizzly-npn-bootstrap/pom.properties
 inflated: META-INF/maven/org.glassfish.grizzly/grizzly-npn-bootstrap/pom.xml
  created: org/
  created: org/glassfish/
  created: org/glassfish/grizzly/
  created: org/glassfish/grizzly/npn/
 inflated: org/glassfish/grizzly/npn/AlpnClientNegotiator.class
 inflated: org/glassfish/grizzly/npn/AlpnServerNegotiator.class
 inflated: org/glassfish/grizzly/npn/ClientSideNegotiator.class
 inflated: org/glassfish/grizzly/npn/NegotiationSupport.class
 inflated: org/glassfish/grizzly/npn/ServerSideNegotiator.class
  created: sun/
  created: sun/security/
  created: sun/security/ssl/
 inflated: sun/security/ssl/Alerts.class
 inflated: sun/security/ssl/AlpnExtension$Builder.class
 inflated: sun/security/ssl/AlpnExtension.class
 inflated: sun/security/ssl/ClientHandshaker$1.class
 inflated: sun/security/ssl/ClientHandshaker$2.class
 inflated: sun/security/ssl/ClientHandshaker.class
 inflated: sun/security/ssl/ExtensionType.class
 inflated: sun/security/ssl/GrizzlyNPN.class
 inflated: sun/security/ssl/HandshakeMessage$1.class
 inflated: sun/security/ssl/HandshakeMessage$CertificateMsg.class
 inflated: sun/security/ssl/HandshakeMessage$CertificateRequest.class
 inflated: sun/security/ssl/HandshakeMessage$CertificateVerify$1.class
 inflated: sun/security/ssl/HandshakeMessage$CertificateVerify.class
 inflated: sun/security/ssl/HandshakeMessage$ClientHello.class
 inflated: sun/security/ssl/HandshakeMessage$DH_ServerKeyExchange.class
 inflated: sun/security/ssl/HandshakeMessage$DistinguishedName.class
 inflated: sun/security/ssl/HandshakeMessage$ECDH_ServerKeyExchange.class
 inflated: sun/security/ssl/HandshakeMessage$Finished.class
 inflated: sun/security/ssl/HandshakeMessage$HelloRequest.class
 inflated: sun/security/ssl/HandshakeMessage$NextProtocol$Builder.class
 inflated: sun/security/ssl/HandshakeMessage$NextProtocol.class
 inflated: sun/security/ssl/HandshakeMessage$RSA_ServerKeyExchange.class
 inflated: sun/security/ssl/HandshakeMessage$ServerHello.class
 inflated: sun/security/ssl/HandshakeMessage$ServerHelloDone.class
 inflated: sun/security/ssl/HandshakeMessage$ServerKeyExchange.class
 inflated: sun/security/ssl/HandshakeMessage.class
 inflated: sun/security/ssl/Handshaker$1.class
 inflated: sun/security/ssl/Handshaker$DelegatedTask.class
 inflated: sun/security/ssl/Handshaker.class
 inflated: sun/security/ssl/HelloExtensions.class
 inflated: sun/security/ssl/NextProtocolNegotiationExtension$Builder.class
 inflated: sun/security/ssl/NextProtocolNegotiationExtension.class
 inflated: sun/security/ssl/SSLEngineImpl.class
 inflated: sun/security/ssl/ServerHandshaker$1.class
 inflated: sun/security/ssl/ServerHandshaker$2.class
 inflated: sun/security/ssl/ServerHandshaker$3.class
 inflated: sun/security/ssl/ServerHandshaker.class

  1. 观察到 jar 文件在根级别包含 3 个文件夹:META-INForgsun。再次根据 Antoine 的回答,我们要删除
    sun
    文件夹。
  2. 我不知道通过指定要删除的文件夹来重新创建 jar 的命令行方法,所以我执行了这个命令,通过添加
    META-INF
    org 文件夹来重新创建 grizzly-npn-bootstrap.jar
    jar -cvf grizzly-npn-bootstrap.jar META-INF/* org/* 
  3. 随后,如果我执行
    jar -xvf grizzly-npn-bootstrap.jar
    命令,我会得到这个输出(注意不再列出 sun 文件夹):
cduran@cduran-VirtualBox:~/glassfish-5.0-web-profile/glassfish5/glassfish/modules/endorsed$ jar -xvf grizzly-npn-bootstrap.jar 
  created: META-INF/
 inflated: META-INF/MANIFEST.MF
  created: META-INF/maven/
  created: META-INF/maven/org.glassfish.grizzly/
  created: META-INF/maven/org.glassfish.grizzly/grizzly-npn-bootstrap/
 inflated: META-INF/maven/org.glassfish.grizzly/grizzly-npn-bootstrap/pom.properties
 inflated: META-INF/maven/org.glassfish.grizzly/grizzly-npn-bootstrap/pom.xml
  created: org/glassfish/
  created: org/glassfish/grizzly/
  created: org/glassfish/grizzly/npn/
 inflated: org/glassfish/grizzly/npn/ClientSideNegotiator.class
 inflated: org/glassfish/grizzly/npn/ServerSideNegotiator.class
 inflated: org/glassfish/grizzly/npn/AlpnClientNegotiator.class
 inflated: org/glassfish/grizzly/npn/NegotiationSupport.class
 inflated: org/glassfish/grizzly/npn/AlpnServerNegotiator.class
  1. 重新启动你的玻璃鱼。

在此之后,我不再收到上面发布的 OP 的错误消息:

java.lang.NoSuchMethodError: sun.security.ssl.SSLSessionImpl.(Lsun/security/ssl/ProtocolVersion;Lsun/security/ssl/CipherSuite;Ljava/util/Collection;Lsun/security/ssl/SessionId;Ljava/lang/String;I)V


1
投票

也许更优雅一点的是使用 npn-grizzly jar 中完成的现有修复:

mkdir -p scratch/glassfish5/glassfish/modules/endorsed && cd scratch
wget http://download.oracle.com/glassfish/5.0.1/nightly/glassfish-5.0.1-b02-12_03_2018.zip
wget http://central.maven.org/maven2/org/glassfish/grizzly/grizzly-npn-bootstrap/1.8.1/grizzly-npn-bootstrap-1.8.1.jar
mv grizzly-npn-bootstrap-1.8.1.jar glassfish5/glassfish/modules/endorsed/grizzly-npn-bootstrap.jar
jar uvf glassfish-5.0.1-b02-12_03_2018.zip glassfish5/glassfish/modules/endorsed/grizzly-npn-bootstrap.jar 
echo "you have a patched archive for runnig with Java 8 patchlevel 191"

HTH


0
投票

几天前我对这个问题进行了深入研究,并通过查看JDK源代码找到了根本原因。我想你现在正在使用 openjdk。 这是 1.8.0_242 之前 openjdk 中的错误。 SSLSessionImpl 在 SSLSessionEngine 中使用时不会被实例化。它被用作静态类,但它只是一个最终类。 该问题已在 1.8.0_252 中修复,建议您升级至该版本。或者切换到任何构建的 Oracle jdk1.8.0,因为它没有这样的错误。 希望能帮助到你。 打开jdk: SSLSessionEngine.java SSLSessionImpl.java 甲骨文jdk: SSLSessionEngine.java

© www.soinside.com 2019 - 2024. All rights reserved.