final class sun.security.ssl.ExtendedMasterSecretExtension$SHExtendedMasterSecretConsumer implements sun.security.ssl.SSLExtension$ExtensionConsumer
minor version: 0
major version: 59
flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
this_class: sun.security.ssl.ExtendedMasterSecretExtension$SHExtendedMasterSecretConsumer
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$SHExtendedMasterSecretConsumer this
0: .line 302
aload 0 /* this */
invokespecial java.lang.Object.<init>:()V
1: .line 304
return
end local 0 // sun.security.ssl.ExtendedMasterSecretExtension$SHExtendedMasterSecretConsumer this
LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lsun/security/ssl/ExtendedMasterSecretExtension$SHExtendedMasterSecretConsumer;
public void consume(sun.security.ssl.ConnectionContext, sun.security.ssl.SSLHandshake$HandshakeMessage, java.nio.ByteBuffer);
descriptor: (Lsun/security/ssl/ConnectionContext;Lsun/security/ssl/SSLHandshake$HandshakeMessage;Ljava/nio/ByteBuffer;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=6, args_size=4
start local 0 // sun.security.ssl.ExtendedMasterSecretExtension$SHExtendedMasterSecretConsumer this
start local 1 // sun.security.ssl.ConnectionContext context
start local 2 // sun.security.ssl.SSLHandshake$HandshakeMessage message
start local 3 // java.nio.ByteBuffer buffer
0: .line 310
aload 1 /* context */
checkcast sun.security.ssl.ClientHandshakeContext
astore 4 /* chc */
start local 4 // sun.security.ssl.ClientHandshakeContext chc
1: .line 315
aload 4 /* chc */
getfield sun.security.ssl.ClientHandshakeContext.handshakeExtensions:Ljava/util/Map;
getstatic sun.security.ssl.SSLExtension.CH_EXTENDED_MASTER_SECRET:Lsun/security/ssl/SSLExtension;
invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
checkcast sun.security.ssl.ExtendedMasterSecretExtension$ExtendedMasterSecretSpec
2: .line 314
astore 5 /* requstedSpec */
start local 5 // sun.security.ssl.ExtendedMasterSecretExtension$ExtendedMasterSecretSpec requstedSpec
3: .line 316
aload 5 /* requstedSpec */
ifnonnull 7
4: .line 317
aload 4 /* chc */
getfield sun.security.ssl.ClientHandshakeContext.conContext:Lsun/security/ssl/TransportContext;
getstatic sun.security.ssl.Alert.UNSUPPORTED_EXTENSION:Lsun/security/ssl/Alert;
5: .line 318
ldc "Server sent the extended_master_secret extension improperly"
6: .line 317
invokevirtual sun.security.ssl.TransportContext.fatal:(Lsun/security/ssl/Alert;Ljava/lang/String;)Ljavax/net/ssl/SSLException;
athrow
7: .line 324
StackMap locals: sun.security.ssl.ClientHandshakeContext sun.security.ssl.ExtendedMasterSecretExtension$ExtendedMasterSecretSpec
StackMap stack:
new sun.security.ssl.ExtendedMasterSecretExtension$ExtendedMasterSecretSpec
aload 4 /* chc */
aload 3 /* buffer */
invokespecial sun.security.ssl.ExtendedMasterSecretExtension$ExtendedMasterSecretSpec.<init>:(Lsun/security/ssl/HandshakeContext;Ljava/nio/ByteBuffer;)V
8: .line 325
aload 4 /* chc */
getfield sun.security.ssl.ClientHandshakeContext.isResumption:Z
ifeq 13
aload 4 /* chc */
getfield sun.security.ssl.ClientHandshakeContext.resumingSession:Lsun/security/ssl/SSLSessionImpl;
ifnull 13
9: .line 326
aload 4 /* chc */
getfield sun.security.ssl.ClientHandshakeContext.resumingSession:Lsun/security/ssl/SSLSessionImpl;
getfield sun.security.ssl.SSLSessionImpl.useExtendedMasterSecret:Z
ifne 13
10: .line 327
aload 4 /* chc */
getfield sun.security.ssl.ClientHandshakeContext.conContext:Lsun/security/ssl/TransportContext;
getstatic sun.security.ssl.Alert.UNSUPPORTED_EXTENSION:Lsun/security/ssl/Alert;
11: .line 328
ldc "Server sent an unexpected extended_master_secret extension on session resumption"
12: .line 327
invokevirtual sun.security.ssl.TransportContext.fatal:(Lsun/security/ssl/Alert;Ljava/lang/String;)Ljavax/net/ssl/SSLException;
athrow
13: .line 333
StackMap locals:
StackMap stack:
aload 4 /* chc */
getfield sun.security.ssl.ClientHandshakeContext.handshakeExtensions:Ljava/util/Map;
14: .line 334
getstatic sun.security.ssl.SSLExtension.SH_EXTENDED_MASTER_SECRET:Lsun/security/ssl/SSLExtension;
getstatic sun.security.ssl.ExtendedMasterSecretExtension$ExtendedMasterSecretSpec.NOMINAL:Lsun/security/ssl/ExtendedMasterSecretExtension$ExtendedMasterSecretSpec;
15: .line 333
invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
pop
16: .line 337
return
end local 5 // sun.security.ssl.ExtendedMasterSecretExtension$ExtendedMasterSecretSpec requstedSpec
end local 4 // sun.security.ssl.ClientHandshakeContext chc
end local 3 // java.nio.ByteBuffer buffer
end local 2 // sun.security.ssl.SSLHandshake$HandshakeMessage message
end local 1 // sun.security.ssl.ConnectionContext context
end local 0 // sun.security.ssl.ExtendedMasterSecretExtension$SHExtendedMasterSecretConsumer this
LocalVariableTable:
Start End Slot Name Signature
0 17 0 this Lsun/security/ssl/ExtendedMasterSecretExtension$SHExtendedMasterSecretConsumer;
0 17 1 context Lsun/security/ssl/ConnectionContext;
0 17 2 message Lsun/security/ssl/SSLHandshake$HandshakeMessage;
0 17 3 buffer Ljava/nio/ByteBuffer;
1 17 4 chc Lsun/security/ssl/ClientHandshakeContext;
3 17 5 requstedSpec Lsun/security/ssl/ExtendedMasterSecretExtension$ExtendedMasterSecretSpec;
Exceptions:
throws java.io.IOException
MethodParameters:
Name Flags
context
message
buffer
}
SourceFile: "ExtendedMasterSecretExtension.java"
NestHost: sun.security.ssl.ExtendedMasterSecretExtension
InnerClasses:
final ExtendedMasterSecretSpec = sun.security.ssl.ExtendedMasterSecretExtension$ExtendedMasterSecretSpec of sun.security.ssl.ExtendedMasterSecretExtension
private final SHExtendedMasterSecretConsumer = sun.security.ssl.ExtendedMasterSecretExtension$SHExtendedMasterSecretConsumer of sun.security.ssl.ExtendedMasterSecretExtension
abstract ExtensionConsumer = sun.security.ssl.SSLExtension$ExtensionConsumer of sun.security.ssl.SSLExtension
abstract HandshakeMessage = sun.security.ssl.SSLHandshake$HandshakeMessage of sun.security.ssl.SSLHandshake