final class sun.security.ssl.DHClientKeyExchange$DHClientKeyExchangeMessage extends sun.security.ssl.SSLHandshake$HandshakeMessage
minor version: 0
major version: 59
flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
this_class: sun.security.ssl.DHClientKeyExchange$DHClientKeyExchangeMessage
super_class: sun.security.ssl.SSLHandshake$HandshakeMessage
{
private byte[] y;
descriptor: [B
flags: (0x0002) ACC_PRIVATE
void <init>(sun.security.ssl.HandshakeContext);
descriptor: (Lsun/security/ssl/HandshakeContext;)V
flags: (0x0000)
Code:
stack=3, locals=6, args_size=2
start local 0 start local 1 0: aload 0
aload 1
invokespecial sun.security.ssl.SSLHandshake$HandshakeMessage.<init>:(Lsun/security/ssl/HandshakeContext;)V
1: aload 1
checkcast sun.security.ssl.ClientHandshakeContext
2: astore 2
start local 2 3: aconst_null
astore 3
start local 3 4: aload 2
getfield sun.security.ssl.ClientHandshakeContext.handshakePossessions:Ljava/util/List;
invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
astore 5
goto 9
StackMap locals: sun.security.ssl.DHClientKeyExchange$DHClientKeyExchangeMessage sun.security.ssl.HandshakeContext sun.security.ssl.ClientHandshakeContext sun.security.ssl.DHKeyExchange$DHEPossession top java.util.Iterator
StackMap stack:
5: aload 5
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast sun.security.ssl.SSLPossession
astore 4
start local 4 6: aload 4
instanceof sun.security.ssl.DHKeyExchange$DHEPossession
ifeq 9
7: aload 4
checkcast sun.security.ssl.DHKeyExchange$DHEPossession
astore 3
8: goto 10
end local 4 9: StackMap locals:
StackMap stack:
aload 5
invokeinterface java.util.Iterator.hasNext:()Z
ifne 5
10: StackMap locals: sun.security.ssl.DHClientKeyExchange$DHClientKeyExchangeMessage sun.security.ssl.HandshakeContext sun.security.ssl.ClientHandshakeContext sun.security.ssl.DHKeyExchange$DHEPossession
StackMap stack:
aload 3
ifnonnull 14
11: aload 2
getfield sun.security.ssl.ClientHandshakeContext.conContext:Lsun/security/ssl/TransportContext;
getstatic sun.security.ssl.Alert.HANDSHAKE_FAILURE:Lsun/security/ssl/Alert;
12: ldc "No DHE credentials negotiated for client key exchange"
13: invokevirtual sun.security.ssl.TransportContext.fatal:(Lsun/security/ssl/Alert;Ljava/lang/String;)Ljavax/net/ssl/SSLException;
athrow
14: StackMap locals:
StackMap stack:
aload 3
getfield sun.security.ssl.DHKeyExchange$DHEPossession.publicKey:Ljavax/crypto/interfaces/DHPublicKey;
astore 4
start local 4 15: aload 4
invokeinterface javax.crypto.interfaces.DHPublicKey.getParams:()Ljavax/crypto/spec/DHParameterSpec;
pop
16: aload 0
aload 4
invokeinterface javax.crypto.interfaces.DHPublicKey.getY:()Ljava/math/BigInteger;
invokestatic sun.security.ssl.Utilities.toByteArray:(Ljava/math/BigInteger;)[B
putfield sun.security.ssl.DHClientKeyExchange$DHClientKeyExchangeMessage.y:[B
17: return
end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 18 0 this Lsun/security/ssl/DHClientKeyExchange$DHClientKeyExchangeMessage;
0 18 1 handshakeContext Lsun/security/ssl/HandshakeContext;
3 18 2 chc Lsun/security/ssl/ClientHandshakeContext;
4 18 3 dhePossession Lsun/security/ssl/DHKeyExchange$DHEPossession;
6 9 4 possession Lsun/security/ssl/SSLPossession;
15 18 4 publicKey Ljavax/crypto/interfaces/DHPublicKey;
Exceptions:
throws java.io.IOException
MethodParameters:
Name Flags
handshakeContext
void <init>(sun.security.ssl.HandshakeContext, java.nio.ByteBuffer);
descriptor: (Lsun/security/ssl/HandshakeContext;Ljava/nio/ByteBuffer;)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
invokespecial sun.security.ssl.SSLHandshake$HandshakeMessage.<init>:(Lsun/security/ssl/HandshakeContext;)V
1: aload 1
checkcast sun.security.ssl.ServerHandshakeContext
2: astore 3
start local 3 3: aload 2
invokevirtual java.nio.ByteBuffer.remaining:()I
iconst_3
if_icmpge 7
4: aload 3
getfield sun.security.ssl.ServerHandshakeContext.conContext:Lsun/security/ssl/TransportContext;
getstatic sun.security.ssl.Alert.HANDSHAKE_FAILURE:Lsun/security/ssl/Alert;
5: ldc "Invalid DH ClientKeyExchange message: insufficient data"
6: invokevirtual sun.security.ssl.TransportContext.fatal:(Lsun/security/ssl/Alert;Ljava/lang/String;)Ljavax/net/ssl/SSLException;
athrow
7: StackMap locals: sun.security.ssl.DHClientKeyExchange$DHClientKeyExchangeMessage sun.security.ssl.HandshakeContext java.nio.ByteBuffer sun.security.ssl.ServerHandshakeContext
StackMap stack:
aload 0
aload 2
invokestatic sun.security.ssl.Record.getBytes16:(Ljava/nio/ByteBuffer;)[B
putfield sun.security.ssl.DHClientKeyExchange$DHClientKeyExchangeMessage.y:[B
8: aload 2
invokevirtual java.nio.ByteBuffer.hasRemaining:()Z
ifeq 12
9: aload 3
getfield sun.security.ssl.ServerHandshakeContext.conContext:Lsun/security/ssl/TransportContext;
getstatic sun.security.ssl.Alert.HANDSHAKE_FAILURE:Lsun/security/ssl/Alert;
10: ldc "Invalid DH ClientKeyExchange message: unknown extra data"
11: invokevirtual sun.security.ssl.TransportContext.fatal:(Lsun/security/ssl/Alert;Ljava/lang/String;)Ljavax/net/ssl/SSLException;
athrow
12: StackMap locals:
StackMap stack:
return
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 13 0 this Lsun/security/ssl/DHClientKeyExchange$DHClientKeyExchangeMessage;
0 13 1 handshakeContext Lsun/security/ssl/HandshakeContext;
0 13 2 m Ljava/nio/ByteBuffer;
3 13 3 shc Lsun/security/ssl/ServerHandshakeContext;
Exceptions:
throws java.io.IOException
MethodParameters:
Name Flags
handshakeContext
m
public sun.security.ssl.SSLHandshake handshakeType();
descriptor: ()Lsun/security/ssl/SSLHandshake;
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: getstatic sun.security.ssl.SSLHandshake.CLIENT_KEY_EXCHANGE:Lsun/security/ssl/SSLHandshake;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lsun/security/ssl/DHClientKeyExchange$DHClientKeyExchangeMessage;
public int messageLength();
descriptor: ()I
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=1, args_size=1
start local 0 0: aload 0
getfield sun.security.ssl.DHClientKeyExchange$DHClientKeyExchangeMessage.y:[B
arraylength
iconst_2
iadd
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lsun/security/ssl/DHClientKeyExchange$DHClientKeyExchangeMessage;
public void send(sun.security.ssl.HandshakeOutStream);
descriptor: (Lsun/security/ssl/HandshakeOutStream;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 1
aload 0
getfield sun.security.ssl.DHClientKeyExchange$DHClientKeyExchangeMessage.y:[B
invokevirtual sun.security.ssl.HandshakeOutStream.putBytes16:([B)V
1: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lsun/security/ssl/DHClientKeyExchange$DHClientKeyExchangeMessage;
0 2 1 hos Lsun/security/ssl/HandshakeOutStream;
Exceptions:
throws java.io.IOException
MethodParameters:
Name Flags
hos
public java.lang.String toString();
descriptor: ()Ljava/lang/String;
flags: (0x0001) ACC_PUBLIC
Code:
stack=5, locals=4, args_size=1
start local 0 0: new java.text.MessageFormat
dup
1: ldc "\"DH ClientKeyExchange\": '{'\n \"parameters\": '{'\n \"dh_Yc\": '{'\n{0}\n '}',\n '}'\n'}'"
2: getstatic java.util.Locale.ENGLISH:Ljava/util/Locale;
3: invokespecial java.text.MessageFormat.<init>:(Ljava/lang/String;Ljava/util/Locale;)V
astore 1
start local 1 4: new sun.security.util.HexDumpEncoder
dup
invokespecial sun.security.util.HexDumpEncoder.<init>:()V
astore 2
start local 2 5: iconst_1
anewarray java.lang.Object
dup
iconst_0
6: aload 2
aload 0
getfield sun.security.ssl.DHClientKeyExchange$DHClientKeyExchangeMessage.y:[B
invokevirtual sun.security.util.HexDumpEncoder.encodeBuffer:([B)Ljava/lang/String;
ldc " "
7: invokestatic sun.security.ssl.Utilities.indent:(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
aastore
8: astore 3
start local 3 9: aload 1
aload 3
invokevirtual java.text.MessageFormat.format:(Ljava/lang/Object;)Ljava/lang/String;
areturn
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 10 0 this Lsun/security/ssl/DHClientKeyExchange$DHClientKeyExchangeMessage;
4 10 1 messageFormat Ljava/text/MessageFormat;
5 10 2 hexEncoder Lsun/security/util/HexDumpEncoder;
9 10 3 messageFields [Ljava/lang/Object;
}
SourceFile: "DHClientKeyExchange.java"
NestHost: sun.security.ssl.DHClientKeyExchange
InnerClasses:
private final DHClientKeyExchangeMessage = sun.security.ssl.DHClientKeyExchange$DHClientKeyExchangeMessage of sun.security.ssl.DHClientKeyExchange
final DHEPossession = sun.security.ssl.DHKeyExchange$DHEPossession of sun.security.ssl.DHKeyExchange
abstract HandshakeMessage = sun.security.ssl.SSLHandshake$HandshakeMessage of sun.security.ssl.SSLHandshake