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 static final sun.security.ssl.Debug debug;
descriptor: Lsun/security/ssl/Debug;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
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 helloCookieManager;
descriptor: Lsun/security/ssl/HelloCookieManager;
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 "ssl"
invokestatic sun.security.ssl.Debug.getInstance:(Ljava/lang/String;)Lsun/security/ssl/Debug;
putstatic sun.security.ssl.SSLContextImpl.debug:Lsun/security/ssl/Debug;
1: ldc "jdk.tls.client.cipherSuites"
invokestatic sun.security.ssl.SSLContextImpl.getCustomizedCipherSuites:(Ljava/lang/String;)Ljava/util/Collection;
2: putstatic sun.security.ssl.SSLContextImpl.clientCustomizedCipherSuites:Ljava/util/Collection;
3: ldc "jdk.tls.server.cipherSuites"
invokestatic sun.security.ssl.SSLContextImpl.getCustomizedCipherSuites:(Ljava/lang/String;)Ljava/util/Collection;
4: putstatic sun.security.ssl.SSLContextImpl.serverCustomizedCipherSuites:Ljava/util/Collection;
5: 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.Debug.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.Debug.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.SSLContextImpl.debug:Lsun/security/ssl/Debug;
ifnull 23
ldc "sslctx"
invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
ifeq 23
22: getstatic java.lang.System.out:Ljava/io/PrintStream;
ldc "trigger seeding of SecureRandom"
invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)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.SSLContextImpl.debug:Lsun/security/ssl/Debug;
ifnull 26
ldc "sslctx"
invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
ifeq 26
25: getstatic java.lang.System.out:Ljava/io/PrintStream;
ldc "done seeding SecureRandom"
invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)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 20
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 19
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.SSLContextImpl.debug:Lsun/security/ssl/Debug;
ifnull 18
ldc "sslctx"
invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
ifeq 18
15: getstatic java.lang.System.out:Ljava/io/PrintStream;
16: ldc "X509KeyManager passed to SSLContext.init(): need an X509ExtendedKeyManager for SSLEngine use"
17: invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
18: 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 19: StackMap locals:
StackMap stack:
iinc 2 1
StackMap locals:
StackMap stack:
20: aload 1
ifnull 21
iload 2
aload 1
arraylength
if_icmplt 2
end local 2 21: 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 22 0 this Lsun/security/ssl/SSLContextImpl;
0 22 1 kms [Ljavax/net/ssl/KeyManager;
1 21 2 i I
3 19 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:
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 3 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:
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 3 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();
descriptor: ()Lsun/security/ssl/HelloCookieManager;
flags: (0x0000)
Code:
stack=3, locals=2, 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
getfield sun.security.ssl.SSLContextImpl.helloCookieManager:Lsun/security/ssl/HelloCookieManager;
ifnull 4
3: aload 0
getfield sun.security.ssl.SSLContextImpl.helloCookieManager:Lsun/security/ssl/HelloCookieManager;
areturn
4: StackMap locals:
StackMap stack:
aload 0
dup
astore 1
monitorenter
5: aload 0
getfield sun.security.ssl.SSLContextImpl.helloCookieManager:Lsun/security/ssl/HelloCookieManager;
ifnonnull 7
6: aload 0
aload 0
aload 0
getfield sun.security.ssl.SSLContextImpl.secureRandom:Ljava/security/SecureRandom;
invokevirtual sun.security.ssl.SSLContextImpl.getHelloCookieManager:(Ljava/security/SecureRandom;)Lsun/security/ssl/HelloCookieManager;
putfield sun.security.ssl.SSLContextImpl.helloCookieManager:Lsun/security/ssl/HelloCookieManager;
7: StackMap locals: sun.security.ssl.SSLContextImpl
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.helloCookieManager:Lsun/security/ssl/HelloCookieManager;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 12 0 this Lsun/security/ssl/SSLContextImpl;
Exception table:
from to target type
5 8 9 any
9 10 9 any
sun.security.ssl.HelloCookieManager getHelloCookieManager(java.security.SecureRandom);
descriptor: (Ljava/security/SecureRandom;)Lsun/security/ssl/HelloCookieManager;
flags: (0x0000)
Code:
stack=3, locals=2, args_size=2
start local 0 start local 1 0: new java.lang.UnsupportedOperationException
dup
1: ldc "Cookie exchange applies to DTLS only"
2: invokespecial java.lang.UnsupportedOperationException.<init>:(Ljava/lang/String;)V
athrow
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lsun/security/ssl/SSLContextImpl;
0 3 1 secureRandom Ljava/security/SecureRandom;
MethodParameters:
Name Flags
secureRandom
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 12
aload 0
getfield sun.security.ssl.SSLContextImpl.statusResponseManager:Lsun/security/ssl/StatusResponseManager;
ifnonnull 12
1: aload 0
dup
astore 1
monitorenter
2: aload 0
getfield sun.security.ssl.SSLContextImpl.statusResponseManager:Lsun/security/ssl/StatusResponseManager;
ifnonnull 8
3: getstatic sun.security.ssl.SSLContextImpl.debug:Lsun/security/ssl/Debug;
ifnull 7
ldc "sslctx"
invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
ifeq 7
4: getstatic java.lang.System.out:Ljava/io/PrintStream;
5: ldc "Initializing StatusResponseManager"
6: invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
7: 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;
8: StackMap locals:
StackMap stack:
aload 1
monitorexit
9: goto 12
StackMap locals:
StackMap stack: java.lang.Throwable
10: aload 1
monitorexit
11: athrow
12: 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 13 0 this Lsun/security/ssl/SSLContextImpl;
Exception table:
from to target type
2 9 10 any
10 11 10 any
abstract sun.security.ssl.ProtocolList getSuportedProtocolList();
descriptor: ()Lsun/security/ssl/ProtocolList;
flags: (0x0400) ACC_ABSTRACT
abstract sun.security.ssl.ProtocolList getServerDefaultProtocolList();
descriptor: ()Lsun/security/ssl/ProtocolList;
flags: (0x0400) ACC_ABSTRACT
abstract sun.security.ssl.ProtocolList getClientDefaultProtocolList();
descriptor: ()Lsun/security/ssl/ProtocolList;
flags: (0x0400) ACC_ABSTRACT
abstract sun.security.ssl.CipherSuiteList getSupportedCipherSuiteList();
descriptor: ()Lsun/security/ssl/CipherSuiteList;
flags: (0x0400) ACC_ABSTRACT
abstract sun.security.ssl.CipherSuiteList getServerDefaultCipherSuiteList();
descriptor: ()Lsun/security/ssl/CipherSuiteList;
flags: (0x0400) ACC_ABSTRACT
abstract sun.security.ssl.CipherSuiteList getClientDefaultCipherSuiteList();
descriptor: ()Lsun/security/ssl/CipherSuiteList;
flags: (0x0400) ACC_ABSTRACT
sun.security.ssl.ProtocolList getDefaultProtocolList(boolean);
descriptor: (Z)Lsun/security/ssl/ProtocolList;
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.getServerDefaultProtocolList:()Lsun/security/ssl/ProtocolList;
goto 2
1: StackMap locals:
StackMap stack:
aload 0
invokevirtual sun.security.ssl.SSLContextImpl.getClientDefaultProtocolList:()Lsun/security/ssl/ProtocolList;
2: StackMap locals:
StackMap stack: sun.security.ssl.ProtocolList
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
MethodParameters:
Name Flags
roleIsServer
sun.security.ssl.CipherSuiteList getDefaultCipherSuiteList(boolean);
descriptor: (Z)Lsun/security/ssl/CipherSuiteList;
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.getServerDefaultCipherSuiteList:()Lsun/security/ssl/CipherSuiteList;
goto 2
1: StackMap locals:
StackMap stack:
aload 0
invokevirtual sun.security.ssl.SSLContextImpl.getClientDefaultCipherSuiteList:()Lsun/security/ssl/CipherSuiteList;
2: StackMap locals:
StackMap stack: sun.security.ssl.CipherSuiteList
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
MethodParameters:
Name Flags
roleIsServer
boolean isDefaultProtocolList(sun.security.ssl.ProtocolList);
descriptor: (Lsun/security/ssl/ProtocolList;)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.getServerDefaultProtocolList:()Lsun/security/ssl/ProtocolList;
if_acmpeq 3
1: aload 1
aload 0
invokevirtual sun.security.ssl.SSLContextImpl.getClientDefaultProtocolList:()Lsun/security/ssl/ProtocolList;
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 Lsun/security/ssl/ProtocolList;
MethodParameters:
Name Flags
protocols
boolean isDefaultCipherSuiteList(sun.security.ssl.CipherSuiteList);
descriptor: (Lsun/security/ssl/CipherSuiteList;)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.getServerDefaultCipherSuiteList:()Lsun/security/ssl/CipherSuiteList;
if_acmpeq 3
1: aload 1
aload 0
invokevirtual sun.security.ssl.SSLContextImpl.getClientDefaultCipherSuiteList:()Lsun/security/ssl/CipherSuiteList;
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 Lsun/security/ssl/CipherSuiteList;
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 sun.security.ssl.CipherSuiteList getApplicableSupportedCipherSuiteList(sun.security.ssl.ProtocolList);
descriptor: (Lsun/security/ssl/ProtocolList;)Lsun/security/ssl/CipherSuiteList;
flags: (0x000a) ACC_PRIVATE, ACC_STATIC
Code:
stack=3, locals=1, args_size=1
start local 0 0: invokestatic sun.security.ssl.CipherSuite.allowedCipherSuites:()Ljava/util/Collection;
1: aload 0
iconst_1
2: invokestatic sun.security.ssl.SSLContextImpl.getApplicableCipherSuiteList:(Ljava/util/Collection;Lsun/security/ssl/ProtocolList;I)Lsun/security/ssl/CipherSuiteList;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 protocols Lsun/security/ssl/ProtocolList;
MethodParameters:
Name Flags
protocols
private static sun.security.ssl.CipherSuiteList getApplicableEnabledCipherSuiteList(sun.security.ssl.ProtocolList, boolean);
descriptor: (Lsun/security/ssl/ProtocolList;Z)Lsun/security/ssl/CipherSuiteList;
flags: (0x000a) ACC_PRIVATE, ACC_STATIC
Code:
stack=3, locals=2, args_size=2
start local 0 start local 1 0: iload 1
ifeq 5
1: getstatic sun.security.ssl.SSLContextImpl.clientCustomizedCipherSuites:Ljava/util/Collection;
invokeinterface java.util.Collection.isEmpty:()Z
ifne 9
2: getstatic sun.security.ssl.SSLContextImpl.clientCustomizedCipherSuites:Ljava/util/Collection;
3: aload 0
iconst_1
4: invokestatic sun.security.ssl.SSLContextImpl.getApplicableCipherSuiteList:(Ljava/util/Collection;Lsun/security/ssl/ProtocolList;I)Lsun/security/ssl/CipherSuiteList;
areturn
5: StackMap locals:
StackMap stack:
getstatic sun.security.ssl.SSLContextImpl.serverCustomizedCipherSuites:Ljava/util/Collection;
invokeinterface java.util.Collection.isEmpty:()Z
ifne 9
6: getstatic sun.security.ssl.SSLContextImpl.serverCustomizedCipherSuites:Ljava/util/Collection;
7: aload 0
iconst_1
8: invokestatic sun.security.ssl.SSLContextImpl.getApplicableCipherSuiteList:(Ljava/util/Collection;Lsun/security/ssl/ProtocolList;I)Lsun/security/ssl/CipherSuiteList;
areturn
9: StackMap locals:
StackMap stack:
invokestatic sun.security.ssl.CipherSuite.allowedCipherSuites:()Ljava/util/Collection;
10: aload 0
sipush 300
11: invokestatic sun.security.ssl.SSLContextImpl.getApplicableCipherSuiteList:(Ljava/util/Collection;Lsun/security/ssl/ProtocolList;I)Lsun/security/ssl/CipherSuiteList;
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 12 0 protocols Lsun/security/ssl/ProtocolList;
0 12 1 isClient Z
MethodParameters:
Name Flags
protocols
isClient
private static sun.security.ssl.CipherSuiteList getApplicableCipherSuiteList(java.util.Collection<sun.security.ssl.CipherSuite>, sun.security.ssl.ProtocolList, int);
descriptor: (Ljava/util/Collection;Lsun/security/ssl/ProtocolList;I)Lsun/security/ssl/CipherSuiteList;
flags: (0x000a) ACC_PRIVATE, ACC_STATIC
Code:
stack=4, locals=6, args_size=3
start local 0 start local 1 start local 2 0: new java.util.TreeSet
dup
invokespecial java.util.TreeSet.<init>:()V
astore 3
start local 3 1: aload 1
invokevirtual sun.security.ssl.ProtocolList.collection:()Ljava/util/Collection;
invokeinterface java.util.Collection.isEmpty:()Z
ifne 41
2: aload 1
getfield sun.security.ssl.ProtocolList.min:Lsun/security/ssl/ProtocolVersion;
getfield sun.security.ssl.ProtocolVersion.v:I
getstatic sun.security.ssl.ProtocolVersion.NONE:Lsun/security/ssl/ProtocolVersion;
getfield sun.security.ssl.ProtocolVersion.v:I
if_icmpeq 41
3: aload 0
invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
astore 5
goto 40
StackMap locals: java.util.Collection sun.security.ssl.ProtocolList int java.util.TreeSet top java.util.Iterator
StackMap stack:
4: aload 5
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast sun.security.ssl.CipherSuite
astore 4
start local 4 5: aload 4
getfield sun.security.ssl.CipherSuite.allowed:Z
ifeq 40
aload 4
getfield sun.security.ssl.CipherSuite.priority:I
iload 2
if_icmpge 7
6: goto 40
7: StackMap locals: java.util.Collection sun.security.ssl.ProtocolList int java.util.TreeSet sun.security.ssl.CipherSuite java.util.Iterator
StackMap stack:
aload 4
invokevirtual sun.security.ssl.CipherSuite.isAvailable:()Z
ifeq 25
8: aload 1
getfield sun.security.ssl.ProtocolList.min:Lsun/security/ssl/ProtocolVersion;
aload 4
invokevirtual sun.security.ssl.ProtocolVersion.obsoletes:(Lsun/security/ssl/CipherSuite;)Z
ifne 25
9: aload 1
getfield sun.security.ssl.ProtocolList.max:Lsun/security/ssl/ProtocolVersion;
aload 4
invokevirtual sun.security.ssl.ProtocolVersion.supports:(Lsun/security/ssl/CipherSuite;)Z
ifeq 25
10: getstatic sun.security.ssl.SSLAlgorithmConstraints.DEFAULT:Ljava/security/AlgorithmConstraints;
11: getstatic java.security.CryptoPrimitive.KEY_AGREEMENT:Ljava/security/CryptoPrimitive;
invokestatic java.util.EnumSet.of:(Ljava/lang/Enum;)Ljava/util/EnumSet;
12: aload 4
getfield sun.security.ssl.CipherSuite.name:Ljava/lang/String;
aconst_null
13: invokeinterface java.security.AlgorithmConstraints.permits:(Ljava/util/Set;Ljava/lang/String;Ljava/security/AlgorithmParameters;)Z
14: ifeq 17
15: aload 3
aload 4
invokevirtual java.util.TreeSet.add:(Ljava/lang/Object;)Z
pop
16: goto 40
17: StackMap locals:
StackMap stack:
getstatic sun.security.ssl.SSLContextImpl.debug:Lsun/security/ssl/Debug;
ifnull 40
ldc "sslctx"
invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
ifeq 40
18: ldc "verbose"
invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
ifeq 40
19: getstatic java.lang.System.out:Ljava/io/PrintStream;
20: new java.lang.StringBuilder
dup
ldc "Ignoring disabled cipher suite: "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
21: aload 4
getfield sun.security.ssl.CipherSuite.name:Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
22: invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
23: invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
24: goto 40
StackMap locals:
StackMap stack:
25: getstatic sun.security.ssl.SSLContextImpl.debug:Lsun/security/ssl/Debug;
ifnull 40
26: ldc "sslctx"
invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
ifeq 40
ldc "verbose"
invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
ifeq 40
27: aload 1
getfield sun.security.ssl.ProtocolList.min:Lsun/security/ssl/ProtocolVersion;
aload 4
invokevirtual sun.security.ssl.ProtocolVersion.obsoletes:(Lsun/security/ssl/CipherSuite;)Z
ifeq 32
28: getstatic java.lang.System.out:Ljava/io/PrintStream;
29: new java.lang.StringBuilder
dup
ldc "Ignoring obsoleted cipher suite: "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 4
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
30: invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
31: goto 40
StackMap locals:
StackMap stack:
32: aload 1
getfield sun.security.ssl.ProtocolList.max:Lsun/security/ssl/ProtocolVersion;
aload 4
invokevirtual sun.security.ssl.ProtocolVersion.supports:(Lsun/security/ssl/CipherSuite;)Z
ifne 37
33: getstatic java.lang.System.out:Ljava/io/PrintStream;
34: new java.lang.StringBuilder
dup
ldc "Ignoring unsupported cipher suite: "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 4
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
35: invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
36: goto 40
37: StackMap locals:
StackMap stack:
getstatic java.lang.System.out:Ljava/io/PrintStream;
38: new java.lang.StringBuilder
dup
ldc "Ignoring unavailable cipher suite: "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 4
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
39: invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
end local 4 40: StackMap locals: java.util.Collection sun.security.ssl.ProtocolList int java.util.TreeSet top java.util.Iterator
StackMap stack:
aload 5
invokeinterface java.util.Iterator.hasNext:()Z
ifne 4
41: StackMap locals: java.util.Collection sun.security.ssl.ProtocolList int java.util.TreeSet
StackMap stack:
new sun.security.ssl.CipherSuiteList
dup
aload 3
invokespecial sun.security.ssl.CipherSuiteList.<init>:(Ljava/util/Collection;)V
areturn
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 42 0 allowedCipherSuites Ljava/util/Collection<Lsun/security/ssl/CipherSuite;>;
0 42 1 protocols Lsun/security/ssl/ProtocolList;
0 42 2 minPriority I
1 42 3 suites Ljava/util/TreeSet<Lsun/security/ssl/CipherSuite;>;
5 40 4 suite Lsun/security/ssl/CipherSuite;
Signature: (Ljava/util/Collection<Lsun/security/ssl/CipherSuite;>;Lsun/security/ssl/ProtocolList;I)Lsun/security/ssl/CipherSuiteList;
MethodParameters:
Name Flags
allowedCipherSuites
protocols
minPriority
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.SSLContextImpl.debug:Lsun/security/ssl/Debug;
ifnull 7
ldc "sslctx"
invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
ifeq 7
2: getstatic java.lang.System.out:Ljava/io/PrintStream;
3: 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;
4: 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;
5: invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
6: invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
7: StackMap locals: java.lang.String
StackMap stack:
aload 1
ifnull 11
aload 1
invokevirtual java.lang.String.length:()I
ifeq 11
8: aload 1
invokevirtual java.lang.String.length:()I
iconst_1
if_icmple 11
aload 1
iconst_0
invokevirtual java.lang.String.charAt:(I)C
bipush 34
if_icmpne 11
9: aload 1
aload 1
invokevirtual java.lang.String.length:()I
iconst_1
isub
invokevirtual java.lang.String.charAt:(I)C
bipush 34
if_icmpne 11
10: 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
11: StackMap locals:
StackMap stack:
aload 1
ifnull 42
aload 1
invokevirtual java.lang.String.length:()I
ifeq 42
12: aload 1
ldc ","
invokevirtual java.lang.String.split:(Ljava/lang/String;)[Ljava/lang/String;
astore 2
start local 2 13: new java.util.ArrayList
dup
aload 2
arraylength
invokespecial java.util.ArrayList.<init>:(I)V
14: astore 3
start local 3 15: iconst_0
istore 4
start local 4 16: goto 40
17: 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
18: aload 2
iload 4
aaload
invokevirtual java.lang.String.isEmpty:()Z
ifeq 20
19: goto 39
20: StackMap locals:
StackMap stack:
aload 2
iload 4
aaload
invokestatic sun.security.ssl.CipherSuite.valueOf:(Ljava/lang/String;)Lsun/security/ssl/CipherSuite;
astore 5
start local 5 21: goto 30
end local 5 StackMap locals:
StackMap stack: java.lang.IllegalArgumentException
22: pop
23: getstatic sun.security.ssl.SSLContextImpl.debug:Lsun/security/ssl/Debug;
ifnull 39
ldc "sslctx"
invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
ifeq 39
24: getstatic java.lang.System.out:Ljava/io/PrintStream;
25: new java.lang.StringBuilder
dup
ldc "Unknown or unsupported cipher suite name: "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
26: aload 2
iload 4
aaload
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
27: invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
28: invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
29: goto 39
start local 5 30: StackMap locals: sun.security.ssl.CipherSuite
StackMap stack:
aload 5
invokevirtual sun.security.ssl.CipherSuite.isAvailable:()Z
ifeq 33
31: aload 3
aload 5
invokeinterface java.util.Collection.add:(Ljava/lang/Object;)Z
pop
32: goto 39
33: StackMap locals:
StackMap stack:
getstatic sun.security.ssl.SSLContextImpl.debug:Lsun/security/ssl/Debug;
ifnull 39
ldc "sslctx"
invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
ifeq 39
34: getstatic java.lang.System.out:Ljava/io/PrintStream;
35: new java.lang.StringBuilder
dup
ldc "The current installed providers do not support cipher suite: "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
36: aload 2
iload 4
aaload
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
37: invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
38: invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
end local 5 39: StackMap locals:
StackMap stack:
iinc 4 1
StackMap locals:
StackMap stack:
40: iload 4
aload 2
arraylength
if_icmplt 17
end local 4 41: aload 3
areturn
end local 3 end local 2 42: 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 43 0 propertyName Ljava/lang/String;
1 43 1 property Ljava/lang/String;
13 42 2 cipherSuiteNames [Ljava/lang/String;
15 42 3 cipherSuites Ljava/util/Collection<Lsun/security/ssl/CipherSuite;>;
16 41 4 i I
21 22 5 suite Lsun/security/ssl/CipherSuite;
30 39 5 suite Lsun/security/ssl/CipherSuite;
Exception table:
from to target type
20 21 22 Class java.lang.IllegalArgumentException
Signature: (Ljava/lang/String;)Ljava/util/Collection<Lsun/security/ssl/CipherSuite;>;
MethodParameters:
Name Flags
propertyName
private static java.lang.String[] getAvailableProtocols(sun.security.ssl.ProtocolVersion[]);
descriptor: ([Lsun/security/ssl/ProtocolVersion;)[Ljava/lang/String;
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;
astore 1
start local 1 1: aload 0
ifnull 9
aload 0
arraylength
ifeq 9
2: new java.util.ArrayList
dup
aload 0
arraylength
invokespecial java.util.ArrayList.<init>:(I)V
astore 1
3: aload 0
dup
astore 5
arraylength
istore 4
iconst_0
istore 3
goto 8
StackMap locals: sun.security.ssl.ProtocolVersion[] java.util.List top int int sun.security.ssl.ProtocolVersion[]
StackMap stack:
4: aload 5
iload 3
aaload
astore 2
start local 2 5: getstatic sun.security.ssl.ProtocolVersion.availableProtocols:Ljava/util/Set;
aload 2
invokeinterface java.util.Set.contains:(Ljava/lang/Object;)Z
ifeq 7
6: aload 1
aload 2
getfield sun.security.ssl.ProtocolVersion.name:Ljava/lang/String;
invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
pop
end local 2 7: StackMap locals:
StackMap stack:
iinc 3 1
StackMap locals:
StackMap stack:
8: iload 3
iload 4
if_icmplt 4
9: StackMap locals: sun.security.ssl.ProtocolVersion[] java.util.List
StackMap stack:
aload 1
iconst_0
anewarray java.lang.String
invokeinterface java.util.List.toArray:([Ljava/lang/Object;)[Ljava/lang/Object;
checkcast java.lang.String[]
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 10 0 protocolCandidates [Lsun/security/ssl/ProtocolVersion;
1 10 1 availableProtocols Ljava/util/List<Ljava/lang/String;>;
5 7 2 p 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$TLSContext
InnerClasses:
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 TLSContext = sun.security.ssl.SSLContextImpl$TLSContext of sun.security.ssl.SSLContextImpl