当我尝试使用
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"
}
问题的出现是因为Glassfish将原生的
sun.*
类嵌入到[glassfish5_home]/glassfish/modules/endorsed/grizzly-npn-bootstrap.jar
中,因此它与包含在[JDK_HOME]/jre/lib/jsse.jar
中的其他类发生冲突
所以编辑
grizzly-npn-bootstrap.jar
(之前复制一份)文件并删除sun文件夹。
编辑:因为这是“正确答案”,Java 1.8.0-151 可能会缺少安全补丁。我不建议降级到这么旧的 Java 版本。
请查看 Payara 项目或 Glassfish 的新版本。
--
尝试将Java版本降级到Java 1.8.0-151。它应该工作。
带有 Java 8 161 的 glassfish 5 中存在一个问题,创建了一个issue,但我昨天(3 月 19 日)检查过关于这个问题的夜间构建没有变化。
上述错误可能导致在您的浏览器中显示:
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
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。无需删除或更改任何内容。
我刚刚遇到这个令人沮丧的问题,我确实想稍微扩展 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)
正如安托万所说,我将
grizzly-npn-bootstrap.jar
复制到另一个位置作为备份。我做了
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
sun
文件夹。META-INF和 org 文件夹来重新创建
grizzly-npn-bootstrap.jar
:jar -cvf grizzly-npn-bootstrap.jar META-INF/* org/*
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
在此之后,我不再收到上面发布的 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
也许更优雅一点的是使用 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