final class sun.security.ssl.ExtendedMasterSecretExtension$CHExtendedMasterSecretProducer implements sun.security.ssl.HandshakeProducer
minor version: 0
major version: 59
flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
this_class: sun.security.ssl.ExtendedMasterSecretExtension$CHExtendedMasterSecretProducer
super_class: java.lang.Object
{
private void <init>();
descriptor: ()V
flags: (0x0002) ACC_PRIVATE
Code:
stack=1, locals=1, args_size=1
start local 0 // sun.security.ssl.ExtendedMasterSecretExtension$CHExtendedMasterSecretProducer this
0: .line 106
aload 0 /* this */
invokespecial java.lang.Object.<init>:()V
1: .line 108
return
end local 0 // sun.security.ssl.ExtendedMasterSecretExtension$CHExtendedMasterSecretProducer this
LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lsun/security/ssl/ExtendedMasterSecretExtension$CHExtendedMasterSecretProducer;
public byte[] produce(sun.security.ssl.ConnectionContext, sun.security.ssl.SSLHandshake$HandshakeMessage);
descriptor: (Lsun/security/ssl/ConnectionContext;Lsun/security/ssl/SSLHandshake$HandshakeMessage;)[B
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=5, args_size=3
start local 0 // sun.security.ssl.ExtendedMasterSecretExtension$CHExtendedMasterSecretProducer this
start local 1 // sun.security.ssl.ConnectionContext context
start local 2 // sun.security.ssl.SSLHandshake$HandshakeMessage message
0: .line 114
aload 1 /* context */
checkcast sun.security.ssl.ClientHandshakeContext
astore 3 /* chc */
start local 3 // sun.security.ssl.ClientHandshakeContext chc
1: .line 117
aload 3 /* chc */
getfield sun.security.ssl.ClientHandshakeContext.sslConfig:Lsun/security/ssl/SSLConfiguration;
getstatic sun.security.ssl.SSLExtension.CH_EXTENDED_MASTER_SECRET:Lsun/security/ssl/SSLExtension;
invokevirtual sun.security.ssl.SSLConfiguration.isAvailable:(Lsun/security/ssl/SSLExtension;)Z
ifeq 4
2: .line 118
getstatic sun.security.ssl.SSLConfiguration.useExtendedMasterSecret:Z
ifeq 4
3: .line 119
aload 3 /* chc */
getfield sun.security.ssl.ClientHandshakeContext.conContext:Lsun/security/ssl/TransportContext;
getfield sun.security.ssl.TransportContext.protocolVersion:Lsun/security/ssl/ProtocolVersion;
invokevirtual sun.security.ssl.ProtocolVersion.useTLS10PlusSpec:()Z
ifne 8
4: .line 120
StackMap locals: sun.security.ssl.ClientHandshakeContext
StackMap stack:
getstatic sun.security.ssl.SSLLogger.isOn:Z
ifeq 7
ldc "ssl,handshake"
invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
ifeq 7
5: .line 122
ldc "Ignore unavailable extended_master_secret extension"
iconst_0
anewarray java.lang.Object
6: .line 121
invokestatic sun.security.ssl.SSLLogger.fine:(Ljava/lang/String;[Ljava/lang/Object;)V
7: .line 125
StackMap locals:
StackMap stack:
aconst_null
areturn
8: .line 128
StackMap locals:
StackMap stack:
aload 3 /* chc */
getfield sun.security.ssl.ClientHandshakeContext.handshakeSession:Lsun/security/ssl/SSLSessionImpl;
ifnull 10
9: .line 129
aload 3 /* chc */
getfield sun.security.ssl.ClientHandshakeContext.handshakeSession:Lsun/security/ssl/SSLSessionImpl;
getfield sun.security.ssl.SSLSessionImpl.useExtendedMasterSecret:Z
ifeq 15
10: .line 130
StackMap locals:
StackMap stack:
iconst_0
newarray 8
astore 4 /* extData */
start local 4 // byte[] extData
11: .line 131
aload 3 /* chc */
getfield sun.security.ssl.ClientHandshakeContext.handshakeExtensions:Ljava/util/Map;
getstatic sun.security.ssl.SSLExtension.CH_EXTENDED_MASTER_SECRET:Lsun/security/ssl/SSLExtension;
12: .line 132
getstatic sun.security.ssl.ExtendedMasterSecretExtension$ExtendedMasterSecretSpec.NOMINAL:Lsun/security/ssl/ExtendedMasterSecretExtension$ExtendedMasterSecretSpec;
13: .line 131
invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
pop
14: .line 134
aload 4 /* extData */
areturn
end local 4 // byte[] extData
15: .line 137
StackMap locals:
StackMap stack:
aconst_null
areturn
end local 3 // sun.security.ssl.ClientHandshakeContext chc
end local 2 // sun.security.ssl.SSLHandshake$HandshakeMessage message
end local 1 // sun.security.ssl.ConnectionContext context
end local 0 // sun.security.ssl.ExtendedMasterSecretExtension$CHExtendedMasterSecretProducer this
LocalVariableTable:
Start End Slot Name Signature
0 16 0 this Lsun/security/ssl/ExtendedMasterSecretExtension$CHExtendedMasterSecretProducer;
0 16 1 context Lsun/security/ssl/ConnectionContext;
0 16 2 message Lsun/security/ssl/SSLHandshake$HandshakeMessage;
1 16 3 chc Lsun/security/ssl/ClientHandshakeContext;
11 15 4 extData [B
Exceptions:
throws java.io.IOException
MethodParameters:
Name Flags
context
message
}
SourceFile: "ExtendedMasterSecretExtension.java"
NestHost: sun.security.ssl.ExtendedMasterSecretExtension
InnerClasses:
private final CHExtendedMasterSecretProducer = sun.security.ssl.ExtendedMasterSecretExtension$CHExtendedMasterSecretProducer of sun.security.ssl.ExtendedMasterSecretExtension
final ExtendedMasterSecretSpec = sun.security.ssl.ExtendedMasterSecretExtension$ExtendedMasterSecretSpec of sun.security.ssl.ExtendedMasterSecretExtension
abstract HandshakeMessage = sun.security.ssl.SSLHandshake$HandshakeMessage of sun.security.ssl.SSLHandshake