public abstract class sun.security.ssl.SSLContextImpl extends javax.net.ssl.SSLContextSpi
minor version: 0
major version: 59
flags: flags: (0x0421) ACC_PUBLIC, ACC_SUPER, ACC_ABSTRACT
this_class: sun.security.ssl.SSLContextImpl
super_class: javax.net.ssl.SSLContextSpi
{
private final sun.security.ssl.EphemeralKeyManager ephemeralKeyManager;
descriptor: Lsun/security/ssl/EphemeralKeyManager;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final sun.security.ssl.SSLSessionContextImpl clientCache;
descriptor: Lsun/security/ssl/SSLSessionContextImpl;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final sun.security.ssl.SSLSessionContextImpl serverCache;
descriptor: Lsun/security/ssl/SSLSessionContextImpl;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private boolean isInitialized;
descriptor: Z
flags: (0x0002) ACC_PRIVATE
private javax.net.ssl.X509ExtendedKeyManager keyManager;
descriptor: Ljavax/net/ssl/X509ExtendedKeyManager;
flags: (0x0002) ACC_PRIVATE
private javax.net.ssl.X509TrustManager trustManager;
descriptor: Ljavax/net/ssl/X509TrustManager;
flags: (0x0002) ACC_PRIVATE
private java.security.SecureRandom secureRandom;
descriptor: Ljava/security/SecureRandom;
flags: (0x0002) ACC_PRIVATE
private volatile sun.security.ssl.HelloCookieManager$Builder helloCookieManagerBuilder;
descriptor: Lsun/security/ssl/HelloCookieManager$Builder;
flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE
private final boolean clientEnableStapling;
descriptor: Z
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final boolean serverEnableStapling;
descriptor: Z
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private static final java.util.Collection<sun.security.ssl.CipherSuite> clientCustomizedCipherSuites;
descriptor: Ljava/util/Collection;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
Signature: Ljava/util/Collection<Lsun/security/ssl/CipherSuite;>;
private static final java.util.Collection<sun.security.ssl.CipherSuite> serverCustomizedCipherSuites;
descriptor: Ljava/util/Collection;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
Signature: Ljava/util/Collection<Lsun/security/ssl/CipherSuite;>;
private volatile sun.security.ssl.StatusResponseManager statusResponseManager;
descriptor: Lsun/security/ssl/StatusResponseManager;
flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE
static void <clinit>();
descriptor: ()V
flags: (0x0008) ACC_STATIC
Code:
stack=1, locals=0, args_size=0
0: ldc "jdk.tls.client.cipherSuites"
invokestatic sun.security.ssl.SSLContextImpl.getCustomizedCipherSuites:(Ljava/lang/String;)Ljava/util/Collection;
1: putstatic sun.security.ssl.SSLContextImpl.clientCustomizedCipherSuites:Ljava/util/Collection;
2: ldc "jdk.tls.server.cipherSuites"
invokestatic sun.security.ssl.SSLContextImpl.getCustomizedCipherSuites:(Ljava/lang/String;)Ljava/util/Collection;
3: putstatic sun.security.ssl.SSLContextImpl.serverCustomizedCipherSuites:Ljava/util/Collection;
4: return
LocalVariableTable:
Start End Slot Name Signature
void <init>();
descriptor: ()V
flags: (0x0000)
Code:
stack=3, locals=1, args_size=1
start local 0 0: aload 0
invokespecial javax.net.ssl.SSLContextSpi.<init>:()V
1: aload 0
2: ldc "jdk.tls.client.enableStatusRequestExtension"
iconst_1
3: invokestatic sun.security.ssl.Utilities.getBooleanProperty:(Ljava/lang/String;Z)Z
putfield sun.security.ssl.SSLContextImpl.clientEnableStapling:Z
4: aload 0
5: ldc "jdk.tls.server.enableStatusRequestExtension"
iconst_0
6: invokestatic sun.security.ssl.Utilities.getBooleanProperty:(Ljava/lang/String;Z)Z
putfield sun.security.ssl.SSLContextImpl.serverEnableStapling:Z
7: aload 0
new sun.security.ssl.EphemeralKeyManager
dup
invokespecial sun.security.ssl.EphemeralKeyManager.<init>:()V
putfield sun.security.ssl.SSLContextImpl.ephemeralKeyManager:Lsun/security/ssl/EphemeralKeyManager;
8: aload 0
new sun.security.ssl.SSLSessionContextImpl
dup
invokespecial sun.security.ssl.SSLSessionContextImpl.<init>:()V
putfield sun.security.ssl.SSLContextImpl.clientCache:Lsun/security/ssl/SSLSessionContextImpl;
9: aload 0
new sun.security.ssl.SSLSessionContextImpl
dup
invokespecial sun.security.ssl.SSLSessionContextImpl.<init>:()V
putfield sun.security.ssl.SSLContextImpl.serverCache:Lsun/security/ssl/SSLSessionContextImpl;
10: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 11 0 this Lsun/security/ssl/SSLContextImpl;
protected void engineInit(javax.net.ssl.KeyManager[], javax.net.ssl.TrustManager[], java.security.SecureRandom);
descriptor: ([Ljavax/net/ssl/KeyManager;[Ljavax/net/ssl/TrustManager;Ljava/security/SecureRandom;)V
flags: (0x0004) ACC_PROTECTED
Code:
stack=5, locals=5, args_size=4
start local 0 start local 1 start local 2 start local 3 0: aload 0
iconst_0
putfield sun.security.ssl.SSLContextImpl.isInitialized:Z
1: aload 0
aload 0
aload 1
invokevirtual sun.security.ssl.SSLContextImpl.chooseKeyManager:([Ljavax/net/ssl/KeyManager;)Ljavax/net/ssl/X509ExtendedKeyManager;
putfield sun.security.ssl.SSLContextImpl.keyManager:Ljavax/net/ssl/X509ExtendedKeyManager;
2: aload 2
ifnonnull 9
3: invokestatic javax.net.ssl.TrustManagerFactory.getDefaultAlgorithm:()Ljava/lang/String;
4: invokestatic javax.net.ssl.TrustManagerFactory.getInstance:(Ljava/lang/String;)Ljavax/net/ssl/TrustManagerFactory;
astore 4
start local 4 5: aload 4
aconst_null
invokevirtual javax.net.ssl.TrustManagerFactory.init:(Ljava/security/KeyStore;)V
6: aload 4
invokevirtual javax.net.ssl.TrustManagerFactory.getTrustManagers:()[Ljavax/net/ssl/TrustManager;
astore 2
end local 4 7: goto 9
StackMap locals:
StackMap stack: java.lang.Exception
8: pop
9: StackMap locals:
StackMap stack:
aload 0
aload 0
aload 2
invokevirtual sun.security.ssl.SSLContextImpl.chooseTrustManager:([Ljavax/net/ssl/TrustManager;)Ljavax/net/ssl/X509TrustManager;
putfield sun.security.ssl.SSLContextImpl.trustManager:Ljavax/net/ssl/X509TrustManager;
10: aload 3
ifnonnull 13
11: aload 0
invokestatic sun.security.ssl.JsseJce.getSecureRandom:()Ljava/security/SecureRandom;
putfield sun.security.ssl.SSLContextImpl.secureRandom:Ljava/security/SecureRandom;
12: goto 21
13: StackMap locals:
StackMap stack:
invokestatic sun.security.ssl.SunJSSE.isFIPS:()Z
ifeq 20
14: aload 3
invokevirtual java.security.SecureRandom.getProvider:()Ljava/security/Provider;
getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
if_acmpeq 20
15: new java.security.KeyManagementException
dup
16: new java.lang.StringBuilder
dup
ldc "FIPS mode: SecureRandom must be from provider "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
17: getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
invokevirtual java.security.Provider.getName:()Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
18: invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
19: invokespecial java.security.KeyManagementException.<init>:(Ljava/lang/String;)V
athrow
20: StackMap locals:
StackMap stack:
aload 0
aload 3
putfield sun.security.ssl.SSLContextImpl.secureRandom:Ljava/security/SecureRandom;
21: StackMap locals:
StackMap stack:
getstatic sun.security.ssl.SSLLogger.isOn:Z
ifeq 23
ldc "ssl,sslctx"
invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
ifeq 23
22: ldc "trigger seeding of SecureRandom"
iconst_0
anewarray java.lang.Object
invokestatic sun.security.ssl.SSLLogger.finest:(Ljava/lang/String;[Ljava/lang/Object;)V
23: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.ssl.SSLContextImpl.secureRandom:Ljava/security/SecureRandom;
invokevirtual java.security.SecureRandom.nextInt:()I
pop
24: getstatic sun.security.ssl.SSLLogger.isOn:Z
ifeq 26
ldc "ssl,sslctx"
invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
ifeq 26
25: ldc "done seeding of SecureRandom"
iconst_0
anewarray java.lang.Object
invokestatic sun.security.ssl.SSLLogger.finest:(Ljava/lang/String;[Ljava/lang/Object;)V
26: StackMap locals:
StackMap stack:
aload 0
iconst_1
putfield sun.security.ssl.SSLContextImpl.isInitialized:Z
27: return
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 28 0 this Lsun/security/ssl/SSLContextImpl;
0 28 1 km [Ljavax/net/ssl/KeyManager;
0 28 2 tm [Ljavax/net/ssl/TrustManager;
0 28 3 sr Ljava/security/SecureRandom;
5 7 4 tmf Ljavax/net/ssl/TrustManagerFactory;
Exception table:
from to target type
3 7 8 Class java.lang.Exception
Exceptions:
throws java.security.KeyManagementException
MethodParameters:
Name Flags
km
tm
sr
private javax.net.ssl.X509TrustManager chooseTrustManager(javax.net.ssl.TrustManager[]);
descriptor: ([Ljavax/net/ssl/TrustManager;)Ljavax/net/ssl/X509TrustManager;
flags: (0x0002) ACC_PRIVATE
Code:
stack=4, locals=3, args_size=2
start local 0 start local 1 0: iconst_0
istore 2
start local 2 1: goto 14
2: StackMap locals: int
StackMap stack:
aload 1
iload 2
aaload
instanceof javax.net.ssl.X509TrustManager
ifeq 13
3: invokestatic sun.security.ssl.SunJSSE.isFIPS:()Z
ifeq 8
4: aload 1
iload 2
aaload
instanceof sun.security.ssl.X509TrustManagerImpl
ifne 8
5: new java.security.KeyManagementException
dup
6: ldc "FIPS mode: only SunJSSE TrustManagers may be used"
7: invokespecial java.security.KeyManagementException.<init>:(Ljava/lang/String;)V
athrow
8: StackMap locals:
StackMap stack:
aload 1
iload 2
aaload
instanceof javax.net.ssl.X509ExtendedTrustManager
ifeq 10
9: aload 1
iload 2
aaload
checkcast javax.net.ssl.X509TrustManager
areturn
10: StackMap locals:
StackMap stack:
new sun.security.ssl.AbstractTrustManagerWrapper
dup
11: aload 1
iload 2
aaload
checkcast javax.net.ssl.X509TrustManager
12: invokespecial sun.security.ssl.AbstractTrustManagerWrapper.<init>:(Ljavax/net/ssl/X509TrustManager;)V
areturn
13: StackMap locals:
StackMap stack:
iinc 2 1
StackMap locals:
StackMap stack:
14: aload 1
ifnull 15
iload 2
aload 1
arraylength
if_icmplt 2
end local 2 15: StackMap locals:
StackMap stack:
getstatic sun.security.ssl.DummyX509TrustManager.INSTANCE:Ljavax/net/ssl/X509TrustManager;
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 16 0 this Lsun/security/ssl/SSLContextImpl;
0 16 1 tm [Ljavax/net/ssl/TrustManager;
1 15 2 i I
Exceptions:
throws java.security.KeyManagementException
MethodParameters:
Name Flags
tm
private javax.net.ssl.X509ExtendedKeyManager chooseKeyManager(javax.net.ssl.KeyManager[]);
descriptor: ([Ljavax/net/ssl/KeyManager;)Ljavax/net/ssl/X509ExtendedKeyManager;
flags: (0x0002) ACC_PRIVATE
Code:
stack=3, locals=4, args_size=2
start local 0 start local 1 0: iconst_0
istore 2
start local 2 1: goto 19
2: StackMap locals: int
StackMap stack:
aload 1
iload 2
aaload
astore 3
start local 3 3: aload 3
instanceof javax.net.ssl.X509KeyManager
ifne 5
4: goto 18
5: StackMap locals: javax.net.ssl.KeyManager
StackMap stack:
invokestatic sun.security.ssl.SunJSSE.isFIPS:()Z
ifeq 12
6: aload 3
instanceof sun.security.ssl.X509KeyManagerImpl
ifne 8
7: aload 3
instanceof sun.security.ssl.SunX509KeyManagerImpl
ifeq 9
8: StackMap locals:
StackMap stack:
aload 3
checkcast javax.net.ssl.X509ExtendedKeyManager
areturn
9: StackMap locals:
StackMap stack:
new java.security.KeyManagementException
dup
10: ldc "FIPS mode: only SunJSSE KeyManagers may be used"
11: invokespecial java.security.KeyManagementException.<init>:(Ljava/lang/String;)V
athrow
12: StackMap locals:
StackMap stack:
aload 3
instanceof javax.net.ssl.X509ExtendedKeyManager
ifeq 14
13: aload 3
checkcast javax.net.ssl.X509ExtendedKeyManager
areturn
14: StackMap locals:
StackMap stack:
getstatic sun.security.ssl.SSLLogger.isOn:Z
ifeq 17
ldc "ssl,sslctx"
invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
ifeq 17
15: ldc "X509KeyManager passed to SSLContext.init(): need an X509ExtendedKeyManager for SSLEngine use"
iconst_0
anewarray java.lang.Object
16: invokestatic sun.security.ssl.SSLLogger.warning:(Ljava/lang/String;[Ljava/lang/Object;)V
17: StackMap locals:
StackMap stack:
new sun.security.ssl.AbstractKeyManagerWrapper
dup
aload 3
checkcast javax.net.ssl.X509KeyManager
invokespecial sun.security.ssl.AbstractKeyManagerWrapper.<init>:(Ljavax/net/ssl/X509KeyManager;)V
areturn
end local 3 18: StackMap locals:
StackMap stack:
iinc 2 1
StackMap locals:
StackMap stack:
19: aload 1
ifnull 20
iload 2
aload 1
arraylength
if_icmplt 2
end local 2 20: StackMap locals:
StackMap stack:
getstatic sun.security.ssl.DummyX509KeyManager.INSTANCE:Ljavax/net/ssl/X509ExtendedKeyManager;
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 21 0 this Lsun/security/ssl/SSLContextImpl;
0 21 1 kms [Ljavax/net/ssl/KeyManager;
1 20 2 i I
3 18 3 km Ljavax/net/ssl/KeyManager;
Exceptions:
throws java.security.KeyManagementException
MethodParameters:
Name Flags
kms
abstract javax.net.ssl.SSLEngine createSSLEngineImpl();
descriptor: ()Ljavax/net/ssl/SSLEngine;
flags: (0x0400) ACC_ABSTRACT
abstract javax.net.ssl.SSLEngine createSSLEngineImpl(java.lang.String, int);
descriptor: (Ljava/lang/String;I)Ljavax/net/ssl/SSLEngine;
flags: (0x0400) ACC_ABSTRACT
MethodParameters:
Name Flags
host
port
protected javax.net.ssl.SSLEngine engineCreateSSLEngine();
descriptor: ()Ljavax/net/ssl/SSLEngine;
flags: (0x0004) ACC_PROTECTED
Code:
stack=3, locals=1, args_size=1
start local 0 0: aload 0
getfield sun.security.ssl.SSLContextImpl.isInitialized:Z
ifne 2
1: new java.lang.IllegalStateException
dup
ldc "SSLContext is not initialized"
invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
athrow
2: StackMap locals:
StackMap stack:
aload 0
invokevirtual sun.security.ssl.SSLContextImpl.createSSLEngineImpl:()Ljavax/net/ssl/SSLEngine;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lsun/security/ssl/SSLContextImpl;
protected javax.net.ssl.SSLEngine engineCreateSSLEngine(java.lang.String, int);
descriptor: (Ljava/lang/String;I)Ljavax/net/ssl/SSLEngine;
flags: (0x0004) ACC_PROTECTED
Code:
stack=3, locals=3, args_size=3
start local 0 start local 1 start local 2 0: aload 0
getfield sun.security.ssl.SSLContextImpl.isInitialized:Z
ifne 2
1: new java.lang.IllegalStateException
dup
ldc "SSLContext is not initialized"
invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
athrow
2: StackMap locals:
StackMap stack:
aload 0
aload 1
iload 2
invokevirtual sun.security.ssl.SSLContextImpl.createSSLEngineImpl:(Ljava/lang/String;I)Ljavax/net/ssl/SSLEngine;
areturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lsun/security/ssl/SSLContextImpl;
0 3 1 host Ljava/lang/String;
0 3 2 port I
MethodParameters:
Name Flags
host
port
protected javax.net.ssl.SSLSocketFactory engineGetSocketFactory();
descriptor: ()Ljavax/net/ssl/SSLSocketFactory;
flags: (0x0004) ACC_PROTECTED
Code:
stack=3, locals=1, args_size=1
start local 0 0: aload 0
getfield sun.security.ssl.SSLContextImpl.isInitialized:Z
ifne 2
1: new java.lang.IllegalStateException
dup
ldc "SSLContext is not initialized"
invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
athrow
2: StackMap locals:
StackMap stack:
aload 0
invokevirtual sun.security.ssl.SSLContextImpl.isDTLS:()Z
ifeq 6
3: new java.lang.UnsupportedOperationException
dup
4: ldc "DTLS not supported with SSLSocket"
5: invokespecial java.lang.UnsupportedOperationException.<init>:(Ljava/lang/String;)V
athrow
6: StackMap locals:
StackMap stack:
new sun.security.ssl.SSLSocketFactoryImpl
dup
aload 0
invokespecial sun.security.ssl.SSLSocketFactoryImpl.<init>:(Lsun/security/ssl/SSLContextImpl;)V
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 7 0 this Lsun/security/ssl/SSLContextImpl;
protected javax.net.ssl.SSLServerSocketFactory engineGetServerSocketFactory();
descriptor: ()Ljavax/net/ssl/SSLServerSocketFactory;
flags: (0x0004) ACC_PROTECTED
Code:
stack=3, locals=1, args_size=1
start local 0 0: aload 0
getfield sun.security.ssl.SSLContextImpl.isInitialized:Z
ifne 2
1: new java.lang.IllegalStateException
dup
ldc "SSLContext is not initialized"
invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
athrow
2: StackMap locals:
StackMap stack:
aload 0
invokevirtual sun.security.ssl.SSLContextImpl.isDTLS:()Z
ifeq 6
3: new java.lang.UnsupportedOperationException
dup
4: ldc "DTLS not supported with SSLServerSocket"
5: invokespecial java.lang.UnsupportedOperationException.<init>:(Ljava/lang/String;)V
athrow
6: StackMap locals:
StackMap stack:
new sun.security.ssl.SSLServerSocketFactoryImpl
dup
aload 0
invokespecial sun.security.ssl.SSLServerSocketFactoryImpl.<init>:(Lsun/security/ssl/SSLContextImpl;)V
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 7 0 this Lsun/security/ssl/SSLContextImpl;
protected javax.net.ssl.SSLSessionContext engineGetClientSessionContext();
descriptor: ()Ljavax/net/ssl/SSLSessionContext;
flags: (0x0004) ACC_PROTECTED
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield sun.security.ssl.SSLContextImpl.clientCache:Lsun/security/ssl/SSLSessionContextImpl;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lsun/security/ssl/SSLContextImpl;
protected javax.net.ssl.SSLSessionContext engineGetServerSessionContext();
descriptor: ()Ljavax/net/ssl/SSLSessionContext;
flags: (0x0004) ACC_PROTECTED
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield sun.security.ssl.SSLContextImpl.serverCache:Lsun/security/ssl/SSLSessionContextImpl;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lsun/security/ssl/SSLContextImpl;
java.security.SecureRandom getSecureRandom();
descriptor: ()Ljava/security/SecureRandom;
flags: (0x0000)
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield sun.security.ssl.SSLContextImpl.secureRandom:Ljava/security/SecureRandom;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lsun/security/ssl/SSLContextImpl;
javax.net.ssl.X509ExtendedKeyManager getX509KeyManager();
descriptor: ()Ljavax/net/ssl/X509ExtendedKeyManager;
flags: (0x0000)
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield sun.security.ssl.SSLContextImpl.keyManager:Ljavax/net/ssl/X509ExtendedKeyManager;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lsun/security/ssl/SSLContextImpl;
javax.net.ssl.X509TrustManager getX509TrustManager();
descriptor: ()Ljavax/net/ssl/X509TrustManager;
flags: (0x0000)
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield sun.security.ssl.SSLContextImpl.trustManager:Ljavax/net/ssl/X509TrustManager;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lsun/security/ssl/SSLContextImpl;
sun.security.ssl.EphemeralKeyManager getEphemeralKeyManager();
descriptor: ()Lsun/security/ssl/EphemeralKeyManager;
flags: (0x0000)
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield sun.security.ssl.SSLContextImpl.ephemeralKeyManager:Lsun/security/ssl/EphemeralKeyManager;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lsun/security/ssl/SSLContextImpl;
sun.security.ssl.HelloCookieManager getHelloCookieManager(sun.security.ssl.ProtocolVersion);
descriptor: (Lsun/security/ssl/ProtocolVersion;)Lsun/security/ssl/HelloCookieManager;
flags: (0x0000)
Code:
stack=4, locals=3, args_size=2
start local 0 start local 1 0: aload 0
getfield sun.security.ssl.SSLContextImpl.helloCookieManagerBuilder:Lsun/security/ssl/HelloCookieManager$Builder;
ifnonnull 10
1: aload 0
dup
astore 2
monitorenter
2: aload 0
getfield sun.security.ssl.SSLContextImpl.helloCookieManagerBuilder:Lsun/security/ssl/HelloCookieManager$Builder;
ifnonnull 6
3: aload 0
4: new sun.security.ssl.HelloCookieManager$Builder
dup
aload 0
getfield sun.security.ssl.SSLContextImpl.secureRandom:Ljava/security/SecureRandom;
invokespecial sun.security.ssl.HelloCookieManager$Builder.<init>:(Ljava/security/SecureRandom;)V
5: putfield sun.security.ssl.SSLContextImpl.helloCookieManagerBuilder:Lsun/security/ssl/HelloCookieManager$Builder;
6: StackMap locals: sun.security.ssl.SSLContextImpl
StackMap stack:
aload 2
monitorexit
7: goto 10
StackMap locals:
StackMap stack: java.lang.Throwable
8: aload 2
monitorexit
9: athrow
10: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.ssl.SSLContextImpl.helloCookieManagerBuilder:Lsun/security/ssl/HelloCookieManager$Builder;
aload 1
invokevirtual sun.security.ssl.HelloCookieManager$Builder.valueOf:(Lsun/security/ssl/ProtocolVersion;)Lsun/security/ssl/HelloCookieManager;
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 11 0 this Lsun/security/ssl/SSLContextImpl;
0 11 1 protocolVersion Lsun/security/ssl/ProtocolVersion;
Exception table:
from to target type
2 7 8 any
8 9 8 any
MethodParameters:
Name Flags
protocolVersion
sun.security.ssl.StatusResponseManager getStatusResponseManager();
descriptor: ()Lsun/security/ssl/StatusResponseManager;
flags: (0x0000)
Code:
stack=3, locals=2, args_size=1
start local 0 0: aload 0
getfield sun.security.ssl.SSLContextImpl.serverEnableStapling:Z
ifeq 11
aload 0
getfield sun.security.ssl.SSLContextImpl.statusResponseManager:Lsun/security/ssl/StatusResponseManager;
ifnonnull 11
1: aload 0
dup
astore 1
monitorenter
2: aload 0
getfield sun.security.ssl.SSLContextImpl.statusResponseManager:Lsun/security/ssl/StatusResponseManager;
ifnonnull 7
3: getstatic sun.security.ssl.SSLLogger.isOn:Z
ifeq 6
ldc "ssl,sslctx"
invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
ifeq 6
4: ldc "Initializing StatusResponseManager"
iconst_0
anewarray java.lang.Object
5: invokestatic sun.security.ssl.SSLLogger.finest:(Ljava/lang/String;[Ljava/lang/Object;)V
6: StackMap locals: sun.security.ssl.SSLContextImpl
StackMap stack:
aload 0
new sun.security.ssl.StatusResponseManager
dup
invokespecial sun.security.ssl.StatusResponseManager.<init>:()V
putfield sun.security.ssl.SSLContextImpl.statusResponseManager:Lsun/security/ssl/StatusResponseManager;
7: StackMap locals:
StackMap stack:
aload 1
monitorexit
8: goto 11
StackMap locals:
StackMap stack: java.lang.Throwable
9: aload 1
monitorexit
10: athrow
11: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.ssl.SSLContextImpl.statusResponseManager:Lsun/security/ssl/StatusResponseManager;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 12 0 this Lsun/security/ssl/SSLContextImpl;
Exception table:
from to target type
2 8 9 any
9 10 9 any
abstract java.util.List<sun.security.ssl.ProtocolVersion> getSupportedProtocolVersions();
descriptor: ()Ljava/util/List;
flags: (0x0400) ACC_ABSTRACT
Signature: ()Ljava/util/List<Lsun/security/ssl/ProtocolVersion;>;
abstract java.util.List<sun.security.ssl.ProtocolVersion> getServerDefaultProtocolVersions();
descriptor: ()Ljava/util/List;
flags: (0x0400) ACC_ABSTRACT
Signature: ()Ljava/util/List<Lsun/security/ssl/ProtocolVersion;>;
abstract java.util.List<sun.security.ssl.ProtocolVersion> getClientDefaultProtocolVersions();
descriptor: ()Ljava/util/List;
flags: (0x0400) ACC_ABSTRACT
Signature: ()Ljava/util/List<Lsun/security/ssl/ProtocolVersion;>;
abstract java.util.List<sun.security.ssl.CipherSuite> getSupportedCipherSuites();
descriptor: ()Ljava/util/List;
flags: (0x0400) ACC_ABSTRACT
Signature: ()Ljava/util/List<Lsun/security/ssl/CipherSuite;>;
abstract java.util.List<sun.security.ssl.CipherSuite> getServerDefaultCipherSuites();
descriptor: ()Ljava/util/List;
flags: (0x0400) ACC_ABSTRACT
Signature: ()Ljava/util/List<Lsun/security/ssl/CipherSuite;>;
abstract java.util.List<sun.security.ssl.CipherSuite> getClientDefaultCipherSuites();
descriptor: ()Ljava/util/List;
flags: (0x0400) ACC_ABSTRACT
Signature: ()Ljava/util/List<Lsun/security/ssl/CipherSuite;>;
abstract boolean isDTLS();
descriptor: ()Z
flags: (0x0400) ACC_ABSTRACT
java.util.List<sun.security.ssl.ProtocolVersion> getDefaultProtocolVersions(boolean);
descriptor: (Z)Ljava/util/List;
flags: (0x0000)
Code:
stack=1, locals=2, args_size=2
start local 0 start local 1 0: iload 1
ifeq 1
aload 0
invokevirtual sun.security.ssl.SSLContextImpl.getServerDefaultProtocolVersions:()Ljava/util/List;
goto 2
1: StackMap locals:
StackMap stack:
aload 0
invokevirtual sun.security.ssl.SSLContextImpl.getClientDefaultProtocolVersions:()Ljava/util/List;
2: StackMap locals:
StackMap stack: java.util.List
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lsun/security/ssl/SSLContextImpl;
0 3 1 roleIsServer Z
Signature: (Z)Ljava/util/List<Lsun/security/ssl/ProtocolVersion;>;
MethodParameters:
Name Flags
roleIsServer
java.util.List<sun.security.ssl.CipherSuite> getDefaultCipherSuites(boolean);
descriptor: (Z)Ljava/util/List;
flags: (0x0000)
Code:
stack=1, locals=2, args_size=2
start local 0 start local 1 0: iload 1
ifeq 1
aload 0
invokevirtual sun.security.ssl.SSLContextImpl.getServerDefaultCipherSuites:()Ljava/util/List;
goto 2
1: StackMap locals:
StackMap stack:
aload 0
invokevirtual sun.security.ssl.SSLContextImpl.getClientDefaultCipherSuites:()Ljava/util/List;
2: StackMap locals:
StackMap stack: java.util.List
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lsun/security/ssl/SSLContextImpl;
0 3 1 roleIsServer Z
Signature: (Z)Ljava/util/List<Lsun/security/ssl/CipherSuite;>;
MethodParameters:
Name Flags
roleIsServer
boolean isDefaultProtocolVesions(java.util.List<sun.security.ssl.ProtocolVersion>);
descriptor: (Ljava/util/List;)Z
flags: (0x0000)
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 1
aload 0
invokevirtual sun.security.ssl.SSLContextImpl.getServerDefaultProtocolVersions:()Ljava/util/List;
if_acmpeq 3
1: aload 1
aload 0
invokevirtual sun.security.ssl.SSLContextImpl.getClientDefaultProtocolVersions:()Ljava/util/List;
if_acmpeq 3
2: iconst_0
ireturn
StackMap locals:
StackMap stack:
3: iconst_1
ireturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lsun/security/ssl/SSLContextImpl;
0 4 1 protocols Ljava/util/List<Lsun/security/ssl/ProtocolVersion;>;
Signature: (Ljava/util/List<Lsun/security/ssl/ProtocolVersion;>;)Z
MethodParameters:
Name Flags
protocols
boolean isDefaultCipherSuiteList(java.util.List<sun.security.ssl.CipherSuite>);
descriptor: (Ljava/util/List;)Z
flags: (0x0000)
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 1
aload 0
invokevirtual sun.security.ssl.SSLContextImpl.getServerDefaultCipherSuites:()Ljava/util/List;
if_acmpeq 3
1: aload 1
aload 0
invokevirtual sun.security.ssl.SSLContextImpl.getClientDefaultCipherSuites:()Ljava/util/List;
if_acmpeq 3
2: iconst_0
ireturn
StackMap locals:
StackMap stack:
3: iconst_1
ireturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lsun/security/ssl/SSLContextImpl;
0 4 1 cipherSuites Ljava/util/List<Lsun/security/ssl/CipherSuite;>;
Signature: (Ljava/util/List<Lsun/security/ssl/CipherSuite;>;)Z
MethodParameters:
Name Flags
cipherSuites
boolean isStaplingEnabled(boolean);
descriptor: (Z)Z
flags: (0x0000)
Code:
stack=1, locals=2, args_size=2
start local 0 start local 1 0: iload 1
ifeq 1
aload 0
getfield sun.security.ssl.SSLContextImpl.clientEnableStapling:Z
goto 2
StackMap locals:
StackMap stack:
1: aload 0
getfield sun.security.ssl.SSLContextImpl.serverEnableStapling:Z
StackMap locals:
StackMap stack: int
2: ireturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lsun/security/ssl/SSLContextImpl;
0 3 1 isClient Z
MethodParameters:
Name Flags
isClient
private static java.util.List<sun.security.ssl.CipherSuite> getApplicableSupportedCipherSuites(java.util.List<sun.security.ssl.ProtocolVersion>);
descriptor: (Ljava/util/List;)Ljava/util/List;
flags: (0x000a) ACC_PRIVATE, ACC_STATIC
Code:
stack=2, locals=1, args_size=1
start local 0 0: invokestatic sun.security.ssl.CipherSuite.allowedCipherSuites:()Ljava/util/Collection;
aload 0
1: invokestatic sun.security.ssl.SSLContextImpl.getApplicableCipherSuites:(Ljava/util/Collection;Ljava/util/List;)Ljava/util/List;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 protocols Ljava/util/List<Lsun/security/ssl/ProtocolVersion;>;
Signature: (Ljava/util/List<Lsun/security/ssl/ProtocolVersion;>;)Ljava/util/List<Lsun/security/ssl/CipherSuite;>;
MethodParameters:
Name Flags
protocols
private static java.util.List<sun.security.ssl.CipherSuite> getApplicableEnabledCipherSuites(java.util.List<sun.security.ssl.ProtocolVersion>, boolean);
descriptor: (Ljava/util/List;Z)Ljava/util/List;
flags: (0x000a) ACC_PRIVATE, ACC_STATIC
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: iload 1
ifeq 4
1: getstatic sun.security.ssl.SSLContextImpl.clientCustomizedCipherSuites:Ljava/util/Collection;
invokeinterface java.util.Collection.isEmpty:()Z
ifne 7
2: getstatic sun.security.ssl.SSLContextImpl.clientCustomizedCipherSuites:Ljava/util/Collection;
aload 0
3: invokestatic sun.security.ssl.SSLContextImpl.getApplicableCipherSuites:(Ljava/util/Collection;Ljava/util/List;)Ljava/util/List;
areturn
4: StackMap locals:
StackMap stack:
getstatic sun.security.ssl.SSLContextImpl.serverCustomizedCipherSuites:Ljava/util/Collection;
invokeinterface java.util.Collection.isEmpty:()Z
ifne 7
5: getstatic sun.security.ssl.SSLContextImpl.serverCustomizedCipherSuites:Ljava/util/Collection;
aload 0
6: invokestatic sun.security.ssl.SSLContextImpl.getApplicableCipherSuites:(Ljava/util/Collection;Ljava/util/List;)Ljava/util/List;
areturn
7: StackMap locals:
StackMap stack:
invokestatic sun.security.ssl.CipherSuite.defaultCipherSuites:()Ljava/util/Collection;
aload 0
8: invokestatic sun.security.ssl.SSLContextImpl.getApplicableCipherSuites:(Ljava/util/Collection;Ljava/util/List;)Ljava/util/List;
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 9 0 protocols Ljava/util/List<Lsun/security/ssl/ProtocolVersion;>;
0 9 1 isClient Z
Signature: (Ljava/util/List<Lsun/security/ssl/ProtocolVersion;>;Z)Ljava/util/List<Lsun/security/ssl/CipherSuite;>;
MethodParameters:
Name Flags
protocols
isClient
private static java.util.List<sun.security.ssl.CipherSuite> getApplicableCipherSuites(java.util.Collection<sun.security.ssl.CipherSuite>, java.util.List<sun.security.ssl.ProtocolVersion>);
descriptor: (Ljava/util/Collection;Ljava/util/List;)Ljava/util/List;
flags: (0x000a) ACC_PRIVATE, ACC_STATIC
Code:
stack=4, locals=8, args_size=2
start local 0 start local 1 0: new java.util.TreeSet
dup
invokespecial java.util.TreeSet.<init>:()V
astore 2
start local 2 1: aload 1
ifnull 30
aload 1
invokeinterface java.util.List.isEmpty:()Z
ifne 30
2: aload 0
invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
astore 4
goto 29
StackMap locals: java.util.Collection java.util.List java.util.TreeSet top java.util.Iterator
StackMap stack:
3: aload 4
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast sun.security.ssl.CipherSuite
astore 3
start local 3 4: aload 3
invokevirtual sun.security.ssl.CipherSuite.isAvailable:()Z
ifne 6
5: goto 29
6: StackMap locals: java.util.Collection java.util.List java.util.TreeSet sun.security.ssl.CipherSuite java.util.Iterator
StackMap stack:
iconst_0
istore 5
start local 5 7: aload 1
invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
astore 7
goto 24
StackMap locals: java.util.Collection java.util.List java.util.TreeSet sun.security.ssl.CipherSuite java.util.Iterator int top java.util.Iterator
StackMap stack:
8: aload 7
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast sun.security.ssl.ProtocolVersion
astore 6
start local 6 9: aload 3
aload 6
invokevirtual sun.security.ssl.CipherSuite.supports:(Lsun/security/ssl/ProtocolVersion;)Z
ifne 11
10: goto 24
11: StackMap locals: java.util.Collection java.util.List java.util.TreeSet sun.security.ssl.CipherSuite java.util.Iterator int sun.security.ssl.ProtocolVersion java.util.Iterator
StackMap stack:
getstatic sun.security.ssl.SSLAlgorithmConstraints.DEFAULT:Ljava/security/AlgorithmConstraints;
12: getstatic java.security.CryptoPrimitive.KEY_AGREEMENT:Ljava/security/CryptoPrimitive;
invokestatic java.util.EnumSet.of:(Ljava/lang/Enum;)Ljava/util/EnumSet;
13: aload 3
getfield sun.security.ssl.CipherSuite.name:Ljava/lang/String;
aconst_null
14: invokeinterface java.security.AlgorithmConstraints.permits:(Ljava/util/Set;Ljava/lang/String;Ljava/security/AlgorithmParameters;)Z
15: ifeq 19
16: aload 2
aload 3
invokevirtual java.util.TreeSet.add:(Ljava/lang/Object;)Z
pop
17: iconst_1
istore 5
18: goto 25
StackMap locals:
StackMap stack:
19: getstatic sun.security.ssl.SSLLogger.isOn:Z
ifeq 25
20: ldc "ssl,sslctx,verbose"
invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
ifeq 25
21: new java.lang.StringBuilder
dup
ldc "Ignore disabled cipher suite: "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 3
getfield sun.security.ssl.CipherSuite.name:Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
iconst_0
anewarray java.lang.Object
22: invokestatic sun.security.ssl.SSLLogger.fine:(Ljava/lang/String;[Ljava/lang/Object;)V
23: goto 25
end local 6 24: StackMap locals: java.util.Collection java.util.List java.util.TreeSet sun.security.ssl.CipherSuite java.util.Iterator int top java.util.Iterator
StackMap stack:
aload 7
invokeinterface java.util.Iterator.hasNext:()Z
ifne 8
25: StackMap locals: java.util.Collection java.util.List java.util.TreeSet sun.security.ssl.CipherSuite java.util.Iterator int
StackMap stack:
iload 5
ifne 29
getstatic sun.security.ssl.SSLLogger.isOn:Z
ifeq 29
26: ldc "ssl,sslctx,verbose"
invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
ifeq 29
27: new java.lang.StringBuilder
dup
ldc "Ignore unsupported cipher suite: "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 3
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
iconst_0
anewarray java.lang.Object
28: invokestatic sun.security.ssl.SSLLogger.finest:(Ljava/lang/String;[Ljava/lang/Object;)V
end local 5 end local 3 29: StackMap locals: java.util.Collection java.util.List java.util.TreeSet top java.util.Iterator
StackMap stack:
aload 4
invokeinterface java.util.Iterator.hasNext:()Z
ifne 3
30: StackMap locals: java.util.Collection java.util.List java.util.TreeSet
StackMap stack:
new java.util.ArrayList
dup
aload 2
invokespecial java.util.ArrayList.<init>:(Ljava/util/Collection;)V
areturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 31 0 allowedCipherSuites Ljava/util/Collection<Lsun/security/ssl/CipherSuite;>;
0 31 1 protocols Ljava/util/List<Lsun/security/ssl/ProtocolVersion;>;
1 31 2 suites Ljava/util/TreeSet<Lsun/security/ssl/CipherSuite;>;
4 29 3 suite Lsun/security/ssl/CipherSuite;
7 29 5 isSupported Z
9 24 6 protocol Lsun/security/ssl/ProtocolVersion;
Signature: (Ljava/util/Collection<Lsun/security/ssl/CipherSuite;>;Ljava/util/List<Lsun/security/ssl/ProtocolVersion;>;)Ljava/util/List<Lsun/security/ssl/CipherSuite;>;
MethodParameters:
Name Flags
allowedCipherSuites
protocols
private static java.util.Collection<sun.security.ssl.CipherSuite> getCustomizedCipherSuites(java.lang.String);
descriptor: (Ljava/lang/String;)Ljava/util/Collection;
flags: (0x000a) ACC_PRIVATE, ACC_STATIC
Code:
stack=4, locals=6, args_size=1
start local 0 0: aload 0
invokestatic sun.security.action.GetPropertyAction.privilegedGetProperty:(Ljava/lang/String;)Ljava/lang/String;
astore 1
start local 1 1: getstatic sun.security.ssl.SSLLogger.isOn:Z
ifeq 6
ldc "ssl,sslctx"
invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
ifeq 6
2: new java.lang.StringBuilder
dup
ldc "System property "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 0
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
ldc " is set to '"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
3: aload 1
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
ldc "'"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
4: invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
iconst_0
anewarray java.lang.Object
5: invokestatic sun.security.ssl.SSLLogger.fine:(Ljava/lang/String;[Ljava/lang/Object;)V
6: StackMap locals: java.lang.String
StackMap stack:
aload 1
ifnull 10
aload 1
invokevirtual java.lang.String.isEmpty:()Z
ifne 10
7: aload 1
invokevirtual java.lang.String.length:()I
iconst_1
if_icmple 10
aload 1
iconst_0
invokevirtual java.lang.String.charAt:(I)C
bipush 34
if_icmpne 10
8: aload 1
aload 1
invokevirtual java.lang.String.length:()I
iconst_1
isub
invokevirtual java.lang.String.charAt:(I)C
bipush 34
if_icmpne 10
9: aload 1
iconst_1
aload 1
invokevirtual java.lang.String.length:()I
iconst_1
isub
invokevirtual java.lang.String.substring:(II)Ljava/lang/String;
astore 1
10: StackMap locals:
StackMap stack:
aload 1
ifnull 39
aload 1
invokevirtual java.lang.String.isEmpty:()Z
ifne 39
11: aload 1
ldc ","
invokevirtual java.lang.String.split:(Ljava/lang/String;)[Ljava/lang/String;
astore 2
start local 2 12: new java.util.ArrayList
dup
aload 2
arraylength
invokespecial java.util.ArrayList.<init>:(I)V
13: astore 3
start local 3 14: iconst_0
istore 4
start local 4 15: goto 37
16: StackMap locals: java.lang.String[] java.util.Collection int
StackMap stack:
aload 2
iload 4
aload 2
iload 4
aaload
invokevirtual java.lang.String.trim:()Ljava/lang/String;
aastore
17: aload 2
iload 4
aaload
invokevirtual java.lang.String.isEmpty:()Z
ifeq 19
18: goto 36
19: StackMap locals:
StackMap stack:
aload 2
iload 4
aaload
invokestatic sun.security.ssl.CipherSuite.nameOf:(Ljava/lang/String;)Lsun/security/ssl/CipherSuite;
astore 5
start local 5 20: goto 28
end local 5 StackMap locals:
StackMap stack: java.lang.IllegalArgumentException
21: pop
22: getstatic sun.security.ssl.SSLLogger.isOn:Z
ifeq 36
ldc "ssl,sslctx"
invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
ifeq 36
23: new java.lang.StringBuilder
dup
ldc "Unknown or unsupported cipher suite name: "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
24: aload 2
iload 4
aaload
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
25: invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
iconst_0
anewarray java.lang.Object
26: invokestatic sun.security.ssl.SSLLogger.fine:(Ljava/lang/String;[Ljava/lang/Object;)V
27: goto 36
start local 5 28: StackMap locals: sun.security.ssl.CipherSuite
StackMap stack:
aload 5
ifnull 31
aload 5
invokevirtual sun.security.ssl.CipherSuite.isAvailable:()Z
ifeq 31
29: aload 3
aload 5
invokeinterface java.util.Collection.add:(Ljava/lang/Object;)Z
pop
30: goto 36
31: StackMap locals:
StackMap stack:
getstatic sun.security.ssl.SSLLogger.isOn:Z
ifeq 36
ldc "ssl,sslctx"
invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
ifeq 36
32: new java.lang.StringBuilder
dup
ldc "The current installed providers do not support cipher suite: "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
33: aload 2
iload 4
aaload
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
34: invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
iconst_0
anewarray java.lang.Object
35: invokestatic sun.security.ssl.SSLLogger.fine:(Ljava/lang/String;[Ljava/lang/Object;)V
end local 5 36: StackMap locals:
StackMap stack:
iinc 4 1
StackMap locals:
StackMap stack:
37: iload 4
aload 2
arraylength
if_icmplt 16
end local 4 38: aload 3
areturn
end local 3 end local 2 39: StackMap locals:
StackMap stack:
invokestatic java.util.Collections.emptyList:()Ljava/util/List;
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 40 0 propertyName Ljava/lang/String;
1 40 1 property Ljava/lang/String;
12 39 2 cipherSuiteNames [Ljava/lang/String;
14 39 3 cipherSuites Ljava/util/Collection<Lsun/security/ssl/CipherSuite;>;
15 38 4 i I
20 21 5 suite Lsun/security/ssl/CipherSuite;
28 36 5 suite Lsun/security/ssl/CipherSuite;
Exception table:
from to target type
19 20 21 Class java.lang.IllegalArgumentException
Signature: (Ljava/lang/String;)Ljava/util/Collection<Lsun/security/ssl/CipherSuite;>;
MethodParameters:
Name Flags
propertyName
private static java.util.List<sun.security.ssl.ProtocolVersion> getAvailableProtocols(sun.security.ssl.ProtocolVersion[]);
descriptor: ([Lsun/security/ssl/ProtocolVersion;)Ljava/util/List;
flags: (0x000a) ACC_PRIVATE, ACC_STATIC
Code:
stack=3, locals=6, args_size=1
start local 0 0: invokestatic java.util.Collections.emptyList:()Ljava/util/List;
1: astore 1
start local 1 2: aload 0
ifnull 10
aload 0
arraylength
ifeq 10
3: new java.util.ArrayList
dup
aload 0
arraylength
invokespecial java.util.ArrayList.<init>:(I)V
astore 1
4: aload 0
dup
astore 5
arraylength
istore 4
iconst_0
istore 3
goto 9
StackMap locals: sun.security.ssl.ProtocolVersion[] java.util.List top int int sun.security.ssl.ProtocolVersion[]
StackMap stack:
5: aload 5
iload 3
aaload
astore 2
start local 2 6: aload 2
getfield sun.security.ssl.ProtocolVersion.isAvailable:Z
ifeq 8
7: aload 1
aload 2
invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
pop
end local 2 8: StackMap locals:
StackMap stack:
iinc 3 1
StackMap locals:
StackMap stack:
9: iload 3
iload 4
if_icmplt 5
10: StackMap locals: sun.security.ssl.ProtocolVersion[] java.util.List
StackMap stack:
aload 1
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 11 0 protocolCandidates [Lsun/security/ssl/ProtocolVersion;
2 11 1 availableProtocols Ljava/util/List<Lsun/security/ssl/ProtocolVersion;>;
6 8 2 p Lsun/security/ssl/ProtocolVersion;
Signature: ([Lsun/security/ssl/ProtocolVersion;)Ljava/util/List<Lsun/security/ssl/ProtocolVersion;>;
MethodParameters:
Name Flags
protocolCandidates
}
SourceFile: "SSLContextImpl.java"
NestMembers:
sun.security.ssl.SSLContextImpl$AbstractDTLSContext sun.security.ssl.SSLContextImpl$AbstractTLSContext sun.security.ssl.SSLContextImpl$CustomizedDTLSContext sun.security.ssl.SSLContextImpl$CustomizedSSLProtocols sun.security.ssl.SSLContextImpl$CustomizedTLSContext sun.security.ssl.SSLContextImpl$DTLS10Context sun.security.ssl.SSLContextImpl$DTLS12Context sun.security.ssl.SSLContextImpl$DTLSContext sun.security.ssl.SSLContextImpl$DefaultManagersHolder sun.security.ssl.SSLContextImpl$DefaultManagersHolder$1 sun.security.ssl.SSLContextImpl$DefaultManagersHolder$2 sun.security.ssl.SSLContextImpl$DefaultSSLContext sun.security.ssl.SSLContextImpl$DefaultSSLContextHolder sun.security.ssl.SSLContextImpl$TLS10Context sun.security.ssl.SSLContextImpl$TLS11Context sun.security.ssl.SSLContextImpl$TLS12Context sun.security.ssl.SSLContextImpl$TLS13Context sun.security.ssl.SSLContextImpl$TLSContext
InnerClasses:
Builder = sun.security.ssl.HelloCookieManager$Builder of sun.security.ssl.HelloCookieManager
private abstract AbstractDTLSContext = sun.security.ssl.SSLContextImpl$AbstractDTLSContext of sun.security.ssl.SSLContextImpl
private abstract AbstractTLSContext = sun.security.ssl.SSLContextImpl$AbstractTLSContext of sun.security.ssl.SSLContextImpl
private CustomizedDTLSContext = sun.security.ssl.SSLContextImpl$CustomizedDTLSContext of sun.security.ssl.SSLContextImpl
private CustomizedSSLProtocols = sun.security.ssl.SSLContextImpl$CustomizedSSLProtocols of sun.security.ssl.SSLContextImpl
private CustomizedTLSContext = sun.security.ssl.SSLContextImpl$CustomizedTLSContext of sun.security.ssl.SSLContextImpl
public final DTLS10Context = sun.security.ssl.SSLContextImpl$DTLS10Context of sun.security.ssl.SSLContextImpl
public final DTLS12Context = sun.security.ssl.SSLContextImpl$DTLS12Context of sun.security.ssl.SSLContextImpl
public final DTLSContext = sun.security.ssl.SSLContextImpl$DTLSContext of sun.security.ssl.SSLContextImpl
private final DefaultManagersHolder = sun.security.ssl.SSLContextImpl$DefaultManagersHolder of sun.security.ssl.SSLContextImpl
public final DefaultSSLContext = sun.security.ssl.SSLContextImpl$DefaultSSLContext of sun.security.ssl.SSLContextImpl
private final DefaultSSLContextHolder = sun.security.ssl.SSLContextImpl$DefaultSSLContextHolder of sun.security.ssl.SSLContextImpl
public final TLS10Context = sun.security.ssl.SSLContextImpl$TLS10Context of sun.security.ssl.SSLContextImpl
public final TLS11Context = sun.security.ssl.SSLContextImpl$TLS11Context of sun.security.ssl.SSLContextImpl
public final TLS12Context = sun.security.ssl.SSLContextImpl$TLS12Context of sun.security.ssl.SSLContextImpl
public final TLS13Context = sun.security.ssl.SSLContextImpl$TLS13Context of sun.security.ssl.SSLContextImpl
public final TLSContext = sun.security.ssl.SSLContextImpl$TLSContext of sun.security.ssl.SSLContextImpl