final class sun.security.ssl.ClientKeyExchange$ClientKeyExchangeConsumer implements sun.security.ssl.SSLConsumer
minor version: 0
major version: 59
flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
this_class: sun.security.ssl.ClientKeyExchange$ClientKeyExchangeConsumer
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.ClientKeyExchange$ClientKeyExchangeConsumer this
0: .line 82
aload 0 /* this */
invokespecial java.lang.Object.<init>:()V
1: .line 84
return
end local 0 // sun.security.ssl.ClientKeyExchange$ClientKeyExchangeConsumer this
LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lsun/security/ssl/ClientKeyExchange$ClientKeyExchangeConsumer;
public void consume(sun.security.ssl.ConnectionContext, java.nio.ByteBuffer);
descriptor: (Lsun/security/ssl/ConnectionContext;Ljava/nio/ByteBuffer;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=9, args_size=3
start local 0 // sun.security.ssl.ClientKeyExchange$ClientKeyExchangeConsumer this
start local 1 // sun.security.ssl.ConnectionContext context
start local 2 // java.nio.ByteBuffer message
0: .line 90
aload 1 /* context */
checkcast sun.security.ssl.ServerHandshakeContext
astore 3 /* shc */
start local 3 // sun.security.ssl.ServerHandshakeContext shc
1: .line 92
aload 3 /* shc */
getfield sun.security.ssl.ServerHandshakeContext.handshakeConsumers:Ljava/util/LinkedHashMap;
getstatic sun.security.ssl.SSLHandshake.CLIENT_KEY_EXCHANGE:Lsun/security/ssl/SSLHandshake;
getfield sun.security.ssl.SSLHandshake.id:B
invokestatic java.lang.Byte.valueOf:(B)Ljava/lang/Byte;
invokevirtual java.util.LinkedHashMap.remove:(Ljava/lang/Object;)Ljava/lang/Object;
pop
2: .line 97
aload 3 /* shc */
getfield sun.security.ssl.ServerHandshakeContext.handshakeConsumers:Ljava/util/LinkedHashMap;
3: .line 98
getstatic sun.security.ssl.SSLHandshake.CERTIFICATE:Lsun/security/ssl/SSLHandshake;
getfield sun.security.ssl.SSLHandshake.id:B
invokestatic java.lang.Byte.valueOf:(B)Ljava/lang/Byte;
4: .line 97
invokevirtual java.util.LinkedHashMap.containsKey:(Ljava/lang/Object;)Z
5: .line 98
ifeq 9
6: .line 99
aload 3 /* shc */
getfield sun.security.ssl.ServerHandshakeContext.conContext:Lsun/security/ssl/TransportContext;
getstatic sun.security.ssl.Alert.UNEXPECTED_MESSAGE:Lsun/security/ssl/Alert;
7: .line 100
ldc "Unexpected ClientKeyExchange handshake message."
8: .line 99
invokevirtual sun.security.ssl.TransportContext.fatal:(Lsun/security/ssl/Alert;Ljava/lang/String;)Ljavax/net/ssl/SSLException;
athrow
9: .line 104
StackMap locals: sun.security.ssl.ServerHandshakeContext
StackMap stack:
aload 3 /* shc */
getfield sun.security.ssl.ServerHandshakeContext.negotiatedCipherSuite:Lsun/security/ssl/CipherSuite;
getfield sun.security.ssl.CipherSuite.keyExchange:Lsun/security/ssl/CipherSuite$KeyExchange;
10: .line 105
aload 3 /* shc */
getfield sun.security.ssl.ServerHandshakeContext.negotiatedProtocol:Lsun/security/ssl/ProtocolVersion;
11: .line 103
invokestatic sun.security.ssl.SSLKeyExchange.valueOf:(Lsun/security/ssl/CipherSuite$KeyExchange;Lsun/security/ssl/ProtocolVersion;)Lsun/security/ssl/SSLKeyExchange;
astore 4 /* ke */
start local 4 // sun.security.ssl.SSLKeyExchange ke
12: .line 106
aload 4 /* ke */
ifnull 20
13: .line 108
aload 4 /* ke */
aload 3 /* shc */
invokevirtual sun.security.ssl.SSLKeyExchange.getHandshakeConsumers:(Lsun/security/ssl/HandshakeContext;)[Ljava/util/Map$Entry;
dup
astore 8
arraylength
istore 7
iconst_0
istore 6
goto 19
StackMap locals: sun.security.ssl.ClientKeyExchange$ClientKeyExchangeConsumer sun.security.ssl.ConnectionContext java.nio.ByteBuffer sun.security.ssl.ServerHandshakeContext sun.security.ssl.SSLKeyExchange top int int java.util.Map$Entry[]
StackMap stack:
14: aload 8
iload 6
aaload
astore 5 /* hc */
start local 5 // java.util.Map$Entry hc
15: .line 109
aload 5 /* hc */
invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
checkcast java.lang.Byte
invokevirtual java.lang.Byte.byteValue:()B
getstatic sun.security.ssl.SSLHandshake.CLIENT_KEY_EXCHANGE:Lsun/security/ssl/SSLHandshake;
getfield sun.security.ssl.SSLHandshake.id:B
if_icmpne 18
16: .line 110
aload 5 /* hc */
invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
checkcast sun.security.ssl.SSLConsumer
aload 1 /* context */
aload 2 /* message */
invokeinterface sun.security.ssl.SSLConsumer.consume:(Lsun/security/ssl/ConnectionContext;Ljava/nio/ByteBuffer;)V
17: .line 111
return
end local 5 // java.util.Map$Entry hc
18: .line 107
StackMap locals:
StackMap stack:
iinc 6 1
StackMap locals:
StackMap stack:
19: iload 6
iload 7
if_icmplt 14
20: .line 117
StackMap locals: sun.security.ssl.ClientKeyExchange$ClientKeyExchangeConsumer sun.security.ssl.ConnectionContext java.nio.ByteBuffer sun.security.ssl.ServerHandshakeContext sun.security.ssl.SSLKeyExchange
StackMap stack:
aload 3 /* shc */
getfield sun.security.ssl.ServerHandshakeContext.conContext:Lsun/security/ssl/TransportContext;
getstatic sun.security.ssl.Alert.UNEXPECTED_MESSAGE:Lsun/security/ssl/Alert;
21: .line 118
ldc "Unexpected ClientKeyExchange handshake message."
22: .line 117
invokevirtual sun.security.ssl.TransportContext.fatal:(Lsun/security/ssl/Alert;Ljava/lang/String;)Ljavax/net/ssl/SSLException;
athrow
end local 4 // sun.security.ssl.SSLKeyExchange ke
end local 3 // sun.security.ssl.ServerHandshakeContext shc
end local 2 // java.nio.ByteBuffer message
end local 1 // sun.security.ssl.ConnectionContext context
end local 0 // sun.security.ssl.ClientKeyExchange$ClientKeyExchangeConsumer this
LocalVariableTable:
Start End Slot Name Signature
0 23 0 this Lsun/security/ssl/ClientKeyExchange$ClientKeyExchangeConsumer;
0 23 1 context Lsun/security/ssl/ConnectionContext;
0 23 2 message Ljava/nio/ByteBuffer;
1 23 3 shc Lsun/security/ssl/ServerHandshakeContext;
12 23 4 ke Lsun/security/ssl/SSLKeyExchange;
15 18 5 hc Ljava/util/Map$Entry<Ljava/lang/Byte;Lsun/security/ssl/SSLConsumer;>;
Exceptions:
throws java.io.IOException
MethodParameters:
Name Flags
context
message
}
SourceFile: "ClientKeyExchange.java"
NestHost: sun.security.ssl.ClientKeyExchange
InnerClasses:
public abstract Entry = java.util.Map$Entry of java.util.Map
final KeyExchange = sun.security.ssl.CipherSuite$KeyExchange of sun.security.ssl.CipherSuite
private final ClientKeyExchangeConsumer = sun.security.ssl.ClientKeyExchange$ClientKeyExchangeConsumer of sun.security.ssl.ClientKeyExchange