final class sun.security.ssl.ServerKeyExchange$ServerKeyExchangeProducer implements sun.security.ssl.HandshakeProducer
minor version: 0
major version: 59
flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
this_class: sun.security.ssl.ServerKeyExchange$ServerKeyExchangeProducer
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.ServerKeyExchange$ServerKeyExchangeProducer this
0: .line 48
aload 0 /* this */
invokespecial java.lang.Object.<init>:()V
1: .line 50
return
end local 0 // sun.security.ssl.ServerKeyExchange$ServerKeyExchangeProducer this
LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lsun/security/ssl/ServerKeyExchange$ServerKeyExchangeProducer;
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=9, args_size=3
start local 0 // sun.security.ssl.ServerKeyExchange$ServerKeyExchangeProducer this
start local 1 // sun.security.ssl.ConnectionContext context
start local 2 // sun.security.ssl.SSLHandshake$HandshakeMessage message
0: .line 56
aload 1 /* context */
checkcast sun.security.ssl.ServerHandshakeContext
astore 3 /* shc */
start local 3 // sun.security.ssl.ServerHandshakeContext shc
1: .line 59
aload 3 /* shc */
getfield sun.security.ssl.ServerHandshakeContext.negotiatedCipherSuite:Lsun/security/ssl/CipherSuite;
getfield sun.security.ssl.CipherSuite.keyExchange:Lsun/security/ssl/CipherSuite$KeyExchange;
2: .line 60
aload 3 /* shc */
getfield sun.security.ssl.ServerHandshakeContext.negotiatedProtocol:Lsun/security/ssl/ProtocolVersion;
3: .line 58
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
4: .line 61
aload 4 /* ke */
ifnull 11
5: .line 63
aload 4 /* ke */
aload 3 /* shc */
invokevirtual sun.security.ssl.SSLKeyExchange.getHandshakeProducers:(Lsun/security/ssl/HandshakeContext;)[Ljava/util/Map$Entry;
dup
astore 8
arraylength
istore 7
iconst_0
istore 6
goto 10
StackMap locals: sun.security.ssl.ServerKeyExchange$ServerKeyExchangeProducer sun.security.ssl.ConnectionContext sun.security.ssl.SSLHandshake$HandshakeMessage sun.security.ssl.ServerHandshakeContext sun.security.ssl.SSLKeyExchange top int int java.util.Map$Entry[]
StackMap stack:
6: aload 8
iload 6
aaload
astore 5 /* hc */
start local 5 // java.util.Map$Entry hc
7: .line 64
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.SERVER_KEY_EXCHANGE:Lsun/security/ssl/SSLHandshake;
getfield sun.security.ssl.SSLHandshake.id:B
if_icmpne 9
8: .line 65
aload 5 /* hc */
invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
checkcast sun.security.ssl.HandshakeProducer
aload 1 /* context */
aload 2 /* message */
invokeinterface sun.security.ssl.HandshakeProducer.produce:(Lsun/security/ssl/ConnectionContext;Lsun/security/ssl/SSLHandshake$HandshakeMessage;)[B
areturn
end local 5 // java.util.Map$Entry hc
9: .line 62
StackMap locals:
StackMap stack:
iinc 6 1
StackMap locals:
StackMap stack:
10: iload 6
iload 7
if_icmplt 6
11: .line 71
StackMap locals: sun.security.ssl.ServerKeyExchange$ServerKeyExchangeProducer sun.security.ssl.ConnectionContext sun.security.ssl.SSLHandshake$HandshakeMessage 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.HANDSHAKE_FAILURE:Lsun/security/ssl/Alert;
12: .line 72
ldc "No ServerKeyExchange handshake message can be produced."
13: .line 71
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 // sun.security.ssl.SSLHandshake$HandshakeMessage message
end local 1 // sun.security.ssl.ConnectionContext context
end local 0 // sun.security.ssl.ServerKeyExchange$ServerKeyExchangeProducer this
LocalVariableTable:
Start End Slot Name Signature
0 14 0 this Lsun/security/ssl/ServerKeyExchange$ServerKeyExchangeProducer;
0 14 1 context Lsun/security/ssl/ConnectionContext;
0 14 2 message Lsun/security/ssl/SSLHandshake$HandshakeMessage;
1 14 3 shc Lsun/security/ssl/ServerHandshakeContext;
4 14 4 ke Lsun/security/ssl/SSLKeyExchange;
7 9 5 hc Ljava/util/Map$Entry<Ljava/lang/Byte;Lsun/security/ssl/HandshakeProducer;>;
Exceptions:
throws java.io.IOException
MethodParameters:
Name Flags
context
message
}
SourceFile: "ServerKeyExchange.java"
NestHost: sun.security.ssl.ServerKeyExchange
InnerClasses:
public abstract Entry = java.util.Map$Entry of java.util.Map
final KeyExchange = sun.security.ssl.CipherSuite$KeyExchange of sun.security.ssl.CipherSuite
abstract HandshakeMessage = sun.security.ssl.SSLHandshake$HandshakeMessage of sun.security.ssl.SSLHandshake
private final ServerKeyExchangeProducer = sun.security.ssl.ServerKeyExchange$ServerKeyExchangeProducer of sun.security.ssl.ServerKeyExchange