abstract class sun.security.ssl.Handshaker
minor version: 0
major version: 59
flags: flags: (0x0420) ACC_SUPER, ACC_ABSTRACT
this_class: sun.security.ssl.Handshaker
super_class: java.lang.Object
{
sun.security.ssl.ProtocolVersion protocolVersion;
descriptor: Lsun/security/ssl/ProtocolVersion;
flags: (0x0000)
sun.security.ssl.ProtocolVersion activeProtocolVersion;
descriptor: Lsun/security/ssl/ProtocolVersion;
flags: (0x0000)
boolean secureRenegotiation;
descriptor: Z
flags: (0x0000)
byte[] clientVerifyData;
descriptor: [B
flags: (0x0000)
byte[] serverVerifyData;
descriptor: [B
flags: (0x0000)
boolean isInitialHandshake;
descriptor: Z
flags: (0x0000)
private sun.security.ssl.ProtocolList enabledProtocols;
descriptor: Lsun/security/ssl/ProtocolList;
flags: (0x0002) ACC_PRIVATE
private sun.security.ssl.CipherSuiteList enabledCipherSuites;
descriptor: Lsun/security/ssl/CipherSuiteList;
flags: (0x0002) ACC_PRIVATE
java.lang.String identificationProtocol;
descriptor: Ljava/lang/String;
flags: (0x0000)
java.security.AlgorithmConstraints algorithmConstraints;
descriptor: Ljava/security/AlgorithmConstraints;
flags: (0x0000)
private java.util.Collection<sun.security.ssl.SignatureAndHashAlgorithm> localSupportedSignAlgs;
descriptor: Ljava/util/Collection;
flags: (0x0002) ACC_PRIVATE
Signature: Ljava/util/Collection<Lsun/security/ssl/SignatureAndHashAlgorithm;>;
java.util.Collection<sun.security.ssl.SignatureAndHashAlgorithm> peerSupportedSignAlgs;
descriptor: Ljava/util/Collection;
flags: (0x0000)
Signature: Ljava/util/Collection<Lsun/security/ssl/SignatureAndHashAlgorithm;>;
private sun.security.ssl.ProtocolList activeProtocols;
descriptor: Lsun/security/ssl/ProtocolList;
flags: (0x0002) ACC_PRIVATE
private sun.security.ssl.CipherSuiteList activeCipherSuites;
descriptor: Lsun/security/ssl/CipherSuiteList;
flags: (0x0002) ACC_PRIVATE
java.util.List<javax.net.ssl.SNIServerName> serverNames;
descriptor: Ljava/util/List;
flags: (0x0000)
Signature: Ljava/util/List<Ljavax/net/ssl/SNIServerName;>;
java.util.Collection<javax.net.ssl.SNIMatcher> sniMatchers;
descriptor: Ljava/util/Collection;
flags: (0x0000)
Signature: Ljava/util/Collection<Ljavax/net/ssl/SNIMatcher;>;
java.lang.String[] localApl;
descriptor: [Ljava/lang/String;
flags: (0x0000)
java.lang.String applicationProtocol;
descriptor: Ljava/lang/String;
flags: (0x0000)
java.util.function.BiFunction<javax.net.ssl.SSLEngine, java.util.List<java.lang.String>, java.lang.String> appProtocolSelectorSSLEngine;
descriptor: Ljava/util/function/BiFunction;
flags: (0x0000)
Signature: Ljava/util/function/BiFunction<Ljavax/net/ssl/SSLEngine;Ljava/util/List<Ljava/lang/String;>;Ljava/lang/String;>;
java.util.function.BiFunction<javax.net.ssl.SSLSocket, java.util.List<java.lang.String>, java.lang.String> appProtocolSelectorSSLSocket;
descriptor: Ljava/util/function/BiFunction;
flags: (0x0000)
Signature: Ljava/util/function/BiFunction<Ljavax/net/ssl/SSLSocket;Ljava/util/List<Ljava/lang/String;>;Ljava/lang/String;>;
int maximumPacketSize;
descriptor: I
flags: (0x0000)
private boolean isClient;
descriptor: Z
flags: (0x0002) ACC_PRIVATE
private boolean needCertVerify;
descriptor: Z
flags: (0x0002) ACC_PRIVATE
sun.security.ssl.SSLSocketImpl conn;
descriptor: Lsun/security/ssl/SSLSocketImpl;
flags: (0x0000)
sun.security.ssl.SSLEngineImpl engine;
descriptor: Lsun/security/ssl/SSLEngineImpl;
flags: (0x0000)
sun.security.ssl.HandshakeHash handshakeHash;
descriptor: Lsun/security/ssl/HandshakeHash;
flags: (0x0000)
sun.security.ssl.HandshakeInStream input;
descriptor: Lsun/security/ssl/HandshakeInStream;
flags: (0x0000)
sun.security.ssl.HandshakeOutStream output;
descriptor: Lsun/security/ssl/HandshakeOutStream;
flags: (0x0000)
sun.security.ssl.SSLContextImpl sslContext;
descriptor: Lsun/security/ssl/SSLContextImpl;
flags: (0x0000)
sun.security.ssl.RandomCookie clnt_random;
descriptor: Lsun/security/ssl/RandomCookie;
flags: (0x0000)
sun.security.ssl.RandomCookie svr_random;
descriptor: Lsun/security/ssl/RandomCookie;
flags: (0x0000)
sun.security.ssl.SSLSessionImpl session;
descriptor: Lsun/security/ssl/SSLSessionImpl;
flags: (0x0000)
sun.security.ssl.HandshakeStateManager handshakeState;
descriptor: Lsun/security/ssl/HandshakeStateManager;
flags: (0x0000)
boolean clientHelloDelivered;
descriptor: Z
flags: (0x0000)
boolean serverHelloRequested;
descriptor: Z
flags: (0x0000)
boolean handshakeActivated;
descriptor: Z
flags: (0x0000)
boolean handshakeFinished;
descriptor: Z
flags: (0x0000)
sun.security.ssl.CipherSuite cipherSuite;
descriptor: Lsun/security/ssl/CipherSuite;
flags: (0x0000)
sun.security.ssl.CipherSuite$KeyExchange keyExchange;
descriptor: Lsun/security/ssl/CipherSuite$KeyExchange;
flags: (0x0000)
boolean resumingSession;
descriptor: Z
flags: (0x0000)
boolean enableNewSession;
descriptor: Z
flags: (0x0000)
boolean preferLocalCipherSuites;
descriptor: Z
flags: (0x0000)
private javax.crypto.SecretKey clntWriteKey;
descriptor: Ljavax/crypto/SecretKey;
flags: (0x0002) ACC_PRIVATE
private javax.crypto.SecretKey svrWriteKey;
descriptor: Ljavax/crypto/SecretKey;
flags: (0x0002) ACC_PRIVATE
private javax.crypto.spec.IvParameterSpec clntWriteIV;
descriptor: Ljavax/crypto/spec/IvParameterSpec;
flags: (0x0002) ACC_PRIVATE
private javax.crypto.spec.IvParameterSpec svrWriteIV;
descriptor: Ljavax/crypto/spec/IvParameterSpec;
flags: (0x0002) ACC_PRIVATE
private javax.crypto.SecretKey clntMacSecret;
descriptor: Ljavax/crypto/SecretKey;
flags: (0x0002) ACC_PRIVATE
private javax.crypto.SecretKey svrMacSecret;
descriptor: Ljavax/crypto/SecretKey;
flags: (0x0002) ACC_PRIVATE
private volatile boolean taskDelegated;
descriptor: Z
flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE
private volatile sun.security.ssl.Handshaker$DelegatedTask<?> delegatedTask;
descriptor: Lsun/security/ssl/Handshaker$DelegatedTask;
flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE
Signature: Lsun/security/ssl/Handshaker$DelegatedTask<*>;
private volatile java.lang.Exception thrown;
descriptor: Ljava/lang/Exception;
flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE
private java.lang.Object thrownLock;
descriptor: Ljava/lang/Object;
flags: (0x0002) ACC_PRIVATE
static final sun.security.ssl.Debug debug;
descriptor: Lsun/security/ssl/Debug;
flags: (0x0018) ACC_STATIC, ACC_FINAL
static final boolean allowUnsafeRenegotiation;
descriptor: Z
flags: (0x0018) ACC_STATIC, ACC_FINAL
static final boolean allowLegacyHelloMessages;
descriptor: Z
flags: (0x0018) ACC_STATIC, ACC_FINAL
static final boolean rejectClientInitiatedRenego;
descriptor: Z
flags: (0x0018) ACC_STATIC, ACC_FINAL
static final boolean useExtendedMasterSecret;
descriptor: Z
flags: (0x0018) ACC_STATIC, ACC_FINAL
static final boolean allowLegacyResumption;
descriptor: Z
flags: (0x0018) ACC_STATIC, ACC_FINAL
static final boolean allowLegacyMasterSecret;
descriptor: Z
flags: (0x0018) ACC_STATIC, ACC_FINAL
boolean requestedToUseEMS;
descriptor: Z
flags: (0x0000)
boolean invalidated;
descriptor: Z
flags: (0x0000)
final boolean isDTLS;
descriptor: Z
flags: (0x0010) ACC_FINAL
static void <clinit>();
descriptor: ()V
flags: (0x0008) ACC_STATIC
Code:
stack=2, locals=1, args_size=0
0: ldc "ssl"
invokestatic sun.security.ssl.Debug.getInstance:(Ljava/lang/String;)Lsun/security/ssl/Debug;
putstatic sun.security.ssl.Handshaker.debug:Lsun/security/ssl/Debug;
1: ldc "sun.security.ssl.allowUnsafeRenegotiation"
iconst_0
2: invokestatic sun.security.ssl.Debug.getBooleanProperty:(Ljava/lang/String;Z)Z
putstatic sun.security.ssl.Handshaker.allowUnsafeRenegotiation:Z
3: ldc "sun.security.ssl.allowLegacyHelloMessages"
iconst_1
4: invokestatic sun.security.ssl.Debug.getBooleanProperty:(Ljava/lang/String;Z)Z
putstatic sun.security.ssl.Handshaker.allowLegacyHelloMessages:Z
5: ldc "jdk.tls.rejectClientInitiatedRenegotiation"
iconst_0
6: invokestatic sun.security.ssl.Debug.getBooleanProperty:(Ljava/lang/String;Z)Z
7: putstatic sun.security.ssl.Handshaker.rejectClientInitiatedRenego:Z
8: ldc "jdk.tls.allowLegacyResumption"
iconst_1
invokestatic sun.security.ssl.Debug.getBooleanProperty:(Ljava/lang/String;Z)Z
9: putstatic sun.security.ssl.Handshaker.allowLegacyResumption:Z
10: ldc "jdk.tls.allowLegacyMasterSecret"
iconst_1
invokestatic sun.security.ssl.Debug.getBooleanProperty:(Ljava/lang/String;Z)Z
11: putstatic sun.security.ssl.Handshaker.allowLegacyMasterSecret:Z
12: iconst_1
istore 0
start local 0 13: ldc "SunTlsExtendedMasterSecret"
invokestatic sun.security.ssl.JsseJce.getKeyGenerator:(Ljava/lang/String;)Ljavax/crypto/KeyGenerator;
pop
14: goto 17
StackMap locals: int
StackMap stack: java.security.NoSuchAlgorithmException
15: pop
16: iconst_0
istore 0
17: StackMap locals:
StackMap stack:
iload 0
ifeq 21
18: ldc "jdk.tls.useExtendedMasterSecret"
iconst_1
19: invokestatic sun.security.ssl.Debug.getBooleanProperty:(Ljava/lang/String;Z)Z
putstatic sun.security.ssl.Handshaker.useExtendedMasterSecret:Z
20: goto 22
21: StackMap locals:
StackMap stack:
iconst_0
putstatic sun.security.ssl.Handshaker.useExtendedMasterSecret:Z
end local 0 22: StackMap locals:
StackMap stack:
return
LocalVariableTable:
Start End Slot Name Signature
13 22 0 supportExtendedMasterSecret Z
Exception table:
from to target type
13 14 15 Class java.security.NoSuchAlgorithmException
void <init>(sun.security.ssl.SSLSocketImpl, sun.security.ssl.SSLContextImpl, sun.security.ssl.ProtocolList, boolean, boolean, sun.security.ssl.ProtocolVersion, boolean, boolean, byte[], byte[]);
descriptor: (Lsun/security/ssl/SSLSocketImpl;Lsun/security/ssl/SSLContextImpl;Lsun/security/ssl/ProtocolList;ZZLsun/security/ssl/ProtocolVersion;ZZ[B[B)V
flags: (0x0000)
Code:
stack=10, locals=11, args_size=11
start local 0 start local 1 start local 2 start local 3 start local 4 start local 5 start local 6 start local 7 start local 8 start local 9 start local 10 0: aload 0
invokespecial java.lang.Object.<init>:()V
1: aload 0
aconst_null
putfield sun.security.ssl.Handshaker.algorithmConstraints:Ljava/security/AlgorithmConstraints;
2: aload 0
invokestatic java.util.Collections.emptyList:()Ljava/util/List;
putfield sun.security.ssl.Handshaker.serverNames:Ljava/util/List;
3: aload 0
invokestatic java.util.Collections.emptyList:()Ljava/util/List;
putfield sun.security.ssl.Handshaker.sniMatchers:Ljava/util/Collection;
4: aload 0
aconst_null
putfield sun.security.ssl.Handshaker.localApl:[Ljava/lang/String;
5: aload 0
aconst_null
putfield sun.security.ssl.Handshaker.applicationProtocol:Ljava/lang/String;
6: aload 0
aconst_null
putfield sun.security.ssl.Handshaker.appProtocolSelectorSSLEngine:Ljava/util/function/BiFunction;
7: aload 0
aconst_null
putfield sun.security.ssl.Handshaker.appProtocolSelectorSSLSocket:Ljava/util/function/BiFunction;
8: aload 0
iconst_0
putfield sun.security.ssl.Handshaker.maximumPacketSize:I
9: aload 0
aconst_null
putfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
10: aload 0
aconst_null
putfield sun.security.ssl.Handshaker.engine:Lsun/security/ssl/SSLEngineImpl;
11: aload 0
iconst_0
putfield sun.security.ssl.Handshaker.preferLocalCipherSuites:Z
12: aload 0
iconst_0
putfield sun.security.ssl.Handshaker.taskDelegated:Z
13: aload 0
aconst_null
putfield sun.security.ssl.Handshaker.delegatedTask:Lsun/security/ssl/Handshaker$DelegatedTask;
14: aload 0
aconst_null
putfield sun.security.ssl.Handshaker.thrown:Ljava/lang/Exception;
15: aload 0
new java.lang.Object
dup
invokespecial java.lang.Object.<init>:()V
putfield sun.security.ssl.Handshaker.thrownLock:Ljava/lang/Object;
16: aload 0
iconst_0
putfield sun.security.ssl.Handshaker.requestedToUseEMS:Z
17: aload 0
aload 1
putfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
18: aload 0
iconst_0
putfield sun.security.ssl.Handshaker.isDTLS:Z
19: aload 0
aload 2
aload 3
iload 4
iload 5
20: aload 6
iload 7
iload 8
21: aload 9
aload 10
22: invokevirtual sun.security.ssl.Handshaker.init:(Lsun/security/ssl/SSLContextImpl;Lsun/security/ssl/ProtocolList;ZZLsun/security/ssl/ProtocolVersion;ZZ[B[B)V
23: return
end local 10 end local 9 end local 8 end local 7 end local 6 end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 24 0 this Lsun/security/ssl/Handshaker;
0 24 1 c Lsun/security/ssl/SSLSocketImpl;
0 24 2 context Lsun/security/ssl/SSLContextImpl;
0 24 3 enabledProtocols Lsun/security/ssl/ProtocolList;
0 24 4 needCertVerify Z
0 24 5 isClient Z
0 24 6 activeProtocolVersion Lsun/security/ssl/ProtocolVersion;
0 24 7 isInitialHandshake Z
0 24 8 secureRenegotiation Z
0 24 9 clientVerifyData [B
0 24 10 serverVerifyData [B
MethodParameters:
Name Flags
c
context
enabledProtocols
needCertVerify
isClient
activeProtocolVersion
isInitialHandshake
secureRenegotiation
clientVerifyData
serverVerifyData
void <init>(sun.security.ssl.SSLEngineImpl, sun.security.ssl.SSLContextImpl, sun.security.ssl.ProtocolList, boolean, boolean, sun.security.ssl.ProtocolVersion, boolean, boolean, byte[], byte[], boolean);
descriptor: (Lsun/security/ssl/SSLEngineImpl;Lsun/security/ssl/SSLContextImpl;Lsun/security/ssl/ProtocolList;ZZLsun/security/ssl/ProtocolVersion;ZZ[B[BZ)V
flags: (0x0000)
Code:
stack=10, locals=12, args_size=12
start local 0 start local 1 start local 2 start local 3 start local 4 start local 5 start local 6 start local 7 start local 8 start local 9 start local 10 start local 11 0: aload 0
invokespecial java.lang.Object.<init>:()V
1: aload 0
aconst_null
putfield sun.security.ssl.Handshaker.algorithmConstraints:Ljava/security/AlgorithmConstraints;
2: aload 0
invokestatic java.util.Collections.emptyList:()Ljava/util/List;
putfield sun.security.ssl.Handshaker.serverNames:Ljava/util/List;
3: aload 0
invokestatic java.util.Collections.emptyList:()Ljava/util/List;
putfield sun.security.ssl.Handshaker.sniMatchers:Ljava/util/Collection;
4: aload 0
aconst_null
putfield sun.security.ssl.Handshaker.localApl:[Ljava/lang/String;
5: aload 0
aconst_null
putfield sun.security.ssl.Handshaker.applicationProtocol:Ljava/lang/String;
6: aload 0
aconst_null
putfield sun.security.ssl.Handshaker.appProtocolSelectorSSLEngine:Ljava/util/function/BiFunction;
7: aload 0
aconst_null
putfield sun.security.ssl.Handshaker.appProtocolSelectorSSLSocket:Ljava/util/function/BiFunction;
8: aload 0
iconst_0
putfield sun.security.ssl.Handshaker.maximumPacketSize:I
9: aload 0
aconst_null
putfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
10: aload 0
aconst_null
putfield sun.security.ssl.Handshaker.engine:Lsun/security/ssl/SSLEngineImpl;
11: aload 0
iconst_0
putfield sun.security.ssl.Handshaker.preferLocalCipherSuites:Z
12: aload 0
iconst_0
putfield sun.security.ssl.Handshaker.taskDelegated:Z
13: aload 0
aconst_null
putfield sun.security.ssl.Handshaker.delegatedTask:Lsun/security/ssl/Handshaker$DelegatedTask;
14: aload 0
aconst_null
putfield sun.security.ssl.Handshaker.thrown:Ljava/lang/Exception;
15: aload 0
new java.lang.Object
dup
invokespecial java.lang.Object.<init>:()V
putfield sun.security.ssl.Handshaker.thrownLock:Ljava/lang/Object;
16: aload 0
iconst_0
putfield sun.security.ssl.Handshaker.requestedToUseEMS:Z
17: aload 0
aload 1
putfield sun.security.ssl.Handshaker.engine:Lsun/security/ssl/SSLEngineImpl;
18: aload 0
iload 11
putfield sun.security.ssl.Handshaker.isDTLS:Z
19: aload 0
aload 2
aload 3
iload 4
iload 5
20: aload 6
iload 7
iload 8
21: aload 9
aload 10
22: invokevirtual sun.security.ssl.Handshaker.init:(Lsun/security/ssl/SSLContextImpl;Lsun/security/ssl/ProtocolList;ZZLsun/security/ssl/ProtocolVersion;ZZ[B[B)V
23: return
end local 11 end local 10 end local 9 end local 8 end local 7 end local 6 end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 24 0 this Lsun/security/ssl/Handshaker;
0 24 1 engine Lsun/security/ssl/SSLEngineImpl;
0 24 2 context Lsun/security/ssl/SSLContextImpl;
0 24 3 enabledProtocols Lsun/security/ssl/ProtocolList;
0 24 4 needCertVerify Z
0 24 5 isClient Z
0 24 6 activeProtocolVersion Lsun/security/ssl/ProtocolVersion;
0 24 7 isInitialHandshake Z
0 24 8 secureRenegotiation Z
0 24 9 clientVerifyData [B
0 24 10 serverVerifyData [B
0 24 11 isDTLS Z
MethodParameters:
Name Flags
engine
context
enabledProtocols
needCertVerify
isClient
activeProtocolVersion
isInitialHandshake
secureRenegotiation
clientVerifyData
serverVerifyData
isDTLS
private void init(sun.security.ssl.SSLContextImpl, sun.security.ssl.ProtocolList, boolean, boolean, sun.security.ssl.ProtocolVersion, boolean, boolean, byte[], byte[]);
descriptor: (Lsun/security/ssl/SSLContextImpl;Lsun/security/ssl/ProtocolList;ZZLsun/security/ssl/ProtocolVersion;ZZ[B[B)V
flags: (0x0002) ACC_PRIVATE
Code:
stack=5, locals=10, args_size=10
start local 0 start local 1 start local 2 start local 3 start local 4 start local 5 start local 6 start local 7 start local 8 start local 9 0: getstatic sun.security.ssl.Handshaker.debug:Lsun/security/ssl/Debug;
ifnull 8
ldc "handshake"
invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
ifeq 8
1: getstatic java.lang.System.out:Ljava/io/PrintStream;
2: new java.lang.StringBuilder
dup
ldc "Allow unsafe renegotiation: "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
getstatic sun.security.ssl.Handshaker.allowUnsafeRenegotiation:Z
invokevirtual java.lang.StringBuilder.append:(Z)Ljava/lang/StringBuilder;
3: ldc "\nAllow legacy hello messages: "
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
getstatic sun.security.ssl.Handshaker.allowLegacyHelloMessages:Z
invokevirtual java.lang.StringBuilder.append:(Z)Ljava/lang/StringBuilder;
4: ldc "\nIs initial handshake: "
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
iload 6
invokevirtual java.lang.StringBuilder.append:(Z)Ljava/lang/StringBuilder;
5: ldc "\nIs secure renegotiation: "
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
iload 7
invokevirtual java.lang.StringBuilder.append:(Z)Ljava/lang/StringBuilder;
6: invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
7: invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
8: StackMap locals:
StackMap stack:
aload 0
aload 1
putfield sun.security.ssl.Handshaker.sslContext:Lsun/security/ssl/SSLContextImpl;
9: aload 0
iload 4
putfield sun.security.ssl.Handshaker.isClient:Z
10: aload 0
iload 3
putfield sun.security.ssl.Handshaker.needCertVerify:Z
11: aload 0
aload 5
putfield sun.security.ssl.Handshaker.activeProtocolVersion:Lsun/security/ssl/ProtocolVersion;
12: aload 0
iload 6
putfield sun.security.ssl.Handshaker.isInitialHandshake:Z
13: aload 0
iload 7
putfield sun.security.ssl.Handshaker.secureRenegotiation:Z
14: aload 0
aload 8
putfield sun.security.ssl.Handshaker.clientVerifyData:[B
15: aload 0
aload 9
putfield sun.security.ssl.Handshaker.serverVerifyData:[B
16: aload 0
iconst_1
putfield sun.security.ssl.Handshaker.enableNewSession:Z
17: aload 0
iconst_0
putfield sun.security.ssl.Handshaker.invalidated:Z
18: aload 0
new sun.security.ssl.HandshakeStateManager
dup
aload 0
getfield sun.security.ssl.Handshaker.isDTLS:Z
invokespecial sun.security.ssl.HandshakeStateManager.<init>:(Z)V
putfield sun.security.ssl.Handshaker.handshakeState:Lsun/security/ssl/HandshakeStateManager;
19: aload 0
iconst_0
putfield sun.security.ssl.Handshaker.clientHelloDelivered:Z
20: aload 0
iconst_0
putfield sun.security.ssl.Handshaker.serverHelloRequested:Z
21: aload 0
iconst_0
putfield sun.security.ssl.Handshaker.handshakeActivated:Z
22: aload 0
iconst_0
putfield sun.security.ssl.Handshaker.handshakeFinished:Z
23: aload 0
getstatic sun.security.ssl.CipherSuite.C_NULL:Lsun/security/ssl/CipherSuite;
invokevirtual sun.security.ssl.Handshaker.setCipherSuite:(Lsun/security/ssl/CipherSuite;)V
24: aload 0
aload 2
invokevirtual sun.security.ssl.Handshaker.setEnabledProtocols:(Lsun/security/ssl/ProtocolList;)V
25: aload 0
getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
ifnull 28
26: aload 0
new sun.security.ssl.SSLAlgorithmConstraints
dup
aload 0
getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
iconst_1
invokespecial sun.security.ssl.SSLAlgorithmConstraints.<init>:(Ljavax/net/ssl/SSLSocket;Z)V
putfield sun.security.ssl.Handshaker.algorithmConstraints:Ljava/security/AlgorithmConstraints;
27: goto 29
28: StackMap locals:
StackMap stack:
aload 0
new sun.security.ssl.SSLAlgorithmConstraints
dup
aload 0
getfield sun.security.ssl.Handshaker.engine:Lsun/security/ssl/SSLEngineImpl;
iconst_1
invokespecial sun.security.ssl.SSLAlgorithmConstraints.<init>:(Ljavax/net/ssl/SSLEngine;Z)V
putfield sun.security.ssl.Handshaker.algorithmConstraints:Ljava/security/AlgorithmConstraints;
29: StackMap locals:
StackMap stack:
return
end local 9 end local 8 end local 7 end local 6 end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 30 0 this Lsun/security/ssl/Handshaker;
0 30 1 context Lsun/security/ssl/SSLContextImpl;
0 30 2 enabledProtocols Lsun/security/ssl/ProtocolList;
0 30 3 needCertVerify Z
0 30 4 isClient Z
0 30 5 activeProtocolVersion Lsun/security/ssl/ProtocolVersion;
0 30 6 isInitialHandshake Z
0 30 7 secureRenegotiation Z
0 30 8 clientVerifyData [B
0 30 9 serverVerifyData [B
MethodParameters:
Name Flags
context
enabledProtocols
needCertVerify
isClient
activeProtocolVersion
isInitialHandshake
secureRenegotiation
clientVerifyData
serverVerifyData
void fatalSE(byte, java.lang.String);
descriptor: (BLjava/lang/String;)V
flags: (0x0000)
Code:
stack=4, locals=3, args_size=3
start local 0 start local 1 start local 2 0: aload 0
iload 1
aload 2
aconst_null
invokevirtual sun.security.ssl.Handshaker.fatalSE:(BLjava/lang/String;Ljava/lang/Throwable;)V
1: return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lsun/security/ssl/Handshaker;
0 2 1 b B
0 2 2 diagnostic Ljava/lang/String;
Exceptions:
throws java.io.IOException
MethodParameters:
Name Flags
b
diagnostic
void fatalSE(byte, java.lang.Throwable);
descriptor: (BLjava/lang/Throwable;)V
flags: (0x0000)
Code:
stack=4, locals=3, args_size=3
start local 0 start local 1 start local 2 0: aload 0
iload 1
aconst_null
aload 2
invokevirtual sun.security.ssl.Handshaker.fatalSE:(BLjava/lang/String;Ljava/lang/Throwable;)V
1: return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lsun/security/ssl/Handshaker;
0 2 1 b B
0 2 2 cause Ljava/lang/Throwable;
Exceptions:
throws java.io.IOException
MethodParameters:
Name Flags
b
cause
void fatalSE(byte, java.lang.String, java.lang.Throwable);
descriptor: (BLjava/lang/String;Ljava/lang/Throwable;)V
flags: (0x0000)
Code:
stack=4, locals=4, args_size=4
start local 0 start local 1 start local 2 start local 3 0: aload 0
getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
ifnull 3
1: aload 0
getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
iload 1
aload 2
aload 3
invokevirtual sun.security.ssl.SSLSocketImpl.fatal:(BLjava/lang/String;Ljava/lang/Throwable;)V
2: goto 4
3: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.ssl.Handshaker.engine:Lsun/security/ssl/SSLEngineImpl;
iload 1
aload 2
aload 3
invokevirtual sun.security.ssl.SSLEngineImpl.fatal:(BLjava/lang/String;Ljava/lang/Throwable;)V
4: StackMap locals:
StackMap stack:
return
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 5 0 this Lsun/security/ssl/Handshaker;
0 5 1 b B
0 5 2 diagnostic Ljava/lang/String;
0 5 3 cause Ljava/lang/Throwable;
Exceptions:
throws java.io.IOException
MethodParameters:
Name Flags
b
diagnostic
cause
void warningSE(byte);
descriptor: (B)V
flags: (0x0000)
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
ifnull 3
1: aload 0
getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
iload 1
invokevirtual sun.security.ssl.SSLSocketImpl.warning:(B)V
2: goto 4
3: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.ssl.Handshaker.engine:Lsun/security/ssl/SSLEngineImpl;
iload 1
invokevirtual sun.security.ssl.SSLEngineImpl.warning:(B)V
4: StackMap locals:
StackMap stack:
return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 5 0 this Lsun/security/ssl/Handshaker;
0 5 1 b B
MethodParameters:
Name Flags
b
java.lang.String getHostSE();
descriptor: ()Ljava/lang/String;
flags: (0x0000)
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
ifnull 2
1: aload 0
getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
invokevirtual sun.security.ssl.SSLSocketImpl.getHost:()Ljava/lang/String;
areturn
2: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.ssl.Handshaker.engine:Lsun/security/ssl/SSLEngineImpl;
invokevirtual sun.security.ssl.SSLEngineImpl.getPeerHost:()Ljava/lang/String;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lsun/security/ssl/Handshaker;
java.lang.String getHostAddressSE();
descriptor: ()Ljava/lang/String;
flags: (0x0000)
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
ifnull 2
1: aload 0
getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
invokevirtual sun.security.ssl.SSLSocketImpl.getInetAddress:()Ljava/net/InetAddress;
invokevirtual java.net.InetAddress.getHostAddress:()Ljava/lang/String;
areturn
2: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.ssl.Handshaker.engine:Lsun/security/ssl/SSLEngineImpl;
invokevirtual sun.security.ssl.SSLEngineImpl.getPeerHost:()Ljava/lang/String;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lsun/security/ssl/Handshaker;
int getPortSE();
descriptor: ()I
flags: (0x0000)
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
ifnull 2
1: aload 0
getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
invokevirtual sun.security.ssl.SSLSocketImpl.getPort:()I
ireturn
2: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.ssl.Handshaker.engine:Lsun/security/ssl/SSLEngineImpl;
invokevirtual sun.security.ssl.SSLEngineImpl.getPeerPort:()I
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lsun/security/ssl/Handshaker;
int getLocalPortSE();
descriptor: ()I
flags: (0x0000)
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
ifnull 2
1: aload 0
getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
invokevirtual sun.security.ssl.SSLSocketImpl.getLocalPort:()I
ireturn
2: StackMap locals:
StackMap stack:
iconst_m1
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lsun/security/ssl/Handshaker;
java.security.AccessControlContext getAccSE();
descriptor: ()Ljava/security/AccessControlContext;
flags: (0x0000)
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
ifnull 2
1: aload 0
getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
invokevirtual sun.security.ssl.SSLSocketImpl.getAcc:()Ljava/security/AccessControlContext;
areturn
2: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.ssl.Handshaker.engine:Lsun/security/ssl/SSLEngineImpl;
invokevirtual sun.security.ssl.SSLEngineImpl.getAcc:()Ljava/security/AccessControlContext;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lsun/security/ssl/Handshaker;
java.lang.String getEndpointIdentificationAlgorithmSE();
descriptor: ()Ljava/lang/String;
flags: (0x0000)
Code:
stack=1, locals=2, args_size=1
start local 0 0: aload 0
getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
ifnull 3
1: aload 0
getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
invokevirtual sun.security.ssl.SSLSocketImpl.getSSLParameters:()Ljavax/net/ssl/SSLParameters;
astore 1
start local 1 2: goto 4
end local 1 3: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.ssl.Handshaker.engine:Lsun/security/ssl/SSLEngineImpl;
invokevirtual sun.security.ssl.SSLEngineImpl.getSSLParameters:()Ljavax/net/ssl/SSLParameters;
astore 1
start local 1 4: StackMap locals: javax.net.ssl.SSLParameters
StackMap stack:
aload 1
invokevirtual javax.net.ssl.SSLParameters.getEndpointIdentificationAlgorithm:()Ljava/lang/String;
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 5 0 this Lsun/security/ssl/Handshaker;
2 3 1 paras Ljavax/net/ssl/SSLParameters;
4 5 1 paras Ljavax/net/ssl/SSLParameters;
private void setVersionSE(sun.security.ssl.ProtocolVersion);
descriptor: (Lsun/security/ssl/ProtocolVersion;)V
flags: (0x0002) ACC_PRIVATE
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
ifnull 3
1: aload 0
getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
aload 1
invokevirtual sun.security.ssl.SSLSocketImpl.setVersion:(Lsun/security/ssl/ProtocolVersion;)V
2: goto 4
3: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.ssl.Handshaker.engine:Lsun/security/ssl/SSLEngineImpl;
aload 1
invokevirtual sun.security.ssl.SSLEngineImpl.setVersion:(Lsun/security/ssl/ProtocolVersion;)V
4: StackMap locals:
StackMap stack:
return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 5 0 this Lsun/security/ssl/Handshaker;
0 5 1 protocolVersion Lsun/security/ssl/ProtocolVersion;
MethodParameters:
Name Flags
protocolVersion
void setVersion(sun.security.ssl.ProtocolVersion);
descriptor: (Lsun/security/ssl/ProtocolVersion;)V
flags: (0x0000)
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
aload 1
putfield sun.security.ssl.Handshaker.protocolVersion:Lsun/security/ssl/ProtocolVersion;
1: aload 0
aload 1
invokevirtual sun.security.ssl.Handshaker.setVersionSE:(Lsun/security/ssl/ProtocolVersion;)V
2: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lsun/security/ssl/Handshaker;
0 3 1 protocolVersion Lsun/security/ssl/ProtocolVersion;
MethodParameters:
Name Flags
protocolVersion
void setEnabledProtocols(sun.security.ssl.ProtocolList);
descriptor: (Lsun/security/ssl/ProtocolList;)V
flags: (0x0000)
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
aconst_null
putfield sun.security.ssl.Handshaker.activeCipherSuites:Lsun/security/ssl/CipherSuiteList;
1: aload 0
aconst_null
putfield sun.security.ssl.Handshaker.activeProtocols:Lsun/security/ssl/ProtocolList;
2: aload 0
aload 1
putfield sun.security.ssl.Handshaker.enabledProtocols:Lsun/security/ssl/ProtocolList;
3: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lsun/security/ssl/Handshaker;
0 4 1 enabledProtocols Lsun/security/ssl/ProtocolList;
MethodParameters:
Name Flags
enabledProtocols
void setEnabledCipherSuites(sun.security.ssl.CipherSuiteList);
descriptor: (Lsun/security/ssl/CipherSuiteList;)V
flags: (0x0000)
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
aconst_null
putfield sun.security.ssl.Handshaker.activeCipherSuites:Lsun/security/ssl/CipherSuiteList;
1: aload 0
aconst_null
putfield sun.security.ssl.Handshaker.activeProtocols:Lsun/security/ssl/ProtocolList;
2: aload 0
aload 1
putfield sun.security.ssl.Handshaker.enabledCipherSuites:Lsun/security/ssl/CipherSuiteList;
3: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lsun/security/ssl/Handshaker;
0 4 1 enabledCipherSuites Lsun/security/ssl/CipherSuiteList;
MethodParameters:
Name Flags
enabledCipherSuites
void setAlgorithmConstraints(java.security.AlgorithmConstraints);
descriptor: (Ljava/security/AlgorithmConstraints;)V
flags: (0x0000)
Code:
stack=4, locals=2, args_size=2
start local 0 start local 1 0: aload 0
aconst_null
putfield sun.security.ssl.Handshaker.activeCipherSuites:Lsun/security/ssl/CipherSuiteList;
1: aload 0
aconst_null
putfield sun.security.ssl.Handshaker.activeProtocols:Lsun/security/ssl/ProtocolList;
2: aload 0
3: new sun.security.ssl.SSLAlgorithmConstraints
dup
aload 1
invokespecial sun.security.ssl.SSLAlgorithmConstraints.<init>:(Ljava/security/AlgorithmConstraints;)V
4: putfield sun.security.ssl.Handshaker.algorithmConstraints:Ljava/security/AlgorithmConstraints;
5: aload 0
aconst_null
putfield sun.security.ssl.Handshaker.localSupportedSignAlgs:Ljava/util/Collection;
6: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 7 0 this Lsun/security/ssl/Handshaker;
0 7 1 algorithmConstraints Ljava/security/AlgorithmConstraints;
MethodParameters:
Name Flags
algorithmConstraints
java.util.Collection<sun.security.ssl.SignatureAndHashAlgorithm> getLocalSupportedSignAlgs();
descriptor: ()Ljava/util/Collection;
flags: (0x0000)
Code:
stack=2, locals=1, args_size=1
start local 0 0: aload 0
getfield sun.security.ssl.Handshaker.localSupportedSignAlgs:Ljava/util/Collection;
ifnonnull 5
1: aload 0
2: aload 0
getfield sun.security.ssl.Handshaker.algorithmConstraints:Ljava/security/AlgorithmConstraints;
3: invokestatic sun.security.ssl.SignatureAndHashAlgorithm.getSupportedAlgorithms:(Ljava/security/AlgorithmConstraints;)Ljava/util/Collection;
4: putfield sun.security.ssl.Handshaker.localSupportedSignAlgs:Ljava/util/Collection;
5: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.ssl.Handshaker.localSupportedSignAlgs:Ljava/util/Collection;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 6 0 this Lsun/security/ssl/Handshaker;
Signature: ()Ljava/util/Collection<Lsun/security/ssl/SignatureAndHashAlgorithm;>;
void setPeerSupportedSignAlgs(java.util.Collection<sun.security.ssl.SignatureAndHashAlgorithm>);
descriptor: (Ljava/util/Collection;)V
flags: (0x0000)
Code:
stack=4, locals=2, args_size=2
start local 0 start local 1 0: aload 0
1: new java.util.ArrayList
dup
aload 1
invokespecial java.util.ArrayList.<init>:(Ljava/util/Collection;)V
2: putfield sun.security.ssl.Handshaker.peerSupportedSignAlgs:Ljava/util/Collection;
3: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lsun/security/ssl/Handshaker;
0 4 1 algorithms Ljava/util/Collection<Lsun/security/ssl/SignatureAndHashAlgorithm;>;
Signature: (Ljava/util/Collection<Lsun/security/ssl/SignatureAndHashAlgorithm;>;)V
MethodParameters:
Name Flags
algorithms
java.util.Collection<sun.security.ssl.SignatureAndHashAlgorithm> getPeerSupportedSignAlgs();
descriptor: ()Ljava/util/Collection;
flags: (0x0000)
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield sun.security.ssl.Handshaker.peerSupportedSignAlgs:Ljava/util/Collection;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lsun/security/ssl/Handshaker;
Signature: ()Ljava/util/Collection<Lsun/security/ssl/SignatureAndHashAlgorithm;>;
void setIdentificationProtocol(java.lang.String);
descriptor: (Ljava/lang/String;)V
flags: (0x0000)
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
aload 1
putfield sun.security.ssl.Handshaker.identificationProtocol:Ljava/lang/String;
1: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lsun/security/ssl/Handshaker;
0 2 1 protocol Ljava/lang/String;
MethodParameters:
Name Flags
protocol
void setSNIServerNames(java.util.List<javax.net.ssl.SNIServerName>);
descriptor: (Ljava/util/List;)V
flags: (0x0000)
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
aload 1
putfield sun.security.ssl.Handshaker.serverNames:Ljava/util/List;
1: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lsun/security/ssl/Handshaker;
0 2 1 serverNames Ljava/util/List<Ljavax/net/ssl/SNIServerName;>;
Signature: (Ljava/util/List<Ljavax/net/ssl/SNIServerName;>;)V
MethodParameters:
Name Flags
serverNames
void setSNIMatchers(java.util.Collection<javax.net.ssl.SNIMatcher>);
descriptor: (Ljava/util/Collection;)V
flags: (0x0000)
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
aload 1
putfield sun.security.ssl.Handshaker.sniMatchers:Ljava/util/Collection;
1: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lsun/security/ssl/Handshaker;
0 2 1 sniMatchers Ljava/util/Collection<Ljavax/net/ssl/SNIMatcher;>;
Signature: (Ljava/util/Collection<Ljavax/net/ssl/SNIMatcher;>;)V
MethodParameters:
Name Flags
sniMatchers
void setMaximumPacketSize(int);
descriptor: (I)V
flags: (0x0000)
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
iload 1
putfield sun.security.ssl.Handshaker.maximumPacketSize:I
1: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lsun/security/ssl/Handshaker;
0 2 1 maximumPacketSize I
MethodParameters:
Name Flags
maximumPacketSize
void setApplicationProtocols(java.lang.String[]);
descriptor: ([Ljava/lang/String;)V
flags: (0x0000)
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
aload 1
putfield sun.security.ssl.Handshaker.localApl:[Ljava/lang/String;
1: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lsun/security/ssl/Handshaker;
0 2 1 apl [Ljava/lang/String;
MethodParameters:
Name Flags
apl
java.lang.String getHandshakeApplicationProtocol();
descriptor: ()Ljava/lang/String;
flags: (0x0000)
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield sun.security.ssl.Handshaker.applicationProtocol:Ljava/lang/String;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lsun/security/ssl/Handshaker;
void setApplicationProtocolSelectorSSLEngine(java.util.function.BiFunction<javax.net.ssl.SSLEngine, java.util.List<java.lang.String>, java.lang.String>);
descriptor: (Ljava/util/function/BiFunction;)V
flags: (0x0000)
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
aload 1
putfield sun.security.ssl.Handshaker.appProtocolSelectorSSLEngine:Ljava/util/function/BiFunction;
1: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lsun/security/ssl/Handshaker;
0 2 1 selector Ljava/util/function/BiFunction<Ljavax/net/ssl/SSLEngine;Ljava/util/List<Ljava/lang/String;>;Ljava/lang/String;>;
Signature: (Ljava/util/function/BiFunction<Ljavax/net/ssl/SSLEngine;Ljava/util/List<Ljava/lang/String;>;Ljava/lang/String;>;)V
MethodParameters:
Name Flags
selector
void setApplicationProtocolSelectorSSLSocket(java.util.function.BiFunction<javax.net.ssl.SSLSocket, java.util.List<java.lang.String>, java.lang.String>);
descriptor: (Ljava/util/function/BiFunction;)V
flags: (0x0000)
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
aload 1
putfield sun.security.ssl.Handshaker.appProtocolSelectorSSLSocket:Ljava/util/function/BiFunction;
1: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lsun/security/ssl/Handshaker;
0 2 1 selector Ljava/util/function/BiFunction<Ljavax/net/ssl/SSLSocket;Ljava/util/List<Ljava/lang/String;>;Ljava/lang/String;>;
Signature: (Ljava/util/function/BiFunction<Ljavax/net/ssl/SSLSocket;Ljava/util/List<Ljava/lang/String;>;Ljava/lang/String;>;)V
MethodParameters:
Name Flags
selector
void setUseCipherSuitesOrder(boolean);
descriptor: (Z)V
flags: (0x0000)
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
iload 1
putfield sun.security.ssl.Handshaker.preferLocalCipherSuites:Z
1: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lsun/security/ssl/Handshaker;
0 2 1 on Z
MethodParameters:
Name Flags
on
void activate(sun.security.ssl.ProtocolVersion);
descriptor: (Lsun/security/ssl/ProtocolVersion;)V
flags: (0x0000)
Code:
stack=4, locals=2, args_size=2
start local 0 start local 1 0: aload 0
getfield sun.security.ssl.Handshaker.activeProtocols:Lsun/security/ssl/ProtocolList;
ifnonnull 2
1: aload 0
aload 0
invokevirtual sun.security.ssl.Handshaker.getActiveProtocols:()Lsun/security/ssl/ProtocolList;
putfield sun.security.ssl.Handshaker.activeProtocols:Lsun/security/ssl/ProtocolList;
2: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.ssl.Handshaker.activeProtocols:Lsun/security/ssl/ProtocolList;
invokevirtual sun.security.ssl.ProtocolList.collection:()Ljava/util/Collection;
invokeinterface java.util.Collection.isEmpty:()Z
ifne 4
3: aload 0
getfield sun.security.ssl.Handshaker.activeProtocols:Lsun/security/ssl/ProtocolList;
getfield sun.security.ssl.ProtocolList.max: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_icmpne 7
4: StackMap locals:
StackMap stack:
new javax.net.ssl.SSLHandshakeException
dup
5: ldc "No appropriate protocol (protocol is disabled or cipher suites are inappropriate)"
6: invokespecial javax.net.ssl.SSLHandshakeException.<init>:(Ljava/lang/String;)V
athrow
7: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.ssl.Handshaker.activeCipherSuites:Lsun/security/ssl/CipherSuiteList;
ifnonnull 9
8: aload 0
aload 0
invokevirtual sun.security.ssl.Handshaker.getActiveCipherSuites:()Lsun/security/ssl/CipherSuiteList;
putfield sun.security.ssl.Handshaker.activeCipherSuites:Lsun/security/ssl/CipherSuiteList;
9: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.ssl.Handshaker.activeCipherSuites:Lsun/security/ssl/CipherSuiteList;
invokevirtual sun.security.ssl.CipherSuiteList.collection:()Ljava/util/Collection;
invokeinterface java.util.Collection.isEmpty:()Z
ifeq 11
10: new javax.net.ssl.SSLHandshakeException
dup
ldc "No appropriate cipher suite"
invokespecial javax.net.ssl.SSLHandshakeException.<init>:(Ljava/lang/String;)V
athrow
11: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.ssl.Handshaker.isInitialHandshake:Z
ifne 14
12: aload 0
aload 0
getfield sun.security.ssl.Handshaker.activeProtocolVersion:Lsun/security/ssl/ProtocolVersion;
putfield sun.security.ssl.Handshaker.protocolVersion:Lsun/security/ssl/ProtocolVersion;
13: goto 15
14: StackMap locals:
StackMap stack:
aload 0
aload 0
getfield sun.security.ssl.Handshaker.activeProtocols:Lsun/security/ssl/ProtocolList;
getfield sun.security.ssl.ProtocolList.max:Lsun/security/ssl/ProtocolVersion;
putfield sun.security.ssl.Handshaker.protocolVersion:Lsun/security/ssl/ProtocolVersion;
15: StackMap locals:
StackMap stack:
aload 1
ifnull 16
aload 1
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_icmpne 17
16: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.ssl.Handshaker.activeProtocols:Lsun/security/ssl/ProtocolList;
getfield sun.security.ssl.ProtocolList.helloVersion:Lsun/security/ssl/ProtocolVersion;
astore 1
17: StackMap locals:
StackMap stack:
aload 0
new sun.security.ssl.HandshakeHash
dup
aload 0
getfield sun.security.ssl.Handshaker.needCertVerify:Z
invokespecial sun.security.ssl.HandshakeHash.<init>:(Z)V
putfield sun.security.ssl.Handshaker.handshakeHash:Lsun/security/ssl/HandshakeHash;
18: aload 0
getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
ifnull 27
19: aload 0
new sun.security.ssl.HandshakeInStream
dup
invokespecial sun.security.ssl.HandshakeInStream.<init>:()V
putfield sun.security.ssl.Handshaker.input:Lsun/security/ssl/HandshakeInStream;
20: aload 0
new sun.security.ssl.HandshakeOutStream
dup
aload 0
getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
getfield sun.security.ssl.SSLSocketImpl.outputRecord:Lsun/security/ssl/OutputRecord;
invokespecial sun.security.ssl.HandshakeOutStream.<init>:(Lsun/security/ssl/OutputRecord;)V
putfield sun.security.ssl.Handshaker.output:Lsun/security/ssl/HandshakeOutStream;
21: aload 0
getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
getfield sun.security.ssl.SSLSocketImpl.inputRecord:Lsun/security/ssl/InputRecord;
aload 0
getfield sun.security.ssl.Handshaker.handshakeHash:Lsun/security/ssl/HandshakeHash;
invokevirtual sun.security.ssl.InputRecord.setHandshakeHash:(Lsun/security/ssl/HandshakeHash;)V
22: aload 0
getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
getfield sun.security.ssl.SSLSocketImpl.inputRecord:Lsun/security/ssl/InputRecord;
aload 1
invokevirtual sun.security.ssl.InputRecord.setHelloVersion:(Lsun/security/ssl/ProtocolVersion;)V
23: aload 0
getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
getfield sun.security.ssl.SSLSocketImpl.outputRecord:Lsun/security/ssl/OutputRecord;
aload 0
getfield sun.security.ssl.Handshaker.handshakeHash:Lsun/security/ssl/HandshakeHash;
invokevirtual sun.security.ssl.OutputRecord.setHandshakeHash:(Lsun/security/ssl/HandshakeHash;)V
24: aload 0
getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
getfield sun.security.ssl.SSLSocketImpl.outputRecord:Lsun/security/ssl/OutputRecord;
aload 1
invokevirtual sun.security.ssl.OutputRecord.setHelloVersion:(Lsun/security/ssl/ProtocolVersion;)V
25: aload 0
getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
getfield sun.security.ssl.SSLSocketImpl.outputRecord:Lsun/security/ssl/OutputRecord;
aload 0
getfield sun.security.ssl.Handshaker.protocolVersion:Lsun/security/ssl/ProtocolVersion;
invokevirtual sun.security.ssl.OutputRecord.setVersion:(Lsun/security/ssl/ProtocolVersion;)V
26: goto 35
StackMap locals:
StackMap stack:
27: aload 0
getfield sun.security.ssl.Handshaker.engine:Lsun/security/ssl/SSLEngineImpl;
ifnull 35
28: aload 0
new sun.security.ssl.HandshakeInStream
dup
invokespecial sun.security.ssl.HandshakeInStream.<init>:()V
putfield sun.security.ssl.Handshaker.input:Lsun/security/ssl/HandshakeInStream;
29: aload 0
new sun.security.ssl.HandshakeOutStream
dup
aload 0
getfield sun.security.ssl.Handshaker.engine:Lsun/security/ssl/SSLEngineImpl;
getfield sun.security.ssl.SSLEngineImpl.outputRecord:Lsun/security/ssl/OutputRecord;
invokespecial sun.security.ssl.HandshakeOutStream.<init>:(Lsun/security/ssl/OutputRecord;)V
putfield sun.security.ssl.Handshaker.output:Lsun/security/ssl/HandshakeOutStream;
30: aload 0
getfield sun.security.ssl.Handshaker.engine:Lsun/security/ssl/SSLEngineImpl;
getfield sun.security.ssl.SSLEngineImpl.inputRecord:Lsun/security/ssl/InputRecord;
aload 0
getfield sun.security.ssl.Handshaker.handshakeHash:Lsun/security/ssl/HandshakeHash;
invokevirtual sun.security.ssl.InputRecord.setHandshakeHash:(Lsun/security/ssl/HandshakeHash;)V
31: aload 0
getfield sun.security.ssl.Handshaker.engine:Lsun/security/ssl/SSLEngineImpl;
getfield sun.security.ssl.SSLEngineImpl.inputRecord:Lsun/security/ssl/InputRecord;
aload 1
invokevirtual sun.security.ssl.InputRecord.setHelloVersion:(Lsun/security/ssl/ProtocolVersion;)V
32: aload 0
getfield sun.security.ssl.Handshaker.engine:Lsun/security/ssl/SSLEngineImpl;
getfield sun.security.ssl.SSLEngineImpl.outputRecord:Lsun/security/ssl/OutputRecord;
aload 0
getfield sun.security.ssl.Handshaker.handshakeHash:Lsun/security/ssl/HandshakeHash;
invokevirtual sun.security.ssl.OutputRecord.setHandshakeHash:(Lsun/security/ssl/HandshakeHash;)V
33: aload 0
getfield sun.security.ssl.Handshaker.engine:Lsun/security/ssl/SSLEngineImpl;
getfield sun.security.ssl.SSLEngineImpl.outputRecord:Lsun/security/ssl/OutputRecord;
aload 1
invokevirtual sun.security.ssl.OutputRecord.setHelloVersion:(Lsun/security/ssl/ProtocolVersion;)V
34: aload 0
getfield sun.security.ssl.Handshaker.engine:Lsun/security/ssl/SSLEngineImpl;
getfield sun.security.ssl.SSLEngineImpl.outputRecord:Lsun/security/ssl/OutputRecord;
aload 0
getfield sun.security.ssl.Handshaker.protocolVersion:Lsun/security/ssl/ProtocolVersion;
invokevirtual sun.security.ssl.OutputRecord.setVersion:(Lsun/security/ssl/ProtocolVersion;)V
35: StackMap locals:
StackMap stack:
aload 0
iconst_1
putfield sun.security.ssl.Handshaker.handshakeActivated:Z
36: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 37 0 this Lsun/security/ssl/Handshaker;
0 37 1 helloVersion Lsun/security/ssl/ProtocolVersion;
Exceptions:
throws java.io.IOException
MethodParameters:
Name Flags
helloVersion
void setCipherSuite(sun.security.ssl.CipherSuite);
descriptor: (Lsun/security/ssl/CipherSuite;)V
flags: (0x0000)
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
aload 1
putfield sun.security.ssl.Handshaker.cipherSuite:Lsun/security/ssl/CipherSuite;
1: aload 0
aload 1
getfield sun.security.ssl.CipherSuite.keyExchange:Lsun/security/ssl/CipherSuite$KeyExchange;
putfield sun.security.ssl.Handshaker.keyExchange:Lsun/security/ssl/CipherSuite$KeyExchange;
2: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lsun/security/ssl/Handshaker;
0 3 1 s Lsun/security/ssl/CipherSuite;
MethodParameters:
Name Flags
s
boolean isNegotiable(sun.security.ssl.CipherSuite);
descriptor: (Lsun/security/ssl/CipherSuite;)Z
flags: (0x0000)
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
getfield sun.security.ssl.Handshaker.activeCipherSuites:Lsun/security/ssl/CipherSuiteList;
ifnonnull 2
1: aload 0
aload 0
invokevirtual sun.security.ssl.Handshaker.getActiveCipherSuites:()Lsun/security/ssl/CipherSuiteList;
putfield sun.security.ssl.Handshaker.activeCipherSuites:Lsun/security/ssl/CipherSuiteList;
2: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.ssl.Handshaker.activeCipherSuites:Lsun/security/ssl/CipherSuiteList;
aload 1
invokestatic sun.security.ssl.Handshaker.isNegotiable:(Lsun/security/ssl/CipherSuiteList;Lsun/security/ssl/CipherSuite;)Z
ireturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lsun/security/ssl/Handshaker;
0 3 1 s Lsun/security/ssl/CipherSuite;
MethodParameters:
Name Flags
s
static final boolean isNegotiable(sun.security.ssl.CipherSuiteList, sun.security.ssl.CipherSuite);
descriptor: (Lsun/security/ssl/CipherSuiteList;Lsun/security/ssl/CipherSuite;)Z
flags: (0x0018) ACC_STATIC, ACC_FINAL
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
aload 1
invokevirtual sun.security.ssl.CipherSuiteList.contains:(Lsun/security/ssl/CipherSuite;)Z
ifeq 1
aload 1
invokevirtual sun.security.ssl.CipherSuite.isNegotiable:()Z
ifeq 1
iconst_1
ireturn
StackMap locals:
StackMap stack:
1: iconst_0
ireturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 proposed Lsun/security/ssl/CipherSuiteList;
0 2 1 s Lsun/security/ssl/CipherSuite;
MethodParameters:
Name Flags
proposed
s
boolean isNegotiable(sun.security.ssl.ProtocolVersion);
descriptor: (Lsun/security/ssl/ProtocolVersion;)Z
flags: (0x0000)
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
getfield sun.security.ssl.Handshaker.activeProtocols:Lsun/security/ssl/ProtocolList;
ifnonnull 2
1: aload 0
aload 0
invokevirtual sun.security.ssl.Handshaker.getActiveProtocols:()Lsun/security/ssl/ProtocolList;
putfield sun.security.ssl.Handshaker.activeProtocols:Lsun/security/ssl/ProtocolList;
2: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.ssl.Handshaker.activeProtocols:Lsun/security/ssl/ProtocolList;
aload 1
invokevirtual sun.security.ssl.ProtocolList.contains:(Lsun/security/ssl/ProtocolVersion;)Z
ireturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lsun/security/ssl/Handshaker;
0 3 1 protocolVersion Lsun/security/ssl/ProtocolVersion;
MethodParameters:
Name Flags
protocolVersion
sun.security.ssl.ProtocolVersion selectProtocolVersion(sun.security.ssl.ProtocolVersion);
descriptor: (Lsun/security/ssl/ProtocolVersion;)Lsun/security/ssl/ProtocolVersion;
flags: (0x0000)
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
getfield sun.security.ssl.Handshaker.activeProtocols:Lsun/security/ssl/ProtocolList;
ifnonnull 2
1: aload 0
aload 0
invokevirtual sun.security.ssl.Handshaker.getActiveProtocols:()Lsun/security/ssl/ProtocolList;
putfield sun.security.ssl.Handshaker.activeProtocols:Lsun/security/ssl/ProtocolList;
2: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.ssl.Handshaker.activeProtocols:Lsun/security/ssl/ProtocolList;
aload 1
invokevirtual sun.security.ssl.ProtocolList.selectProtocolVersion:(Lsun/security/ssl/ProtocolVersion;)Lsun/security/ssl/ProtocolVersion;
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lsun/security/ssl/Handshaker;
0 3 1 protocolVersion Lsun/security/ssl/ProtocolVersion;
MethodParameters:
Name Flags
protocolVersion
sun.security.ssl.CipherSuiteList getActiveCipherSuites();
descriptor: ()Lsun/security/ssl/CipherSuiteList;
flags: (0x0000)
Code:
stack=4, locals=5, args_size=1
start local 0 0: aload 0
getfield sun.security.ssl.Handshaker.activeCipherSuites:Lsun/security/ssl/CipherSuiteList;
ifnonnull 27
1: aload 0
getfield sun.security.ssl.Handshaker.activeProtocols:Lsun/security/ssl/ProtocolList;
ifnonnull 3
2: aload 0
aload 0
invokevirtual sun.security.ssl.Handshaker.getActiveProtocols:()Lsun/security/ssl/ProtocolList;
putfield sun.security.ssl.Handshaker.activeProtocols:Lsun/security/ssl/ProtocolList;
3: StackMap locals:
StackMap stack:
new java.util.ArrayList
dup
invokespecial java.util.ArrayList.<init>:()V
astore 1
start local 1 4: aload 0
getfield sun.security.ssl.Handshaker.activeProtocols:Lsun/security/ssl/ProtocolList;
invokevirtual sun.security.ssl.ProtocolList.collection:()Ljava/util/Collection;
invokeinterface java.util.Collection.isEmpty:()Z
ifne 26
5: aload 0
getfield sun.security.ssl.Handshaker.activeProtocols:Lsun/security/ssl/ProtocolList;
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 26
6: new java.util.EnumMap
dup
ldc Lsun/security/ssl/NamedGroupType;
invokespecial java.util.EnumMap.<init>:(Ljava/lang/Class;)V
7: astore 2
start local 2 8: aload 0
getfield sun.security.ssl.Handshaker.enabledCipherSuites:Lsun/security/ssl/CipherSuiteList;
invokevirtual sun.security.ssl.CipherSuiteList.collection:()Ljava/util/Collection;
invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
astore 4
goto 25
StackMap locals: sun.security.ssl.Handshaker java.util.ArrayList java.util.Map top java.util.Iterator
StackMap stack:
9: aload 4
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast sun.security.ssl.CipherSuite
astore 3
start local 3 10: aload 3
invokevirtual sun.security.ssl.CipherSuite.isAvailable:()Z
ifeq 16
11: aload 0
getfield sun.security.ssl.Handshaker.activeProtocols:Lsun/security/ssl/ProtocolList;
getfield sun.security.ssl.ProtocolList.min:Lsun/security/ssl/ProtocolVersion;
aload 3
invokevirtual sun.security.ssl.ProtocolVersion.obsoletes:(Lsun/security/ssl/CipherSuite;)Z
ifne 16
12: aload 0
getfield sun.security.ssl.Handshaker.activeProtocols:Lsun/security/ssl/ProtocolList;
getfield sun.security.ssl.ProtocolList.max:Lsun/security/ssl/ProtocolVersion;
aload 3
invokevirtual sun.security.ssl.ProtocolVersion.supports:(Lsun/security/ssl/CipherSuite;)Z
ifeq 16
13: aload 0
aload 3
aload 2
invokevirtual sun.security.ssl.Handshaker.isActivatable:(Lsun/security/ssl/CipherSuite;Ljava/util/Map;)Z
ifeq 25
14: aload 1
aload 3
invokevirtual java.util.ArrayList.add:(Ljava/lang/Object;)Z
pop
15: goto 25
StackMap locals: sun.security.ssl.Handshaker java.util.ArrayList java.util.Map sun.security.ssl.CipherSuite java.util.Iterator
StackMap stack:
16: getstatic sun.security.ssl.Handshaker.debug:Lsun/security/ssl/Debug;
ifnull 25
ldc "verbose"
invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
ifeq 25
17: aload 0
getfield sun.security.ssl.Handshaker.activeProtocols:Lsun/security/ssl/ProtocolList;
getfield sun.security.ssl.ProtocolList.min:Lsun/security/ssl/ProtocolVersion;
aload 3
invokevirtual sun.security.ssl.ProtocolVersion.obsoletes:(Lsun/security/ssl/CipherSuite;)Z
ifeq 22
18: getstatic java.lang.System.out:Ljava/io/PrintStream;
19: new java.lang.StringBuilder
dup
ldc "Ignoring obsoleted 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;
20: invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
21: goto 25
22: StackMap locals:
StackMap stack:
getstatic java.lang.System.out:Ljava/io/PrintStream;
23: new java.lang.StringBuilder
dup
ldc "Ignoring 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;
24: invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
end local 3 25: StackMap locals: sun.security.ssl.Handshaker java.util.ArrayList java.util.Map top java.util.Iterator
StackMap stack:
aload 4
invokeinterface java.util.Iterator.hasNext:()Z
ifne 9
end local 2 26: StackMap locals: sun.security.ssl.Handshaker java.util.ArrayList
StackMap stack:
aload 0
new sun.security.ssl.CipherSuiteList
dup
aload 1
invokespecial sun.security.ssl.CipherSuiteList.<init>:(Ljava/util/Collection;)V
putfield sun.security.ssl.Handshaker.activeCipherSuites:Lsun/security/ssl/CipherSuiteList;
end local 1 27: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.ssl.Handshaker.activeCipherSuites:Lsun/security/ssl/CipherSuiteList;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 28 0 this Lsun/security/ssl/Handshaker;
4 27 1 suites Ljava/util/ArrayList<Lsun/security/ssl/CipherSuite;>;
8 26 2 cachedStatus Ljava/util/Map<Lsun/security/ssl/NamedGroupType;Ljava/lang/Boolean;>;
10 25 3 suite Lsun/security/ssl/CipherSuite;
sun.security.ssl.ProtocolList getActiveProtocols();
descriptor: ()Lsun/security/ssl/ProtocolList;
flags: (0x0000)
Code:
stack=4, locals=9, args_size=1
start local 0 0: aload 0
getfield sun.security.ssl.Handshaker.activeProtocols:Lsun/security/ssl/ProtocolList;
ifnonnull 44
1: iconst_0
istore 1
start local 1 2: new java.util.ArrayList
dup
iconst_4
invokespecial java.util.ArrayList.<init>:(I)V
astore 2
start local 2 3: aload 0
getfield sun.security.ssl.Handshaker.enabledProtocols:Lsun/security/ssl/ProtocolList;
invokevirtual sun.security.ssl.ProtocolList.collection:()Ljava/util/Collection;
invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
astore 4
goto 40
StackMap locals: sun.security.ssl.Handshaker int java.util.ArrayList top java.util.Iterator
StackMap stack:
4: aload 4
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast sun.security.ssl.ProtocolVersion
astore 3
start local 3 5: aload 3
getfield sun.security.ssl.ProtocolVersion.v:I
getstatic sun.security.ssl.ProtocolVersion.SSL20Hello:Lsun/security/ssl/ProtocolVersion;
getfield sun.security.ssl.ProtocolVersion.v:I
if_icmpne 8
6: iconst_1
istore 1
7: goto 40
8: StackMap locals: sun.security.ssl.Handshaker int java.util.ArrayList sun.security.ssl.ProtocolVersion java.util.Iterator
StackMap stack:
aload 0
getfield sun.security.ssl.Handshaker.algorithmConstraints:Ljava/security/AlgorithmConstraints;
9: getstatic java.security.CryptoPrimitive.KEY_AGREEMENT:Ljava/security/CryptoPrimitive;
invokestatic java.util.EnumSet.of:(Ljava/lang/Enum;)Ljava/util/EnumSet;
10: aload 3
getfield sun.security.ssl.ProtocolVersion.name:Ljava/lang/String;
aconst_null
11: invokeinterface java.security.AlgorithmConstraints.permits:(Ljava/util/Set;Ljava/lang/String;Ljava/security/AlgorithmParameters;)Z
12: ifne 18
13: getstatic sun.security.ssl.Handshaker.debug:Lsun/security/ssl/Debug;
ifnull 40
ldc "verbose"
invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
ifeq 40
14: getstatic java.lang.System.out:Ljava/io/PrintStream;
15: new java.lang.StringBuilder
dup
ldc "Ignoring disabled protocol: "
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;
16: invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
17: goto 40
18: StackMap locals:
StackMap stack:
iconst_0
istore 5
start local 5 19: new java.util.EnumMap
dup
ldc Lsun/security/ssl/NamedGroupType;
invokespecial java.util.EnumMap.<init>:(Ljava/lang/Class;)V
20: astore 6
start local 6 21: aload 0
getfield sun.security.ssl.Handshaker.enabledCipherSuites:Lsun/security/ssl/CipherSuiteList;
invokevirtual sun.security.ssl.CipherSuiteList.collection:()Ljava/util/Collection;
invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
astore 8
goto 35
StackMap locals: sun.security.ssl.Handshaker int java.util.ArrayList sun.security.ssl.ProtocolVersion java.util.Iterator int java.util.Map top java.util.Iterator
StackMap stack:
22: aload 8
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast sun.security.ssl.CipherSuite
astore 7
start local 7 23: aload 7
invokevirtual sun.security.ssl.CipherSuite.isAvailable:()Z
ifeq 29
aload 3
aload 7
invokevirtual sun.security.ssl.ProtocolVersion.obsoletes:(Lsun/security/ssl/CipherSuite;)Z
ifne 29
24: aload 3
aload 7
invokevirtual sun.security.ssl.ProtocolVersion.supports:(Lsun/security/ssl/CipherSuite;)Z
ifeq 29
25: aload 0
aload 7
aload 6
invokevirtual sun.security.ssl.Handshaker.isActivatable:(Lsun/security/ssl/CipherSuite;Ljava/util/Map;)Z
ifeq 35
26: aload 2
aload 3
invokevirtual java.util.ArrayList.add:(Ljava/lang/Object;)Z
pop
27: iconst_1
istore 5
28: goto 36
29: StackMap locals: sun.security.ssl.Handshaker int java.util.ArrayList sun.security.ssl.ProtocolVersion java.util.Iterator int java.util.Map sun.security.ssl.CipherSuite java.util.Iterator
StackMap stack:
getstatic sun.security.ssl.Handshaker.debug:Lsun/security/ssl/Debug;
ifnull 35
ldc "verbose"
invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
ifeq 35
30: getstatic java.lang.System.out:Ljava/io/PrintStream;
31: new java.lang.StringBuilder
dup
ldc "Ignoring unsupported cipher suite: "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 7
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
32: ldc " for "
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
aload 3
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
33: invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
34: invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
end local 7 35: StackMap locals: sun.security.ssl.Handshaker int java.util.ArrayList sun.security.ssl.ProtocolVersion java.util.Iterator int java.util.Map top java.util.Iterator
StackMap stack:
aload 8
invokeinterface java.util.Iterator.hasNext:()Z
ifne 22
36: StackMap locals: sun.security.ssl.Handshaker int java.util.ArrayList sun.security.ssl.ProtocolVersion java.util.Iterator int java.util.Map
StackMap stack:
iload 5
ifne 40
getstatic sun.security.ssl.Handshaker.debug:Lsun/security/ssl/Debug;
ifnull 40
ldc "handshake"
invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
ifeq 40
37: getstatic java.lang.System.out:Ljava/io/PrintStream;
38: new java.lang.StringBuilder
dup
ldc "No available cipher suite for "
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;
39: invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
end local 6 end local 5 end local 3 40: StackMap locals: sun.security.ssl.Handshaker int java.util.ArrayList top java.util.Iterator
StackMap stack:
aload 4
invokeinterface java.util.Iterator.hasNext:()Z
ifne 4
41: aload 2
invokevirtual java.util.ArrayList.isEmpty:()Z
ifne 43
iload 1
ifeq 43
42: aload 2
getstatic sun.security.ssl.ProtocolVersion.SSL20Hello:Lsun/security/ssl/ProtocolVersion;
invokevirtual java.util.ArrayList.add:(Ljava/lang/Object;)Z
pop
43: StackMap locals: sun.security.ssl.Handshaker int java.util.ArrayList
StackMap stack:
aload 0
new sun.security.ssl.ProtocolList
dup
aload 2
invokespecial sun.security.ssl.ProtocolList.<init>:(Ljava/util/ArrayList;)V
putfield sun.security.ssl.Handshaker.activeProtocols:Lsun/security/ssl/ProtocolList;
end local 2 end local 1 44: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.ssl.Handshaker.activeProtocols:Lsun/security/ssl/ProtocolList;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 45 0 this Lsun/security/ssl/Handshaker;
2 44 1 enabledSSL20Hello Z
3 44 2 protocols Ljava/util/ArrayList<Lsun/security/ssl/ProtocolVersion;>;
5 40 3 protocol Lsun/security/ssl/ProtocolVersion;
19 40 5 found Z
21 40 6 cachedStatus Ljava/util/Map<Lsun/security/ssl/NamedGroupType;Ljava/lang/Boolean;>;
23 35 7 suite Lsun/security/ssl/CipherSuite;
private boolean isActivatable(sun.security.ssl.CipherSuite, java.util.Map<sun.security.ssl.NamedGroupType, java.lang.Boolean>);
descriptor: (Lsun/security/ssl/CipherSuite;Ljava/util/Map;)Z
flags: (0x0002) ACC_PRIVATE
Code:
stack=4, locals=6, args_size=3
start local 0 start local 1 start local 2 0: aload 0
getfield sun.security.ssl.Handshaker.algorithmConstraints:Ljava/security/AlgorithmConstraints;
1: getstatic java.security.CryptoPrimitive.KEY_AGREEMENT:Ljava/security/CryptoPrimitive;
invokestatic java.util.EnumSet.of:(Ljava/lang/Enum;)Ljava/util/EnumSet;
aload 1
getfield sun.security.ssl.CipherSuite.name:Ljava/lang/String;
aconst_null
2: invokeinterface java.security.AlgorithmConstraints.permits:(Ljava/util/Set;Ljava/lang/String;Ljava/security/AlgorithmParameters;)Z
3: ifeq 22
4: iconst_1
istore 3
start local 3 5: aload 1
getfield sun.security.ssl.CipherSuite.keyExchange:Lsun/security/ssl/CipherSuite$KeyExchange;
getfield sun.security.ssl.CipherSuite$KeyExchange.groupType:Lsun/security/ssl/NamedGroupType;
astore 4
start local 4 6: aload 4
getstatic sun.security.ssl.NamedGroupType.NAMED_GROUP_NONE:Lsun/security/ssl/NamedGroupType;
if_acmpeq 21
7: aload 2
aload 4
invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
checkcast java.lang.Boolean
astore 5
start local 5 8: aload 5
ifnonnull 15
9: aload 0
getfield sun.security.ssl.Handshaker.algorithmConstraints:Ljava/security/AlgorithmConstraints;
aload 4
10: invokestatic sun.security.ssl.SupportedGroupsExtension.isActivatable:(Ljava/security/AlgorithmConstraints;Lsun/security/ssl/NamedGroupType;)Z
istore 3
11: aload 2
aload 4
iload 3
invokestatic java.lang.Boolean.valueOf:(Z)Ljava/lang/Boolean;
invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
pop
12: iload 3
ifne 16
getstatic sun.security.ssl.Handshaker.debug:Lsun/security/ssl/Debug;
ifnull 16
ldc "verbose"
invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
ifeq 16
13: getstatic java.lang.System.out:Ljava/io/PrintStream;
ldc "No activated named group"
invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
14: goto 16
15: StackMap locals: int sun.security.ssl.NamedGroupType java.lang.Boolean
StackMap stack:
aload 5
invokevirtual java.lang.Boolean.booleanValue:()Z
istore 3
16: StackMap locals:
StackMap stack:
iload 3
ifne 20
getstatic sun.security.ssl.Handshaker.debug:Lsun/security/ssl/Debug;
ifnull 20
ldc "verbose"
invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
ifeq 20
17: getstatic java.lang.System.out:Ljava/io/PrintStream;
18: new java.lang.StringBuilder
dup
ldc "No active named group, ignore "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 1
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
19: invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
20: StackMap locals:
StackMap stack:
iload 3
ireturn
end local 5 21: StackMap locals:
StackMap stack:
iconst_1
ireturn
end local 4 end local 3 22: StackMap locals:
StackMap stack:
getstatic sun.security.ssl.Handshaker.debug:Lsun/security/ssl/Debug;
ifnull 24
ldc "verbose"
invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
ifeq 24
23: getstatic java.lang.System.out:Ljava/io/PrintStream;
new java.lang.StringBuilder
dup
ldc "Ignoring disabled cipher suite: "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 1
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
24: StackMap locals:
StackMap stack:
iconst_0
ireturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 25 0 this Lsun/security/ssl/Handshaker;
0 25 1 suite Lsun/security/ssl/CipherSuite;
0 25 2 cachedStatus Ljava/util/Map<Lsun/security/ssl/NamedGroupType;Ljava/lang/Boolean;>;
5 22 3 available Z
6 22 4 groupType Lsun/security/ssl/NamedGroupType;
8 21 5 checkedStatus Ljava/lang/Boolean;
Signature: (Lsun/security/ssl/CipherSuite;Ljava/util/Map<Lsun/security/ssl/NamedGroupType;Ljava/lang/Boolean;>;)Z
MethodParameters:
Name Flags
suite
cachedStatus
void setEnableSessionCreation(boolean);
descriptor: (Z)V
flags: (0x0000)
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
iload 1
putfield sun.security.ssl.Handshaker.enableNewSession:Z
1: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lsun/security/ssl/Handshaker;
0 2 1 newSessions Z
MethodParameters:
Name Flags
newSessions
sun.security.ssl.CipherBox newReadCipher();
descriptor: ()Lsun/security/ssl/CipherBox;
flags: (0x0000)
Code:
stack=6, locals=3, args_size=1
start local 0 0: aload 0
getfield sun.security.ssl.Handshaker.cipherSuite:Lsun/security/ssl/CipherSuite;
getfield sun.security.ssl.CipherSuite.cipher:Lsun/security/ssl/CipherSuite$BulkCipher;
astore 1
start local 1 1: aload 0
getfield sun.security.ssl.Handshaker.isClient:Z
ifeq 8
2: aload 1
aload 0
getfield sun.security.ssl.Handshaker.protocolVersion:Lsun/security/ssl/ProtocolVersion;
aload 0
getfield sun.security.ssl.Handshaker.svrWriteKey:Ljavax/crypto/SecretKey;
aload 0
getfield sun.security.ssl.Handshaker.svrWriteIV:Ljavax/crypto/spec/IvParameterSpec;
3: aload 0
getfield sun.security.ssl.Handshaker.sslContext:Lsun/security/ssl/SSLContextImpl;
invokevirtual sun.security.ssl.SSLContextImpl.getSecureRandom:()Ljava/security/SecureRandom;
iconst_0
4: invokevirtual sun.security.ssl.CipherSuite$BulkCipher.newCipher:(Lsun/security/ssl/ProtocolVersion;Ljavax/crypto/SecretKey;Ljavax/crypto/spec/IvParameterSpec;Ljava/security/SecureRandom;Z)Lsun/security/ssl/CipherBox;
astore 2
start local 2 5: aload 0
aconst_null
putfield sun.security.ssl.Handshaker.svrWriteKey:Ljavax/crypto/SecretKey;
6: aload 0
aconst_null
putfield sun.security.ssl.Handshaker.svrWriteIV:Ljavax/crypto/spec/IvParameterSpec;
7: goto 13
end local 2 8: StackMap locals: sun.security.ssl.CipherSuite$BulkCipher
StackMap stack:
aload 1
aload 0
getfield sun.security.ssl.Handshaker.protocolVersion:Lsun/security/ssl/ProtocolVersion;
aload 0
getfield sun.security.ssl.Handshaker.clntWriteKey:Ljavax/crypto/SecretKey;
aload 0
getfield sun.security.ssl.Handshaker.clntWriteIV:Ljavax/crypto/spec/IvParameterSpec;
9: aload 0
getfield sun.security.ssl.Handshaker.sslContext:Lsun/security/ssl/SSLContextImpl;
invokevirtual sun.security.ssl.SSLContextImpl.getSecureRandom:()Ljava/security/SecureRandom;
iconst_0
10: invokevirtual sun.security.ssl.CipherSuite$BulkCipher.newCipher:(Lsun/security/ssl/ProtocolVersion;Ljavax/crypto/SecretKey;Ljavax/crypto/spec/IvParameterSpec;Ljava/security/SecureRandom;Z)Lsun/security/ssl/CipherBox;
astore 2
start local 2 11: aload 0
aconst_null
putfield sun.security.ssl.Handshaker.clntWriteKey:Ljavax/crypto/SecretKey;
12: aload 0
aconst_null
putfield sun.security.ssl.Handshaker.clntWriteIV:Ljavax/crypto/spec/IvParameterSpec;
13: StackMap locals: sun.security.ssl.CipherBox
StackMap stack:
aload 2
areturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 14 0 this Lsun/security/ssl/Handshaker;
1 14 1 cipher Lsun/security/ssl/CipherSuite$BulkCipher;
5 8 2 box Lsun/security/ssl/CipherBox;
11 14 2 box Lsun/security/ssl/CipherBox;
Exceptions:
throws java.security.NoSuchAlgorithmException
sun.security.ssl.CipherBox newWriteCipher();
descriptor: ()Lsun/security/ssl/CipherBox;
flags: (0x0000)
Code:
stack=6, locals=3, args_size=1
start local 0 0: aload 0
getfield sun.security.ssl.Handshaker.cipherSuite:Lsun/security/ssl/CipherSuite;
getfield sun.security.ssl.CipherSuite.cipher:Lsun/security/ssl/CipherSuite$BulkCipher;
astore 1
start local 1 1: aload 0
getfield sun.security.ssl.Handshaker.isClient:Z
ifeq 8
2: aload 1
aload 0
getfield sun.security.ssl.Handshaker.protocolVersion:Lsun/security/ssl/ProtocolVersion;
aload 0
getfield sun.security.ssl.Handshaker.clntWriteKey:Ljavax/crypto/SecretKey;
aload 0
getfield sun.security.ssl.Handshaker.clntWriteIV:Ljavax/crypto/spec/IvParameterSpec;
3: aload 0
getfield sun.security.ssl.Handshaker.sslContext:Lsun/security/ssl/SSLContextImpl;
invokevirtual sun.security.ssl.SSLContextImpl.getSecureRandom:()Ljava/security/SecureRandom;
iconst_1
4: invokevirtual sun.security.ssl.CipherSuite$BulkCipher.newCipher:(Lsun/security/ssl/ProtocolVersion;Ljavax/crypto/SecretKey;Ljavax/crypto/spec/IvParameterSpec;Ljava/security/SecureRandom;Z)Lsun/security/ssl/CipherBox;
astore 2
start local 2 5: aload 0
aconst_null
putfield sun.security.ssl.Handshaker.clntWriteKey:Ljavax/crypto/SecretKey;
6: aload 0
aconst_null
putfield sun.security.ssl.Handshaker.clntWriteIV:Ljavax/crypto/spec/IvParameterSpec;
7: goto 13
end local 2 8: StackMap locals: sun.security.ssl.CipherSuite$BulkCipher
StackMap stack:
aload 1
aload 0
getfield sun.security.ssl.Handshaker.protocolVersion:Lsun/security/ssl/ProtocolVersion;
aload 0
getfield sun.security.ssl.Handshaker.svrWriteKey:Ljavax/crypto/SecretKey;
aload 0
getfield sun.security.ssl.Handshaker.svrWriteIV:Ljavax/crypto/spec/IvParameterSpec;
9: aload 0
getfield sun.security.ssl.Handshaker.sslContext:Lsun/security/ssl/SSLContextImpl;
invokevirtual sun.security.ssl.SSLContextImpl.getSecureRandom:()Ljava/security/SecureRandom;
iconst_1
10: invokevirtual sun.security.ssl.CipherSuite$BulkCipher.newCipher:(Lsun/security/ssl/ProtocolVersion;Ljavax/crypto/SecretKey;Ljavax/crypto/spec/IvParameterSpec;Ljava/security/SecureRandom;Z)Lsun/security/ssl/CipherBox;
astore 2
start local 2 11: aload 0
aconst_null
putfield sun.security.ssl.Handshaker.svrWriteKey:Ljavax/crypto/SecretKey;
12: aload 0
aconst_null
putfield sun.security.ssl.Handshaker.svrWriteIV:Ljavax/crypto/spec/IvParameterSpec;
13: StackMap locals: sun.security.ssl.CipherBox
StackMap stack:
aload 2
areturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 14 0 this Lsun/security/ssl/Handshaker;
1 14 1 cipher Lsun/security/ssl/CipherSuite$BulkCipher;
5 8 2 box Lsun/security/ssl/CipherBox;
11 14 2 box Lsun/security/ssl/CipherBox;
Exceptions:
throws java.security.NoSuchAlgorithmException
sun.security.ssl.Authenticator newReadAuthenticator();
descriptor: ()Lsun/security/ssl/Authenticator;
flags: (0x0000)
Code:
stack=3, locals=3, args_size=1
start local 0 0: aconst_null
astore 1
start local 1 1: aload 0
getfield sun.security.ssl.Handshaker.cipherSuite:Lsun/security/ssl/CipherSuite;
getfield sun.security.ssl.CipherSuite.cipher:Lsun/security/ssl/CipherSuite$BulkCipher;
getfield sun.security.ssl.CipherSuite$BulkCipher.cipherType:Lsun/security/ssl/CipherSuite$CipherType;
getstatic sun.security.ssl.CipherSuite$CipherType.AEAD_CIPHER:Lsun/security/ssl/CipherSuite$CipherType;
if_acmpne 4
2: new sun.security.ssl.Authenticator
dup
aload 0
getfield sun.security.ssl.Handshaker.protocolVersion:Lsun/security/ssl/ProtocolVersion;
invokespecial sun.security.ssl.Authenticator.<init>:(Lsun/security/ssl/ProtocolVersion;)V
astore 1
3: goto 11
4: StackMap locals: sun.security.ssl.Authenticator
StackMap stack:
aload 0
getfield sun.security.ssl.Handshaker.cipherSuite:Lsun/security/ssl/CipherSuite;
getfield sun.security.ssl.CipherSuite.macAlg:Lsun/security/ssl/CipherSuite$MacAlg;
astore 2
start local 2 5: aload 0
getfield sun.security.ssl.Handshaker.isClient:Z
ifeq 9
6: aload 2
aload 0
getfield sun.security.ssl.Handshaker.protocolVersion:Lsun/security/ssl/ProtocolVersion;
aload 0
getfield sun.security.ssl.Handshaker.svrMacSecret:Ljavax/crypto/SecretKey;
invokevirtual sun.security.ssl.CipherSuite$MacAlg.newMac:(Lsun/security/ssl/ProtocolVersion;Ljavax/crypto/SecretKey;)Lsun/security/ssl/MAC;
astore 1
7: aload 0
aconst_null
putfield sun.security.ssl.Handshaker.svrMacSecret:Ljavax/crypto/SecretKey;
8: goto 11
9: StackMap locals: sun.security.ssl.CipherSuite$MacAlg
StackMap stack:
aload 2
aload 0
getfield sun.security.ssl.Handshaker.protocolVersion:Lsun/security/ssl/ProtocolVersion;
aload 0
getfield sun.security.ssl.Handshaker.clntMacSecret:Ljavax/crypto/SecretKey;
invokevirtual sun.security.ssl.CipherSuite$MacAlg.newMac:(Lsun/security/ssl/ProtocolVersion;Ljavax/crypto/SecretKey;)Lsun/security/ssl/MAC;
astore 1
10: aload 0
aconst_null
putfield sun.security.ssl.Handshaker.clntMacSecret:Ljavax/crypto/SecretKey;
end local 2 11: StackMap locals:
StackMap stack:
aload 1
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 12 0 this Lsun/security/ssl/Handshaker;
1 12 1 authenticator Lsun/security/ssl/Authenticator;
5 11 2 macAlg Lsun/security/ssl/CipherSuite$MacAlg;
Exceptions:
throws java.security.NoSuchAlgorithmException, java.security.InvalidKeyException
sun.security.ssl.Authenticator newWriteAuthenticator();
descriptor: ()Lsun/security/ssl/Authenticator;
flags: (0x0000)
Code:
stack=3, locals=3, args_size=1
start local 0 0: aconst_null
astore 1
start local 1 1: aload 0
getfield sun.security.ssl.Handshaker.cipherSuite:Lsun/security/ssl/CipherSuite;
getfield sun.security.ssl.CipherSuite.cipher:Lsun/security/ssl/CipherSuite$BulkCipher;
getfield sun.security.ssl.CipherSuite$BulkCipher.cipherType:Lsun/security/ssl/CipherSuite$CipherType;
getstatic sun.security.ssl.CipherSuite$CipherType.AEAD_CIPHER:Lsun/security/ssl/CipherSuite$CipherType;
if_acmpne 4
2: new sun.security.ssl.Authenticator
dup
aload 0
getfield sun.security.ssl.Handshaker.protocolVersion:Lsun/security/ssl/ProtocolVersion;
invokespecial sun.security.ssl.Authenticator.<init>:(Lsun/security/ssl/ProtocolVersion;)V
astore 1
3: goto 11
4: StackMap locals: sun.security.ssl.Authenticator
StackMap stack:
aload 0
getfield sun.security.ssl.Handshaker.cipherSuite:Lsun/security/ssl/CipherSuite;
getfield sun.security.ssl.CipherSuite.macAlg:Lsun/security/ssl/CipherSuite$MacAlg;
astore 2
start local 2 5: aload 0
getfield sun.security.ssl.Handshaker.isClient:Z
ifeq 9
6: aload 2
aload 0
getfield sun.security.ssl.Handshaker.protocolVersion:Lsun/security/ssl/ProtocolVersion;
aload 0
getfield sun.security.ssl.Handshaker.clntMacSecret:Ljavax/crypto/SecretKey;
invokevirtual sun.security.ssl.CipherSuite$MacAlg.newMac:(Lsun/security/ssl/ProtocolVersion;Ljavax/crypto/SecretKey;)Lsun/security/ssl/MAC;
astore 1
7: aload 0
aconst_null
putfield sun.security.ssl.Handshaker.clntMacSecret:Ljavax/crypto/SecretKey;
8: goto 11
9: StackMap locals: sun.security.ssl.CipherSuite$MacAlg
StackMap stack:
aload 2
aload 0
getfield sun.security.ssl.Handshaker.protocolVersion:Lsun/security/ssl/ProtocolVersion;
aload 0
getfield sun.security.ssl.Handshaker.svrMacSecret:Ljavax/crypto/SecretKey;
invokevirtual sun.security.ssl.CipherSuite$MacAlg.newMac:(Lsun/security/ssl/ProtocolVersion;Ljavax/crypto/SecretKey;)Lsun/security/ssl/MAC;
astore 1
10: aload 0
aconst_null
putfield sun.security.ssl.Handshaker.svrMacSecret:Ljavax/crypto/SecretKey;
end local 2 11: StackMap locals:
StackMap stack:
aload 1
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 12 0 this Lsun/security/ssl/Handshaker;
1 12 1 authenticator Lsun/security/ssl/Authenticator;
5 11 2 macAlg Lsun/security/ssl/CipherSuite$MacAlg;
Exceptions:
throws java.security.NoSuchAlgorithmException, java.security.InvalidKeyException
boolean isDone();
descriptor: ()Z
flags: (0x0000)
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
invokevirtual sun.security.ssl.Handshaker.started:()Z
ifeq 1
aload 0
getfield sun.security.ssl.Handshaker.handshakeState:Lsun/security/ssl/HandshakeStateManager;
invokevirtual sun.security.ssl.HandshakeStateManager.isEmpty:()Z
ifeq 1
aload 0
getfield sun.security.ssl.Handshaker.handshakeFinished:Z
ifeq 1
iconst_1
ireturn
StackMap locals:
StackMap stack:
1: iconst_0
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lsun/security/ssl/Handshaker;
sun.security.ssl.SSLSessionImpl getSession();
descriptor: ()Lsun/security/ssl/SSLSessionImpl;
flags: (0x0000)
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield sun.security.ssl.Handshaker.session:Lsun/security/ssl/SSLSessionImpl;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lsun/security/ssl/Handshaker;
void setHandshakeSessionSE(sun.security.ssl.SSLSessionImpl);
descriptor: (Lsun/security/ssl/SSLSessionImpl;)V
flags: (0x0000)
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
ifnull 3
1: aload 0
getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
aload 1
invokevirtual sun.security.ssl.SSLSocketImpl.setHandshakeSession:(Lsun/security/ssl/SSLSessionImpl;)V
2: goto 4
3: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.ssl.Handshaker.engine:Lsun/security/ssl/SSLEngineImpl;
aload 1
invokevirtual sun.security.ssl.SSLEngineImpl.setHandshakeSession:(Lsun/security/ssl/SSLSessionImpl;)V
4: StackMap locals:
StackMap stack:
return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 5 0 this Lsun/security/ssl/Handshaker;
0 5 1 handshakeSession Lsun/security/ssl/SSLSessionImpl;
MethodParameters:
Name Flags
handshakeSession
void expectingFinishFlightSE();
descriptor: ()V
flags: (0x0000)
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
ifnull 3
1: aload 0
getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
invokevirtual sun.security.ssl.SSLSocketImpl.expectingFinishFlight:()V
2: goto 4
3: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.ssl.Handshaker.engine:Lsun/security/ssl/SSLEngineImpl;
invokevirtual sun.security.ssl.SSLEngineImpl.expectingFinishFlight:()V
4: StackMap locals:
StackMap stack:
return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 5 0 this Lsun/security/ssl/Handshaker;
boolean isSecureRenegotiation();
descriptor: ()Z
flags: (0x0000)
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield sun.security.ssl.Handshaker.secureRenegotiation:Z
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lsun/security/ssl/Handshaker;
byte[] getClientVerifyData();
descriptor: ()[B
flags: (0x0000)
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield sun.security.ssl.Handshaker.clientVerifyData:[B
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lsun/security/ssl/Handshaker;
byte[] getServerVerifyData();
descriptor: ()[B
flags: (0x0000)
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield sun.security.ssl.Handshaker.serverVerifyData:[B
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lsun/security/ssl/Handshaker;
void processRecord(java.nio.ByteBuffer, boolean);
descriptor: (Ljava/nio/ByteBuffer;Z)V
flags: (0x0000)
Code:
stack=4, locals=3, args_size=3
start local 0 start local 1 start local 2 0: aload 0
invokevirtual sun.security.ssl.Handshaker.checkThrown:()V
1: aload 0
getfield sun.security.ssl.Handshaker.input:Lsun/security/ssl/HandshakeInStream;
aload 1
invokevirtual sun.security.ssl.HandshakeInStream.incomingRecord:(Ljava/nio/ByteBuffer;)V
2: aload 0
getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
ifnonnull 3
iload 2
ifeq 5
3: StackMap locals:
StackMap stack:
aload 0
invokevirtual sun.security.ssl.Handshaker.processLoop:()V
4: goto 6
5: StackMap locals:
StackMap stack:
aload 0
new sun.security.ssl.Handshaker$1
dup
aload 0
invokespecial sun.security.ssl.Handshaker$1.<init>:(Lsun/security/ssl/Handshaker;)V
invokevirtual sun.security.ssl.Handshaker.delegateTask:(Ljava/security/PrivilegedExceptionAction;)V
6: StackMap locals:
StackMap stack:
return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 7 0 this Lsun/security/ssl/Handshaker;
0 7 1 record Ljava/nio/ByteBuffer;
0 7 2 expectingFinished Z
Exceptions:
throws java.io.IOException
MethodParameters:
Name Flags
record
expectingFinished
void processLoop();
descriptor: ()V
flags: (0x0000)
Code:
stack=5, locals=3, args_size=1
start local 0 0: goto 22
1: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.ssl.Handshaker.input:Lsun/security/ssl/HandshakeInStream;
iconst_4
invokevirtual sun.security.ssl.HandshakeInStream.mark:(I)V
2: aload 0
getfield sun.security.ssl.Handshaker.input:Lsun/security/ssl/HandshakeInStream;
invokevirtual sun.security.ssl.HandshakeInStream.getInt8:()I
i2b
istore 1
start local 1 3: iload 1
invokestatic sun.security.ssl.HandshakeMessage.isUnsupported:(B)Z
ifeq 9
4: new javax.net.ssl.SSLProtocolException
dup
5: new java.lang.StringBuilder
dup
ldc "Received unsupported or unknown handshake message: "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
6: iload 1
invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
7: invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
8: invokespecial javax.net.ssl.SSLProtocolException.<init>:(Ljava/lang/String;)V
athrow
9: StackMap locals: int
StackMap stack:
aload 0
getfield sun.security.ssl.Handshaker.input:Lsun/security/ssl/HandshakeInStream;
invokevirtual sun.security.ssl.HandshakeInStream.getInt24:()I
istore 2
start local 2 10: aload 0
getfield sun.security.ssl.Handshaker.input:Lsun/security/ssl/HandshakeInStream;
invokevirtual sun.security.ssl.HandshakeInStream.available:()I
iload 2
if_icmpge 13
11: aload 0
getfield sun.security.ssl.Handshaker.input:Lsun/security/ssl/HandshakeInStream;
invokevirtual sun.security.ssl.HandshakeInStream.reset:()V
12: return
13: StackMap locals: int
StackMap stack:
iload 1
iconst_1
if_icmpne 16
14: aload 0
iconst_1
putfield sun.security.ssl.Handshaker.clientHelloDelivered:Z
15: goto 18
StackMap locals:
StackMap stack:
16: iload 1
ifne 18
17: aload 0
iconst_1
putfield sun.security.ssl.Handshaker.serverHelloRequested:Z
18: StackMap locals:
StackMap stack:
aload 0
iload 1
iload 2
invokevirtual sun.security.ssl.Handshaker.processMessage:(BI)V
19: iload 1
bipush 20
if_icmpeq 21
20: iload 1
bipush 15
if_icmpne 22
21: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.ssl.Handshaker.handshakeHash:Lsun/security/ssl/HandshakeHash;
invokevirtual sun.security.ssl.HandshakeHash.reload:()V
end local 2 end local 1 22: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.ssl.Handshaker.input:Lsun/security/ssl/HandshakeInStream;
invokevirtual sun.security.ssl.HandshakeInStream.available:()I
iconst_4
if_icmpge 1
23: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 24 0 this Lsun/security/ssl/Handshaker;
3 22 1 messageType B
10 22 2 messageLen I
Exceptions:
throws java.io.IOException
boolean activated();
descriptor: ()Z
flags: (0x0000)
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield sun.security.ssl.Handshaker.handshakeActivated:Z
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lsun/security/ssl/Handshaker;
boolean started();
descriptor: ()Z
flags: (0x0000)
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield sun.security.ssl.Handshaker.serverHelloRequested:Z
ifne 1
aload 0
getfield sun.security.ssl.Handshaker.clientHelloDelivered:Z
ifne 1
iconst_0
ireturn
StackMap locals:
StackMap stack:
1: iconst_1
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lsun/security/ssl/Handshaker;
void kickstart();
descriptor: ()V
flags: (0x0000)
Code:
stack=3, locals=3, args_size=1
start local 0 0: aload 0
getfield sun.security.ssl.Handshaker.isClient:Z
ifeq 1
aload 0
getfield sun.security.ssl.Handshaker.clientHelloDelivered:Z
ifne 2
1: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.ssl.Handshaker.isClient:Z
ifne 3
aload 0
getfield sun.security.ssl.Handshaker.serverHelloRequested:Z
ifeq 3
2: StackMap locals:
StackMap stack:
return
3: StackMap locals:
StackMap stack:
aload 0
invokevirtual sun.security.ssl.Handshaker.getKickstartMessage:()Lsun/security/ssl/HandshakeMessage;
astore 1
start local 1 4: aload 0
getfield sun.security.ssl.Handshaker.handshakeState:Lsun/security/ssl/HandshakeStateManager;
aload 1
aload 0
getfield sun.security.ssl.Handshaker.resumingSession:Z
invokevirtual sun.security.ssl.HandshakeStateManager.update:(Lsun/security/ssl/HandshakeMessage;Z)V
5: getstatic sun.security.ssl.Handshaker.debug:Lsun/security/ssl/Debug;
ifnull 7
ldc "handshake"
invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
ifeq 7
6: aload 1
getstatic java.lang.System.out:Ljava/io/PrintStream;
invokevirtual sun.security.ssl.HandshakeMessage.print:(Ljava/io/PrintStream;)V
7: StackMap locals: sun.security.ssl.HandshakeMessage
StackMap stack:
aload 1
aload 0
getfield sun.security.ssl.Handshaker.output:Lsun/security/ssl/HandshakeOutStream;
invokevirtual sun.security.ssl.HandshakeMessage.write:(Lsun/security/ssl/HandshakeOutStream;)V
8: aload 0
getfield sun.security.ssl.Handshaker.output:Lsun/security/ssl/HandshakeOutStream;
invokevirtual sun.security.ssl.HandshakeOutStream.flush:()V
9: aload 1
invokevirtual sun.security.ssl.HandshakeMessage.messageType:()I
istore 2
start local 2 10: iload 2
ifne 13
11: aload 0
iconst_1
putfield sun.security.ssl.Handshaker.serverHelloRequested:Z
12: goto 14
13: StackMap locals: int
StackMap stack:
aload 0
iconst_1
putfield sun.security.ssl.Handshaker.clientHelloDelivered:Z
14: StackMap locals:
StackMap stack:
return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 15 0 this Lsun/security/ssl/Handshaker;
4 15 1 m Lsun/security/ssl/HandshakeMessage;
10 15 2 handshakeType I
Exceptions:
throws java.io.IOException
abstract sun.security.ssl.HandshakeMessage getKickstartMessage();
descriptor: ()Lsun/security/ssl/HandshakeMessage;
flags: (0x0400) ACC_ABSTRACT
Exceptions:
throws javax.net.ssl.SSLException
abstract void processMessage(byte, int);
descriptor: (BI)V
flags: (0x0400) ACC_ABSTRACT
Exceptions:
throws java.io.IOException
MethodParameters:
Name Flags
messageType
messageLen
abstract void handshakeAlert(byte);
descriptor: (B)V
flags: (0x0400) ACC_ABSTRACT
Exceptions:
throws javax.net.ssl.SSLProtocolException
MethodParameters:
Name Flags
description
void sendChangeCipherSpec(sun.security.ssl.HandshakeMessage$Finished, boolean);
descriptor: (Lsun/security/ssl/HandshakeMessage$Finished;Z)V
flags: (0x0000)
Code:
stack=3, locals=4, args_size=3
start local 0 start local 1 start local 2 0: aload 0
getfield sun.security.ssl.Handshaker.output:Lsun/security/ssl/HandshakeOutStream;
invokevirtual sun.security.ssl.HandshakeOutStream.flush:()V
1: aload 0
getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
ifnull 16
2: aload 0
getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
getfield sun.security.ssl.SSLSocketImpl.writeLock:Ljava/util/concurrent/locks/ReentrantLock;
invokevirtual java.util.concurrent.locks.ReentrantLock.lock:()V
3: aload 0
getfield sun.security.ssl.Handshaker.handshakeState:Lsun/security/ssl/HandshakeStateManager;
iconst_0
aload 0
getfield sun.security.ssl.Handshaker.isClient:Z
invokevirtual sun.security.ssl.HandshakeStateManager.changeCipherSpec:(ZZ)V
4: aload 0
getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
invokevirtual sun.security.ssl.SSLSocketImpl.changeWriteCiphers:()V
5: getstatic sun.security.ssl.Handshaker.debug:Lsun/security/ssl/Debug;
ifnull 7
ldc "handshake"
invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
ifeq 7
6: aload 1
getstatic java.lang.System.out:Ljava/io/PrintStream;
invokevirtual sun.security.ssl.HandshakeMessage$Finished.print:(Ljava/io/PrintStream;)V
7: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.ssl.Handshaker.handshakeState:Lsun/security/ssl/HandshakeStateManager;
aload 1
aload 0
getfield sun.security.ssl.Handshaker.resumingSession:Z
invokevirtual sun.security.ssl.HandshakeStateManager.update:(Lsun/security/ssl/HandshakeMessage;Z)V
8: aload 1
aload 0
getfield sun.security.ssl.Handshaker.output:Lsun/security/ssl/HandshakeOutStream;
invokevirtual sun.security.ssl.HandshakeMessage$Finished.write:(Lsun/security/ssl/HandshakeOutStream;)V
9: aload 0
getfield sun.security.ssl.Handshaker.output:Lsun/security/ssl/HandshakeOutStream;
invokevirtual sun.security.ssl.HandshakeOutStream.flush:()V
10: goto 14
StackMap locals:
StackMap stack: java.lang.Throwable
11: astore 3
12: aload 0
getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
getfield sun.security.ssl.SSLSocketImpl.writeLock:Ljava/util/concurrent/locks/ReentrantLock;
invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
13: aload 3
athrow
14: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.ssl.Handshaker.conn:Lsun/security/ssl/SSLSocketImpl;
getfield sun.security.ssl.SSLSocketImpl.writeLock:Ljava/util/concurrent/locks/ReentrantLock;
invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
15: goto 28
16: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.ssl.Handshaker.engine:Lsun/security/ssl/SSLEngineImpl;
getfield sun.security.ssl.SSLEngineImpl.writeLock:Ljava/lang/Object;
dup
astore 3
monitorenter
17: aload 0
getfield sun.security.ssl.Handshaker.handshakeState:Lsun/security/ssl/HandshakeStateManager;
iconst_0
aload 0
getfield sun.security.ssl.Handshaker.isClient:Z
invokevirtual sun.security.ssl.HandshakeStateManager.changeCipherSpec:(ZZ)V
18: aload 0
getfield sun.security.ssl.Handshaker.engine:Lsun/security/ssl/SSLEngineImpl;
invokevirtual sun.security.ssl.SSLEngineImpl.changeWriteCiphers:()V
19: getstatic sun.security.ssl.Handshaker.debug:Lsun/security/ssl/Debug;
ifnull 21
ldc "handshake"
invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
ifeq 21
20: aload 1
getstatic java.lang.System.out:Ljava/io/PrintStream;
invokevirtual sun.security.ssl.HandshakeMessage$Finished.print:(Ljava/io/PrintStream;)V
21: StackMap locals: java.lang.Object
StackMap stack:
aload 0
getfield sun.security.ssl.Handshaker.handshakeState:Lsun/security/ssl/HandshakeStateManager;
aload 1
aload 0
getfield sun.security.ssl.Handshaker.resumingSession:Z
invokevirtual sun.security.ssl.HandshakeStateManager.update:(Lsun/security/ssl/HandshakeMessage;Z)V
22: aload 1
aload 0
getfield sun.security.ssl.Handshaker.output:Lsun/security/ssl/HandshakeOutStream;
invokevirtual sun.security.ssl.HandshakeMessage$Finished.write:(Lsun/security/ssl/HandshakeOutStream;)V
23: aload 0
getfield sun.security.ssl.Handshaker.output:Lsun/security/ssl/HandshakeOutStream;
invokevirtual sun.security.ssl.HandshakeOutStream.flush:()V
24: aload 3
monitorexit
25: goto 28
StackMap locals:
StackMap stack: java.lang.Throwable
26: aload 3
monitorexit
27: athrow
28: StackMap locals:
StackMap stack:
iload 2
ifeq 30
29: aload 0
iconst_1
putfield sun.security.ssl.Handshaker.handshakeFinished:Z
30: StackMap locals:
StackMap stack:
return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 31 0 this Lsun/security/ssl/Handshaker;
0 31 1 mesg Lsun/security/ssl/HandshakeMessage$Finished;
0 31 2 lastMessage Z
Exception table:
from to target type
3 11 11 any
17 25 26 any
26 27 26 any
Exceptions:
throws java.io.IOException
MethodParameters:
Name Flags
mesg
lastMessage
void receiveChangeCipherSpec();
descriptor: ()V
flags: (0x0000)
Code:
stack=3, locals=1, args_size=1
start local 0 0: aload 0
getfield sun.security.ssl.Handshaker.handshakeState:Lsun/security/ssl/HandshakeStateManager;
iconst_1
aload 0
getfield sun.security.ssl.Handshaker.isClient:Z
invokevirtual sun.security.ssl.HandshakeStateManager.changeCipherSpec:(ZZ)V
1: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lsun/security/ssl/Handshaker;
Exceptions:
throws java.io.IOException
void calculateKeys(javax.crypto.SecretKey, sun.security.ssl.ProtocolVersion);
descriptor: (Ljavax/crypto/SecretKey;Lsun/security/ssl/ProtocolVersion;)V
flags: (0x0000)
Code:
stack=3, locals=4, args_size=3
start local 0 start local 1 start local 2 0: aload 0
aload 1
aload 2
invokevirtual sun.security.ssl.Handshaker.calculateMasterSecret:(Ljavax/crypto/SecretKey;Lsun/security/ssl/ProtocolVersion;)Ljavax/crypto/SecretKey;
astore 3
start local 3 1: aload 0
getfield sun.security.ssl.Handshaker.session:Lsun/security/ssl/SSLSessionImpl;
aload 3
invokevirtual sun.security.ssl.SSLSessionImpl.setMasterSecret:(Ljavax/crypto/SecretKey;)V
2: aload 0
aload 3
invokevirtual sun.security.ssl.Handshaker.calculateConnectionKeys:(Ljavax/crypto/SecretKey;)V
3: return
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lsun/security/ssl/Handshaker;
0 4 1 preMasterSecret Ljavax/crypto/SecretKey;
0 4 2 version Lsun/security/ssl/ProtocolVersion;
1 4 3 master Ljavax/crypto/SecretKey;
MethodParameters:
Name Flags
preMasterSecret
version
private javax.crypto.SecretKey calculateMasterSecret(javax.crypto.SecretKey, sun.security.ssl.ProtocolVersion);
descriptor: (Ljavax/crypto/SecretKey;Lsun/security/ssl/ProtocolVersion;)Ljavax/crypto/SecretKey;
flags: (0x0002) ACC_PRIVATE
Code:
stack=10, locals=13, args_size=3
start local 0 start local 1 start local 2 0: getstatic sun.security.ssl.Handshaker.debug:Lsun/security/ssl/Debug;
ifnull 5
ldc "keygen"
invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
ifeq 5
1: new sun.security.util.HexDumpEncoder
dup
invokespecial sun.security.util.HexDumpEncoder.<init>:()V
astore 3
start local 3 2: getstatic java.lang.System.out:Ljava/io/PrintStream;
ldc "SESSION KEYGEN:"
invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
3: getstatic java.lang.System.out:Ljava/io/PrintStream;
ldc "PreMaster Secret:"
invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
4: aload 3
aload 1
invokeinterface javax.crypto.SecretKey.getEncoded:()[B
invokestatic sun.security.ssl.Handshaker.printHex:(Lsun/security/util/HexDumpEncoder;[B)V
end local 3 5: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.ssl.Handshaker.protocolVersion:Lsun/security/ssl/ProtocolVersion;
getfield sun.security.ssl.ProtocolVersion.major:B
istore 5
start local 5 6: aload 0
getfield sun.security.ssl.Handshaker.protocolVersion:Lsun/security/ssl/ProtocolVersion;
getfield sun.security.ssl.ProtocolVersion.minor:B
istore 6
start local 6 7: aload 0
getfield sun.security.ssl.Handshaker.protocolVersion:Lsun/security/ssl/ProtocolVersion;
invokevirtual sun.security.ssl.ProtocolVersion.isDTLSProtocol:()Z
ifeq 19
8: aload 0
getfield sun.security.ssl.Handshaker.protocolVersion:Lsun/security/ssl/ProtocolVersion;
getfield sun.security.ssl.ProtocolVersion.v:I
getstatic sun.security.ssl.ProtocolVersion.DTLS10:Lsun/security/ssl/ProtocolVersion;
getfield sun.security.ssl.ProtocolVersion.v:I
if_icmpne 14
9: getstatic sun.security.ssl.ProtocolVersion.TLS11:Lsun/security/ssl/ProtocolVersion;
getfield sun.security.ssl.ProtocolVersion.major:B
istore 5
10: getstatic sun.security.ssl.ProtocolVersion.TLS11:Lsun/security/ssl/ProtocolVersion;
getfield sun.security.ssl.ProtocolVersion.minor:B
istore 6
11: ldc "SunTlsMasterSecret"
astore 3
start local 3 12: getstatic sun.security.ssl.CipherSuite$PRF.P_NONE:Lsun/security/ssl/CipherSuite$PRF;
astore 4
start local 4 13: goto 25
end local 4 end local 3 14: StackMap locals: sun.security.ssl.Handshaker javax.crypto.SecretKey sun.security.ssl.ProtocolVersion top top int int
StackMap stack:
getstatic sun.security.ssl.ProtocolVersion.TLS12:Lsun/security/ssl/ProtocolVersion;
getfield sun.security.ssl.ProtocolVersion.major:B
istore 5
15: getstatic sun.security.ssl.ProtocolVersion.TLS12:Lsun/security/ssl/ProtocolVersion;
getfield sun.security.ssl.ProtocolVersion.minor:B
istore 6
16: ldc "SunTls12MasterSecret"
astore 3
start local 3 17: aload 0
getfield sun.security.ssl.Handshaker.cipherSuite:Lsun/security/ssl/CipherSuite;
getfield sun.security.ssl.CipherSuite.prfAlg:Lsun/security/ssl/CipherSuite$PRF;
astore 4
start local 4 18: goto 25
end local 4 end local 3 19: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.ssl.Handshaker.protocolVersion:Lsun/security/ssl/ProtocolVersion;
getfield sun.security.ssl.ProtocolVersion.v:I
getstatic sun.security.ssl.ProtocolVersion.TLS12:Lsun/security/ssl/ProtocolVersion;
getfield sun.security.ssl.ProtocolVersion.v:I
if_icmplt 23
20: ldc "SunTls12MasterSecret"
astore 3
start local 3 21: aload 0
getfield sun.security.ssl.Handshaker.cipherSuite:Lsun/security/ssl/CipherSuite;
getfield sun.security.ssl.CipherSuite.prfAlg:Lsun/security/ssl/CipherSuite$PRF;
astore 4
start local 4 22: goto 25
end local 4 end local 3 23: StackMap locals:
StackMap stack:
ldc "SunTlsMasterSecret"
astore 3
start local 3 24: getstatic sun.security.ssl.CipherSuite$PRF.P_NONE:Lsun/security/ssl/CipherSuite$PRF;
astore 4
start local 4 25: StackMap locals: sun.security.ssl.Handshaker javax.crypto.SecretKey sun.security.ssl.ProtocolVersion java.lang.String sun.security.ssl.CipherSuite$PRF int int
StackMap stack:
aload 4
invokevirtual sun.security.ssl.CipherSuite$PRF.getPRFHashAlg:()Ljava/lang/String;
astore 7
start local 7 26: aload 4
invokevirtual sun.security.ssl.CipherSuite$PRF.getPRFHashLength:()I
istore 8
start local 8 27: aload 4
invokevirtual sun.security.ssl.CipherSuite$PRF.getPRFBlockSize:()I
istore 9
start local 9 28: aload 0
getfield sun.security.ssl.Handshaker.session:Lsun/security/ssl/SSLSessionImpl;
invokevirtual sun.security.ssl.SSLSessionImpl.getUseExtendedMasterSecret:()Z
ifeq 47
29: ldc "SunTlsExtendedMasterSecret"
astore 3
30: aconst_null
astore 11
start local 11 31: aload 0
getfield sun.security.ssl.Handshaker.protocolVersion:Lsun/security/ssl/ProtocolVersion;
invokevirtual sun.security.ssl.ProtocolVersion.useTLS12PlusSpec:()Z
ifeq 34
32: aload 0
getfield sun.security.ssl.Handshaker.handshakeHash:Lsun/security/ssl/HandshakeHash;
invokevirtual sun.security.ssl.HandshakeHash.getFinishedHash:()[B
astore 11
33: goto 40
34: StackMap locals: sun.security.ssl.Handshaker javax.crypto.SecretKey sun.security.ssl.ProtocolVersion java.lang.String sun.security.ssl.CipherSuite$PRF int int java.lang.String int int top byte[]
StackMap stack:
bipush 36
newarray 8
astore 11
35: aload 0
getfield sun.security.ssl.Handshaker.handshakeHash:Lsun/security/ssl/HandshakeHash;
invokevirtual sun.security.ssl.HandshakeHash.getMD5Clone:()Ljava/security/MessageDigest;
aload 11
iconst_0
bipush 16
invokevirtual java.security.MessageDigest.digest:([BII)I
pop
36: aload 0
getfield sun.security.ssl.Handshaker.handshakeHash:Lsun/security/ssl/HandshakeHash;
invokevirtual sun.security.ssl.HandshakeHash.getSHAClone:()Ljava/security/MessageDigest;
aload 11
bipush 16
bipush 20
invokevirtual java.security.MessageDigest.digest:([BII)I
pop
37: goto 40
StackMap locals:
StackMap stack: java.security.DigestException
38: astore 12
start local 12 39: new java.security.ProviderException
dup
aload 12
invokespecial java.security.ProviderException.<init>:(Ljava/lang/Throwable;)V
athrow
end local 12 40: StackMap locals:
StackMap stack:
new sun.security.internal.spec.TlsMasterSecretParameterSpec
dup
41: aload 1
42: iload 5
sipush 255
iand
iload 6
sipush 255
iand
43: aload 11
44: aload 7
iload 8
iload 9
45: invokespecial sun.security.internal.spec.TlsMasterSecretParameterSpec.<init>:(Ljavax/crypto/SecretKey;II[BLjava/lang/String;II)V
astore 10
end local 11 start local 10 46: goto 53
end local 10 47: StackMap locals: sun.security.ssl.Handshaker javax.crypto.SecretKey sun.security.ssl.ProtocolVersion java.lang.String sun.security.ssl.CipherSuite$PRF int int java.lang.String int int
StackMap stack:
new sun.security.internal.spec.TlsMasterSecretParameterSpec
dup
48: aload 1
49: iload 5
sipush 255
iand
iload 6
sipush 255
iand
50: aload 0
getfield sun.security.ssl.Handshaker.clnt_random:Lsun/security/ssl/RandomCookie;
getfield sun.security.ssl.RandomCookie.random_bytes:[B
aload 0
getfield sun.security.ssl.Handshaker.svr_random:Lsun/security/ssl/RandomCookie;
getfield sun.security.ssl.RandomCookie.random_bytes:[B
51: aload 7
iload 8
iload 9
52: invokespecial sun.security.internal.spec.TlsMasterSecretParameterSpec.<init>:(Ljavax/crypto/SecretKey;II[B[BLjava/lang/String;II)V
astore 10
start local 10 53: StackMap locals: sun.security.internal.spec.TlsMasterSecretParameterSpec
StackMap stack:
aload 3
invokestatic sun.security.ssl.JsseJce.getKeyGenerator:(Ljava/lang/String;)Ljavax/crypto/KeyGenerator;
astore 11
start local 11 54: aload 11
aload 10
invokevirtual javax.crypto.KeyGenerator.init:(Ljava/security/spec/AlgorithmParameterSpec;)V
55: aload 11
invokevirtual javax.crypto.KeyGenerator.generateKey:()Ljavax/crypto/SecretKey;
56: areturn
end local 11 57: StackMap locals:
StackMap stack: java.security.GeneralSecurityException
astore 11
start local 11 58: getstatic sun.security.ssl.Handshaker.debug:Lsun/security/ssl/Debug;
ifnull 61
ldc "handshake"
invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
ifeq 61
59: getstatic java.lang.System.out:Ljava/io/PrintStream;
ldc "RSA master secret generation error:"
invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
60: aload 11
getstatic java.lang.System.out:Ljava/io/PrintStream;
invokevirtual java.security.GeneralSecurityException.printStackTrace:(Ljava/io/PrintStream;)V
61: StackMap locals: java.security.GeneralSecurityException
StackMap stack:
new java.security.ProviderException
dup
aload 11
invokespecial java.security.ProviderException.<init>:(Ljava/lang/Throwable;)V
athrow
end local 11 end local 10 end local 9 end local 8 end local 7 end local 6 end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 62 0 this Lsun/security/ssl/Handshaker;
0 62 1 preMasterSecret Ljavax/crypto/SecretKey;
0 62 2 requestedVersion Lsun/security/ssl/ProtocolVersion;
2 5 3 dump Lsun/security/util/HexDumpEncoder;
12 14 3 masterAlg Ljava/lang/String;
17 19 3 masterAlg Ljava/lang/String;
21 23 3 masterAlg Ljava/lang/String;
24 62 3 masterAlg Ljava/lang/String;
13 14 4 prf Lsun/security/ssl/CipherSuite$PRF;
18 19 4 prf Lsun/security/ssl/CipherSuite$PRF;
22 23 4 prf Lsun/security/ssl/CipherSuite$PRF;
25 62 4 prf Lsun/security/ssl/CipherSuite$PRF;
6 62 5 majorVersion B
7 62 6 minorVersion B
26 62 7 prfHashAlg Ljava/lang/String;
27 62 8 prfHashLength I
28 62 9 prfBlockSize I
46 47 10 spec Lsun/security/internal/spec/TlsMasterSecretParameterSpec;
53 62 10 spec Lsun/security/internal/spec/TlsMasterSecretParameterSpec;
31 46 11 sessionHash [B
39 40 12 de Ljava/security/DigestException;
54 57 11 kg Ljavax/crypto/KeyGenerator;
58 62 11 iae Ljava/security/GeneralSecurityException;
Exception table:
from to target type
35 37 38 Class java.security.DigestException
53 56 57 Class java.security.InvalidAlgorithmParameterException
53 56 57 Class java.security.NoSuchAlgorithmException
MethodParameters:
Name Flags
preMasterSecret
requestedVersion
void calculateConnectionKeys(javax.crypto.SecretKey);
descriptor: (Ljavax/crypto/SecretKey;)V
flags: (0x0000)
Code:
stack=15, locals=17, args_size=2
start local 0 start local 1 0: aload 0
getfield sun.security.ssl.Handshaker.cipherSuite:Lsun/security/ssl/CipherSuite;
getfield sun.security.ssl.CipherSuite.macAlg:Lsun/security/ssl/CipherSuite$MacAlg;
getfield sun.security.ssl.CipherSuite$MacAlg.size:I
istore 2
start local 2 1: aload 0
getfield sun.security.ssl.Handshaker.cipherSuite:Lsun/security/ssl/CipherSuite;
getfield sun.security.ssl.CipherSuite.exportable:Z
istore 3
start local 3 2: aload 0
getfield sun.security.ssl.Handshaker.cipherSuite:Lsun/security/ssl/CipherSuite;
getfield sun.security.ssl.CipherSuite.cipher:Lsun/security/ssl/CipherSuite$BulkCipher;
astore 4
start local 4 3: iload 3
ifeq 4
aload 4
getfield sun.security.ssl.CipherSuite$BulkCipher.expandedKeySize:I
goto 5
StackMap locals: int int sun.security.ssl.CipherSuite$BulkCipher
StackMap stack:
4: iconst_0
StackMap locals:
StackMap stack: int
5: istore 5
start local 5 6: aload 0
getfield sun.security.ssl.Handshaker.protocolVersion:Lsun/security/ssl/ProtocolVersion;
getfield sun.security.ssl.ProtocolVersion.major:B
istore 8
start local 8 7: aload 0
getfield sun.security.ssl.Handshaker.protocolVersion:Lsun/security/ssl/ProtocolVersion;
getfield sun.security.ssl.ProtocolVersion.minor:B
istore 9
start local 9 8: aload 0
getfield sun.security.ssl.Handshaker.protocolVersion:Lsun/security/ssl/ProtocolVersion;
invokevirtual sun.security.ssl.ProtocolVersion.isDTLSProtocol:()Z
ifeq 20
9: aload 0
getfield sun.security.ssl.Handshaker.protocolVersion:Lsun/security/ssl/ProtocolVersion;
getfield sun.security.ssl.ProtocolVersion.v:I
getstatic sun.security.ssl.ProtocolVersion.DTLS10:Lsun/security/ssl/ProtocolVersion;
getfield sun.security.ssl.ProtocolVersion.v:I
if_icmpne 15
10: getstatic sun.security.ssl.ProtocolVersion.TLS11:Lsun/security/ssl/ProtocolVersion;
getfield sun.security.ssl.ProtocolVersion.major:B
istore 8
11: getstatic sun.security.ssl.ProtocolVersion.TLS11:Lsun/security/ssl/ProtocolVersion;
getfield sun.security.ssl.ProtocolVersion.minor:B
istore 9
12: ldc "SunTlsKeyMaterial"
astore 6
start local 6 13: getstatic sun.security.ssl.CipherSuite$PRF.P_NONE:Lsun/security/ssl/CipherSuite$PRF;
astore 7
start local 7 14: goto 26
end local 7 end local 6 15: StackMap locals: sun.security.ssl.Handshaker javax.crypto.SecretKey int int sun.security.ssl.CipherSuite$BulkCipher int top top int int
StackMap stack:
getstatic sun.security.ssl.ProtocolVersion.TLS12:Lsun/security/ssl/ProtocolVersion;
getfield sun.security.ssl.ProtocolVersion.major:B
istore 8
16: getstatic sun.security.ssl.ProtocolVersion.TLS12:Lsun/security/ssl/ProtocolVersion;
getfield sun.security.ssl.ProtocolVersion.minor:B
istore 9
17: ldc "SunTls12KeyMaterial"
astore 6
start local 6 18: aload 0
getfield sun.security.ssl.Handshaker.cipherSuite:Lsun/security/ssl/CipherSuite;
getfield sun.security.ssl.CipherSuite.prfAlg:Lsun/security/ssl/CipherSuite$PRF;
astore 7
start local 7 19: goto 26
end local 7 end local 6 20: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.ssl.Handshaker.protocolVersion:Lsun/security/ssl/ProtocolVersion;
getfield sun.security.ssl.ProtocolVersion.v:I
getstatic sun.security.ssl.ProtocolVersion.TLS12:Lsun/security/ssl/ProtocolVersion;
getfield sun.security.ssl.ProtocolVersion.v:I
if_icmplt 24
21: ldc "SunTls12KeyMaterial"
astore 6
start local 6 22: aload 0
getfield sun.security.ssl.Handshaker.cipherSuite:Lsun/security/ssl/CipherSuite;
getfield sun.security.ssl.CipherSuite.prfAlg:Lsun/security/ssl/CipherSuite$PRF;
astore 7
start local 7 23: goto 26
end local 7 end local 6 24: StackMap locals:
StackMap stack:
ldc "SunTlsKeyMaterial"
astore 6
start local 6 25: getstatic sun.security.ssl.CipherSuite$PRF.P_NONE:Lsun/security/ssl/CipherSuite$PRF;
astore 7
start local 7 26: StackMap locals: sun.security.ssl.Handshaker javax.crypto.SecretKey int int sun.security.ssl.CipherSuite$BulkCipher int java.lang.String sun.security.ssl.CipherSuite$PRF int int
StackMap stack:
aload 7
invokevirtual sun.security.ssl.CipherSuite$PRF.getPRFHashAlg:()Ljava/lang/String;
astore 10
start local 10 27: aload 7
invokevirtual sun.security.ssl.CipherSuite$PRF.getPRFHashLength:()I
istore 11
start local 11 28: aload 7
invokevirtual sun.security.ssl.CipherSuite$PRF.getPRFBlockSize:()I
istore 12
start local 12 29: aload 4
getfield sun.security.ssl.CipherSuite$BulkCipher.ivSize:I
istore 13
start local 13 30: aload 4
getfield sun.security.ssl.CipherSuite$BulkCipher.cipherType:Lsun/security/ssl/CipherSuite$CipherType;
getstatic sun.security.ssl.CipherSuite$CipherType.AEAD_CIPHER:Lsun/security/ssl/CipherSuite$CipherType;
if_acmpne 33
31: aload 4
getfield sun.security.ssl.CipherSuite$BulkCipher.fixedIvSize:I
istore 13
32: goto 36
StackMap locals: sun.security.ssl.Handshaker javax.crypto.SecretKey int int sun.security.ssl.CipherSuite$BulkCipher int java.lang.String sun.security.ssl.CipherSuite$PRF int int java.lang.String int int int
StackMap stack:
33: aload 4
getfield sun.security.ssl.CipherSuite$BulkCipher.cipherType:Lsun/security/ssl/CipherSuite$CipherType;
getstatic sun.security.ssl.CipherSuite$CipherType.BLOCK_CIPHER:Lsun/security/ssl/CipherSuite$CipherType;
if_acmpne 36
34: aload 0
getfield sun.security.ssl.Handshaker.protocolVersion:Lsun/security/ssl/ProtocolVersion;
invokevirtual sun.security.ssl.ProtocolVersion.useTLS11PlusSpec:()Z
ifeq 36
35: iconst_0
istore 13
36: StackMap locals:
StackMap stack:
new sun.security.internal.spec.TlsKeyMaterialParameterSpec
dup
37: aload 1
iload 8
sipush 255
iand
iload 9
sipush 255
iand
38: aload 0
getfield sun.security.ssl.Handshaker.clnt_random:Lsun/security/ssl/RandomCookie;
getfield sun.security.ssl.RandomCookie.random_bytes:[B
aload 0
getfield sun.security.ssl.Handshaker.svr_random:Lsun/security/ssl/RandomCookie;
getfield sun.security.ssl.RandomCookie.random_bytes:[B
39: aload 4
getfield sun.security.ssl.CipherSuite$BulkCipher.algorithm:Ljava/lang/String;
aload 4
getfield sun.security.ssl.CipherSuite$BulkCipher.keySize:I
iload 5
40: iload 13
iload 2
41: aload 10
iload 11
iload 12
42: invokespecial sun.security.internal.spec.TlsKeyMaterialParameterSpec.<init>:(Ljavax/crypto/SecretKey;II[B[BLjava/lang/String;IIIILjava/lang/String;II)V
astore 14
start local 14 43: aload 6
invokestatic sun.security.ssl.JsseJce.getKeyGenerator:(Ljava/lang/String;)Ljavax/crypto/KeyGenerator;
astore 15
start local 15 44: aload 15
aload 14
invokevirtual javax.crypto.KeyGenerator.init:(Ljava/security/spec/AlgorithmParameterSpec;)V
45: aload 15
invokevirtual javax.crypto.KeyGenerator.generateKey:()Ljavax/crypto/SecretKey;
checkcast sun.security.internal.spec.TlsKeyMaterialSpec
astore 16
start local 16 46: aload 0
aload 16
invokevirtual sun.security.internal.spec.TlsKeyMaterialSpec.getClientCipherKey:()Ljavax/crypto/SecretKey;
putfield sun.security.ssl.Handshaker.clntWriteKey:Ljavax/crypto/SecretKey;
47: aload 0
aload 16
invokevirtual sun.security.internal.spec.TlsKeyMaterialSpec.getServerCipherKey:()Ljavax/crypto/SecretKey;
putfield sun.security.ssl.Handshaker.svrWriteKey:Ljavax/crypto/SecretKey;
48: aload 0
aload 16
invokevirtual sun.security.internal.spec.TlsKeyMaterialSpec.getClientIv:()Ljavax/crypto/spec/IvParameterSpec;
putfield sun.security.ssl.Handshaker.clntWriteIV:Ljavax/crypto/spec/IvParameterSpec;
49: aload 0
aload 16
invokevirtual sun.security.internal.spec.TlsKeyMaterialSpec.getServerIv:()Ljavax/crypto/spec/IvParameterSpec;
putfield sun.security.ssl.Handshaker.svrWriteIV:Ljavax/crypto/spec/IvParameterSpec;
50: aload 0
aload 16
invokevirtual sun.security.internal.spec.TlsKeyMaterialSpec.getClientMacKey:()Ljavax/crypto/SecretKey;
putfield sun.security.ssl.Handshaker.clntMacSecret:Ljavax/crypto/SecretKey;
51: aload 0
aload 16
invokevirtual sun.security.internal.spec.TlsKeyMaterialSpec.getServerMacKey:()Ljavax/crypto/SecretKey;
putfield sun.security.ssl.Handshaker.svrMacSecret:Ljavax/crypto/SecretKey;
end local 16 end local 15 52: goto 55
StackMap locals: sun.security.ssl.Handshaker javax.crypto.SecretKey int int sun.security.ssl.CipherSuite$BulkCipher int java.lang.String sun.security.ssl.CipherSuite$PRF int int java.lang.String int int int sun.security.internal.spec.TlsKeyMaterialParameterSpec
StackMap stack: java.security.GeneralSecurityException
53: astore 15
start local 15 54: new java.security.ProviderException
dup
aload 15
invokespecial java.security.ProviderException.<init>:(Ljava/lang/Throwable;)V
athrow
end local 15 55: StackMap locals:
StackMap stack:
getstatic sun.security.ssl.Handshaker.debug:Lsun/security/ssl/Debug;
ifnull 96
ldc "keygen"
invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
ifeq 96
56: getstatic java.lang.System.out:Ljava/io/PrintStream;
dup
astore 15
monitorenter
57: new sun.security.util.HexDumpEncoder
dup
invokespecial sun.security.util.HexDumpEncoder.<init>:()V
astore 16
start local 16 58: getstatic java.lang.System.out:Ljava/io/PrintStream;
ldc "CONNECTION KEYGEN:"
invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
59: getstatic java.lang.System.out:Ljava/io/PrintStream;
ldc "Client Nonce:"
invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
60: aload 16
aload 0
getfield sun.security.ssl.Handshaker.clnt_random:Lsun/security/ssl/RandomCookie;
getfield sun.security.ssl.RandomCookie.random_bytes:[B
invokestatic sun.security.ssl.Handshaker.printHex:(Lsun/security/util/HexDumpEncoder;[B)V
61: getstatic java.lang.System.out:Ljava/io/PrintStream;
ldc "Server Nonce:"
invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
62: aload 16
aload 0
getfield sun.security.ssl.Handshaker.svr_random:Lsun/security/ssl/RandomCookie;
getfield sun.security.ssl.RandomCookie.random_bytes:[B
invokestatic sun.security.ssl.Handshaker.printHex:(Lsun/security/util/HexDumpEncoder;[B)V
63: getstatic java.lang.System.out:Ljava/io/PrintStream;
ldc "Master Secret:"
invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
64: aload 16
aload 1
invokeinterface javax.crypto.SecretKey.getEncoded:()[B
invokestatic sun.security.ssl.Handshaker.printHex:(Lsun/security/util/HexDumpEncoder;[B)V
65: aload 0
getfield sun.security.ssl.Handshaker.clntMacSecret:Ljavax/crypto/SecretKey;
ifnull 71
66: getstatic java.lang.System.out:Ljava/io/PrintStream;
ldc "Client MAC write Secret:"
invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
67: aload 16
aload 0
getfield sun.security.ssl.Handshaker.clntMacSecret:Ljavax/crypto/SecretKey;
invokeinterface javax.crypto.SecretKey.getEncoded:()[B
invokestatic sun.security.ssl.Handshaker.printHex:(Lsun/security/util/HexDumpEncoder;[B)V
68: getstatic java.lang.System.out:Ljava/io/PrintStream;
ldc "Server MAC write Secret:"
invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
69: aload 16
aload 0
getfield sun.security.ssl.Handshaker.svrMacSecret:Ljavax/crypto/SecretKey;
invokeinterface javax.crypto.SecretKey.getEncoded:()[B
invokestatic sun.security.ssl.Handshaker.printHex:(Lsun/security/util/HexDumpEncoder;[B)V
70: goto 72
71: StackMap locals: java.io.PrintStream sun.security.util.HexDumpEncoder
StackMap stack:
getstatic java.lang.System.out:Ljava/io/PrintStream;
ldc "... no MAC keys used for this cipher"
invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
72: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.ssl.Handshaker.clntWriteKey:Ljavax/crypto/SecretKey;
ifnull 78
73: getstatic java.lang.System.out:Ljava/io/PrintStream;
ldc "Client write key:"
invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
74: aload 16
aload 0
getfield sun.security.ssl.Handshaker.clntWriteKey:Ljavax/crypto/SecretKey;
invokeinterface javax.crypto.SecretKey.getEncoded:()[B
invokestatic sun.security.ssl.Handshaker.printHex:(Lsun/security/util/HexDumpEncoder;[B)V
75: getstatic java.lang.System.out:Ljava/io/PrintStream;
ldc "Server write key:"
invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
76: aload 16
aload 0
getfield sun.security.ssl.Handshaker.svrWriteKey:Ljavax/crypto/SecretKey;
invokeinterface javax.crypto.SecretKey.getEncoded:()[B
invokestatic sun.security.ssl.Handshaker.printHex:(Lsun/security/util/HexDumpEncoder;[B)V
77: goto 79
78: StackMap locals:
StackMap stack:
getstatic java.lang.System.out:Ljava/io/PrintStream;
ldc "... no encryption keys used"
invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
79: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.ssl.Handshaker.clntWriteIV:Ljavax/crypto/spec/IvParameterSpec;
ifnull 85
80: getstatic java.lang.System.out:Ljava/io/PrintStream;
ldc "Client write IV:"
invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
81: aload 16
aload 0
getfield sun.security.ssl.Handshaker.clntWriteIV:Ljavax/crypto/spec/IvParameterSpec;
invokevirtual javax.crypto.spec.IvParameterSpec.getIV:()[B
invokestatic sun.security.ssl.Handshaker.printHex:(Lsun/security/util/HexDumpEncoder;[B)V
82: getstatic java.lang.System.out:Ljava/io/PrintStream;
ldc "Server write IV:"
invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
83: aload 16
aload 0
getfield sun.security.ssl.Handshaker.svrWriteIV:Ljavax/crypto/spec/IvParameterSpec;
invokevirtual javax.crypto.spec.IvParameterSpec.getIV:()[B
invokestatic sun.security.ssl.Handshaker.printHex:(Lsun/security/util/HexDumpEncoder;[B)V
84: goto 91
85: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.ssl.Handshaker.protocolVersion:Lsun/security/ssl/ProtocolVersion;
invokevirtual sun.security.ssl.ProtocolVersion.useTLS11PlusSpec:()Z
ifeq 90
86: getstatic java.lang.System.out:Ljava/io/PrintStream;
87: ldc "... no IV derived for this protocol"
88: invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
89: goto 91
90: StackMap locals:
StackMap stack:
getstatic java.lang.System.out:Ljava/io/PrintStream;
ldc "... no IV used for this cipher"
invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
91: StackMap locals:
StackMap stack:
getstatic java.lang.System.out:Ljava/io/PrintStream;
invokevirtual java.io.PrintStream.flush:()V
end local 16 92: aload 15
monitorexit
93: goto 96
StackMap locals: sun.security.ssl.Handshaker javax.crypto.SecretKey int int sun.security.ssl.CipherSuite$BulkCipher int java.lang.String sun.security.ssl.CipherSuite$PRF int int java.lang.String int int int sun.security.internal.spec.TlsKeyMaterialParameterSpec java.io.PrintStream
StackMap stack: java.lang.Throwable
94: aload 15
monitorexit
95: athrow
96: StackMap locals:
StackMap stack:
return
end local 14 end local 13 end local 12 end local 11 end local 10 end local 9 end local 8 end local 7 end local 6 end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 97 0 this Lsun/security/ssl/Handshaker;
0 97 1 masterKey Ljavax/crypto/SecretKey;
1 97 2 hashSize I
2 97 3 is_exportable Z
3 97 4 cipher Lsun/security/ssl/CipherSuite$BulkCipher;
6 97 5 expandedKeySize I
13 15 6 keyMaterialAlg Ljava/lang/String;
18 20 6 keyMaterialAlg Ljava/lang/String;
22 24 6 keyMaterialAlg Ljava/lang/String;
25 97 6 keyMaterialAlg Ljava/lang/String;
14 15 7 prf Lsun/security/ssl/CipherSuite$PRF;
19 20 7 prf Lsun/security/ssl/CipherSuite$PRF;
23 24 7 prf Lsun/security/ssl/CipherSuite$PRF;
26 97 7 prf Lsun/security/ssl/CipherSuite$PRF;
7 97 8 majorVersion B
8 97 9 minorVersion B
27 97 10 prfHashAlg Ljava/lang/String;
28 97 11 prfHashLength I
29 97 12 prfBlockSize I
30 97 13 ivSize I
43 97 14 spec Lsun/security/internal/spec/TlsKeyMaterialParameterSpec;
44 52 15 kg Ljavax/crypto/KeyGenerator;
46 52 16 keySpec Lsun/security/internal/spec/TlsKeyMaterialSpec;
54 55 15 e Ljava/security/GeneralSecurityException;
58 92 16 dump Lsun/security/util/HexDumpEncoder;
Exception table:
from to target type
43 52 53 Class java.security.GeneralSecurityException
57 93 94 any
94 95 94 any
MethodParameters:
Name Flags
masterKey
private static void printHex(sun.security.util.HexDumpEncoder, byte[]);
descriptor: (Lsun/security/util/HexDumpEncoder;[B)V
flags: (0x000a) ACC_PRIVATE, ACC_STATIC
Code:
stack=3, locals=2, args_size=2
start local 0 start local 1 0: aload 1
ifnonnull 3
1: getstatic java.lang.System.out:Ljava/io/PrintStream;
ldc "(key bytes not available)"
invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
2: goto 6
3: StackMap locals:
StackMap stack:
aload 0
aload 1
getstatic java.lang.System.out:Ljava/io/PrintStream;
invokevirtual sun.security.util.HexDumpEncoder.encodeBuffer:([BLjava/io/OutputStream;)V
4: goto 6
StackMap locals:
StackMap stack: java.io.IOException
5: pop
6: StackMap locals:
StackMap stack:
return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 7 0 dump Lsun/security/util/HexDumpEncoder;
0 7 1 bytes [B
Exception table:
from to target type
3 4 5 Class java.io.IOException
MethodParameters:
Name Flags
dump
bytes
private <T> void delegateTask(java.security.PrivilegedExceptionAction<T>);
descriptor: (Ljava/security/PrivilegedExceptionAction;)V
flags: (0x0002) ACC_PRIVATE
Code:
stack=5, locals=2, args_size=2
start local 0 start local 1 0: aload 0
new sun.security.ssl.Handshaker$DelegatedTask
dup
aload 0
aload 1
invokespecial sun.security.ssl.Handshaker$DelegatedTask.<init>:(Lsun/security/ssl/Handshaker;Ljava/security/PrivilegedExceptionAction;)V
putfield sun.security.ssl.Handshaker.delegatedTask:Lsun/security/ssl/Handshaker$DelegatedTask;
1: aload 0
iconst_0
putfield sun.security.ssl.Handshaker.taskDelegated:Z
2: aload 0
aconst_null
putfield sun.security.ssl.Handshaker.thrown:Ljava/lang/Exception;
3: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lsun/security/ssl/Handshaker;
0 4 1 pea Ljava/security/PrivilegedExceptionAction<TT;>;
Signature: <T:Ljava/lang/Object;>(Ljava/security/PrivilegedExceptionAction<TT;>;)V
MethodParameters:
Name Flags
pea
sun.security.ssl.Handshaker$DelegatedTask<?> getTask();
descriptor: ()Lsun/security/ssl/Handshaker$DelegatedTask;
flags: (0x0000)
Code:
stack=2, locals=1, args_size=1
start local 0 0: aload 0
getfield sun.security.ssl.Handshaker.taskDelegated:Z
ifne 3
1: aload 0
iconst_1
putfield sun.security.ssl.Handshaker.taskDelegated:Z
2: aload 0
getfield sun.security.ssl.Handshaker.delegatedTask:Lsun/security/ssl/Handshaker$DelegatedTask;
areturn
3: StackMap locals:
StackMap stack:
aconst_null
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lsun/security/ssl/Handshaker;
Signature: ()Lsun/security/ssl/Handshaker$DelegatedTask<*>;
boolean taskOutstanding();
descriptor: ()Z
flags: (0x0000)
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield sun.security.ssl.Handshaker.delegatedTask:Lsun/security/ssl/Handshaker$DelegatedTask;
ifnull 1
iconst_1
ireturn
StackMap locals:
StackMap stack:
1: iconst_0
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lsun/security/ssl/Handshaker;
void checkThrown();
descriptor: ()V
flags: (0x0000)
Code:
stack=4, locals=4, args_size=1
start local 0 0: aload 0
getfield sun.security.ssl.Handshaker.thrownLock:Ljava/lang/Object;
dup
astore 1
monitorenter
1: aload 0
getfield sun.security.ssl.Handshaker.thrown:Ljava/lang/Exception;
ifnull 22
2: aload 0
getfield sun.security.ssl.Handshaker.thrown:Ljava/lang/Exception;
invokevirtual java.lang.Exception.getMessage:()Ljava/lang/String;
astore 2
start local 2 3: aload 2
ifnonnull 5
4: ldc "Delegated task threw Exception/Error"
astore 2
5: StackMap locals: java.lang.Object java.lang.String
StackMap stack:
aload 0
getfield sun.security.ssl.Handshaker.thrown:Ljava/lang/Exception;
astore 3
start local 3 6: aload 0
aconst_null
putfield sun.security.ssl.Handshaker.thrown:Ljava/lang/Exception;
7: aload 3
instanceof java.lang.RuntimeException
ifeq 9
8: new java.lang.RuntimeException
dup
aload 2
aload 3
invokespecial java.lang.RuntimeException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
athrow
9: StackMap locals: java.lang.Exception
StackMap stack:
aload 3
instanceof javax.net.ssl.SSLHandshakeException
ifeq 12
10: new javax.net.ssl.SSLHandshakeException
dup
aload 2
invokespecial javax.net.ssl.SSLHandshakeException.<init>:(Ljava/lang/String;)V
aload 3
invokevirtual javax.net.ssl.SSLHandshakeException.initCause:(Ljava/lang/Throwable;)Ljava/lang/Throwable;
11: checkcast javax.net.ssl.SSLHandshakeException
athrow
12: StackMap locals:
StackMap stack:
aload 3
instanceof javax.net.ssl.SSLKeyException
ifeq 15
13: new javax.net.ssl.SSLKeyException
dup
aload 2
invokespecial javax.net.ssl.SSLKeyException.<init>:(Ljava/lang/String;)V
aload 3
invokevirtual javax.net.ssl.SSLKeyException.initCause:(Ljava/lang/Throwable;)Ljava/lang/Throwable;
14: checkcast javax.net.ssl.SSLKeyException
athrow
15: StackMap locals:
StackMap stack:
aload 3
instanceof javax.net.ssl.SSLPeerUnverifiedException
ifeq 18
16: new javax.net.ssl.SSLPeerUnverifiedException
dup
aload 2
invokespecial javax.net.ssl.SSLPeerUnverifiedException.<init>:(Ljava/lang/String;)V
aload 3
invokevirtual javax.net.ssl.SSLPeerUnverifiedException.initCause:(Ljava/lang/Throwable;)Ljava/lang/Throwable;
17: checkcast javax.net.ssl.SSLPeerUnverifiedException
athrow
18: StackMap locals:
StackMap stack:
aload 3
instanceof javax.net.ssl.SSLProtocolException
ifeq 21
19: new javax.net.ssl.SSLProtocolException
dup
aload 2
invokespecial javax.net.ssl.SSLProtocolException.<init>:(Ljava/lang/String;)V
aload 3
invokevirtual javax.net.ssl.SSLProtocolException.initCause:(Ljava/lang/Throwable;)Ljava/lang/Throwable;
20: checkcast javax.net.ssl.SSLProtocolException
athrow
21: StackMap locals:
StackMap stack:
new javax.net.ssl.SSLException
dup
aload 2
aload 3
invokespecial javax.net.ssl.SSLException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
athrow
end local 3 end local 2 22: StackMap locals:
StackMap stack:
aload 1
monitorexit
23: goto 26
StackMap locals:
StackMap stack: java.lang.Throwable
24: aload 1
monitorexit
25: athrow
26: StackMap locals:
StackMap stack:
return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 27 0 this Lsun/security/ssl/Handshaker;
3 22 2 msg Ljava/lang/String;
6 22 3 e Ljava/lang/Exception;
Exception table:
from to target type
1 23 24 any
24 25 24 any
Exceptions:
throws javax.net.ssl.SSLException
}
SourceFile: "Handshaker.java"
NestMembers:
sun.security.ssl.Handshaker$1 sun.security.ssl.Handshaker$DelegatedTask
InnerClasses:
final BulkCipher = sun.security.ssl.CipherSuite$BulkCipher of sun.security.ssl.CipherSuite
final CipherType = sun.security.ssl.CipherSuite$CipherType of sun.security.ssl.CipherSuite
final KeyExchange = sun.security.ssl.CipherSuite$KeyExchange of sun.security.ssl.CipherSuite
final MacAlg = sun.security.ssl.CipherSuite$MacAlg of sun.security.ssl.CipherSuite
final PRF = sun.security.ssl.CipherSuite$PRF of sun.security.ssl.CipherSuite
final Finished = sun.security.ssl.HandshakeMessage$Finished of sun.security.ssl.HandshakeMessage
sun.security.ssl.Handshaker$1
DelegatedTask = sun.security.ssl.Handshaker$DelegatedTask of sun.security.ssl.Handshaker