final class sun.security.ssl.HandshakeMessage$ClientHello extends sun.security.ssl.HandshakeMessage
minor version: 0
major version: 59
flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
this_class: sun.security.ssl.HandshakeMessage$ClientHello
super_class: sun.security.ssl.HandshakeMessage
{
sun.security.ssl.ProtocolVersion protocolVersion;
descriptor: Lsun/security/ssl/ProtocolVersion;
flags: (0x0000)
sun.security.ssl.RandomCookie clnt_random;
descriptor: Lsun/security/ssl/RandomCookie;
flags: (0x0000)
sun.security.ssl.SessionId sessionId;
descriptor: Lsun/security/ssl/SessionId;
flags: (0x0000)
byte[] cookie;
descriptor: [B
flags: (0x0000)
private sun.security.ssl.CipherSuiteList cipherSuites;
descriptor: Lsun/security/ssl/CipherSuiteList;
flags: (0x0002) ACC_PRIVATE
private final boolean isDTLS;
descriptor: Z
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
byte[] compression_methods;
descriptor: [B
flags: (0x0000)
sun.security.ssl.HelloExtensions extensions;
descriptor: Lsun/security/ssl/HelloExtensions;
flags: (0x0000)
private static final byte[] NULL_COMPRESSION;
descriptor: [B
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
static void <clinit>();
descriptor: ()V
flags: (0x0008) ACC_STATIC
Code:
stack=1, locals=0, args_size=0
0: iconst_1
newarray 8
putstatic sun.security.ssl.HandshakeMessage$ClientHello.NULL_COMPRESSION:[B
return
LocalVariableTable:
Start End Slot Name Signature
void <init>(java.security.SecureRandom, sun.security.ssl.ProtocolVersion, sun.security.ssl.SessionId, sun.security.ssl.CipherSuiteList, boolean);
descriptor: (Ljava/security/SecureRandom;Lsun/security/ssl/ProtocolVersion;Lsun/security/ssl/SessionId;Lsun/security/ssl/CipherSuiteList;Z)V
flags: (0x0000)
Code:
stack=4, locals=6, args_size=6
start local 0 start local 1 start local 2 start local 3 start local 4 start local 5 0: aload 0
invokespecial sun.security.ssl.HandshakeMessage.<init>:()V
1: aload 0
new sun.security.ssl.HelloExtensions
dup
invokespecial sun.security.ssl.HelloExtensions.<init>:()V
putfield sun.security.ssl.HandshakeMessage$ClientHello.extensions:Lsun/security/ssl/HelloExtensions;
2: aload 0
iload 5
putfield sun.security.ssl.HandshakeMessage$ClientHello.isDTLS:Z
3: aload 0
aload 2
putfield sun.security.ssl.HandshakeMessage$ClientHello.protocolVersion:Lsun/security/ssl/ProtocolVersion;
4: aload 0
aload 3
putfield sun.security.ssl.HandshakeMessage$ClientHello.sessionId:Lsun/security/ssl/SessionId;
5: aload 0
aload 4
putfield sun.security.ssl.HandshakeMessage$ClientHello.cipherSuites:Lsun/security/ssl/CipherSuiteList;
6: iload 5
ifeq 9
7: aload 0
iconst_0
newarray 8
putfield sun.security.ssl.HandshakeMessage$ClientHello.cookie:[B
8: goto 10
9: StackMap locals: sun.security.ssl.HandshakeMessage$ClientHello java.security.SecureRandom sun.security.ssl.ProtocolVersion sun.security.ssl.SessionId sun.security.ssl.CipherSuiteList int
StackMap stack:
aload 0
aconst_null
putfield sun.security.ssl.HandshakeMessage$ClientHello.cookie:[B
10: StackMap locals:
StackMap stack:
aload 0
new sun.security.ssl.RandomCookie
dup
aload 1
invokespecial sun.security.ssl.RandomCookie.<init>:(Ljava/security/SecureRandom;)V
putfield sun.security.ssl.HandshakeMessage$ClientHello.clnt_random:Lsun/security/ssl/RandomCookie;
11: aload 0
getstatic sun.security.ssl.HandshakeMessage$ClientHello.NULL_COMPRESSION:[B
putfield sun.security.ssl.HandshakeMessage$ClientHello.compression_methods:[B
12: return
end local 5 end local 4 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/HandshakeMessage$ClientHello;
0 13 1 generator Ljava/security/SecureRandom;
0 13 2 protocolVersion Lsun/security/ssl/ProtocolVersion;
0 13 3 sessionId Lsun/security/ssl/SessionId;
0 13 4 cipherSuites Lsun/security/ssl/CipherSuiteList;
0 13 5 isDTLS Z
MethodParameters:
Name Flags
generator
protocolVersion
sessionId
cipherSuites
isDTLS
void <init>(sun.security.ssl.HandshakeInStream, int, boolean);
descriptor: (Lsun/security/ssl/HandshakeInStream;IZ)V
flags: (0x0000)
Code:
stack=4, locals=4, args_size=4
start local 0 start local 1 start local 2 start local 3 0: aload 0
invokespecial sun.security.ssl.HandshakeMessage.<init>:()V
1: aload 0
new sun.security.ssl.HelloExtensions
dup
invokespecial sun.security.ssl.HelloExtensions.<init>:()V
putfield sun.security.ssl.HandshakeMessage$ClientHello.extensions:Lsun/security/ssl/HelloExtensions;
2: aload 0
iload 3
putfield sun.security.ssl.HandshakeMessage$ClientHello.isDTLS:Z
3: aload 0
aload 1
invokevirtual sun.security.ssl.HandshakeInStream.getInt8:()I
aload 1
invokevirtual sun.security.ssl.HandshakeInStream.getInt8:()I
invokestatic sun.security.ssl.ProtocolVersion.valueOf:(II)Lsun/security/ssl/ProtocolVersion;
putfield sun.security.ssl.HandshakeMessage$ClientHello.protocolVersion:Lsun/security/ssl/ProtocolVersion;
4: aload 0
new sun.security.ssl.RandomCookie
dup
aload 1
invokespecial sun.security.ssl.RandomCookie.<init>:(Lsun/security/ssl/HandshakeInStream;)V
putfield sun.security.ssl.HandshakeMessage$ClientHello.clnt_random:Lsun/security/ssl/RandomCookie;
5: aload 0
new sun.security.ssl.SessionId
dup
aload 1
invokevirtual sun.security.ssl.HandshakeInStream.getBytes8:()[B
invokespecial sun.security.ssl.SessionId.<init>:([B)V
putfield sun.security.ssl.HandshakeMessage$ClientHello.sessionId:Lsun/security/ssl/SessionId;
6: aload 0
getfield sun.security.ssl.HandshakeMessage$ClientHello.sessionId:Lsun/security/ssl/SessionId;
aload 0
getfield sun.security.ssl.HandshakeMessage$ClientHello.protocolVersion:Lsun/security/ssl/ProtocolVersion;
invokevirtual sun.security.ssl.SessionId.checkLength:(Lsun/security/ssl/ProtocolVersion;)V
7: iload 3
ifeq 10
8: aload 0
aload 1
invokevirtual sun.security.ssl.HandshakeInStream.getBytes8:()[B
putfield sun.security.ssl.HandshakeMessage$ClientHello.cookie:[B
9: goto 11
10: StackMap locals: sun.security.ssl.HandshakeMessage$ClientHello sun.security.ssl.HandshakeInStream int int
StackMap stack:
aload 0
aconst_null
putfield sun.security.ssl.HandshakeMessage$ClientHello.cookie:[B
11: StackMap locals:
StackMap stack:
aload 0
new sun.security.ssl.CipherSuiteList
dup
aload 1
invokespecial sun.security.ssl.CipherSuiteList.<init>:(Lsun/security/ssl/HandshakeInStream;)V
putfield sun.security.ssl.HandshakeMessage$ClientHello.cipherSuites:Lsun/security/ssl/CipherSuiteList;
12: aload 0
aload 1
invokevirtual sun.security.ssl.HandshakeInStream.getBytes8:()[B
putfield sun.security.ssl.HandshakeMessage$ClientHello.compression_methods:[B
13: aload 0
invokevirtual sun.security.ssl.HandshakeMessage$ClientHello.messageLength:()I
iload 2
if_icmpeq 15
14: aload 0
new sun.security.ssl.HelloExtensions
dup
aload 1
invokespecial sun.security.ssl.HelloExtensions.<init>:(Lsun/security/ssl/HandshakeInStream;)V
putfield sun.security.ssl.HandshakeMessage$ClientHello.extensions:Lsun/security/ssl/HelloExtensions;
15: StackMap locals:
StackMap stack:
return
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 16 0 this Lsun/security/ssl/HandshakeMessage$ClientHello;
0 16 1 s Lsun/security/ssl/HandshakeInStream;
0 16 2 messageLength I
0 16 3 isDTLS Z
Exceptions:
throws java.io.IOException
MethodParameters:
Name Flags
s
messageLength
isDTLS
sun.security.ssl.CipherSuiteList getCipherSuites();
descriptor: ()Lsun/security/ssl/CipherSuiteList;
flags: (0x0000)
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield sun.security.ssl.HandshakeMessage$ClientHello.cipherSuites:Lsun/security/ssl/CipherSuiteList;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lsun/security/ssl/HandshakeMessage$ClientHello;
void addRenegotiationInfoExtension(byte[]);
descriptor: ([B)V
flags: (0x0000)
Code:
stack=4, locals=3, args_size=2
start local 0 start local 1 0: new sun.security.ssl.RenegotiationInfoExtension
dup
1: aload 1
iconst_0
newarray 8
2: invokespecial sun.security.ssl.RenegotiationInfoExtension.<init>:([B[B)V
astore 2
start local 2 3: aload 0
getfield sun.security.ssl.HandshakeMessage$ClientHello.extensions:Lsun/security/ssl/HelloExtensions;
aload 2
invokevirtual sun.security.ssl.HelloExtensions.add:(Lsun/security/ssl/HelloExtension;)V
4: return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 5 0 this Lsun/security/ssl/HandshakeMessage$ClientHello;
0 5 1 clientVerifyData [B
3 5 2 renegotiationInfo Lsun/security/ssl/HelloExtension;
MethodParameters:
Name Flags
clientVerifyData
void addSNIExtension(java.util.List<javax.net.ssl.SNIServerName>);
descriptor: (Ljava/util/List;)V
flags: (0x0000)
Code:
stack=4, locals=2, args_size=2
start local 0 start local 1 0: aload 0
getfield sun.security.ssl.HandshakeMessage$ClientHello.extensions:Lsun/security/ssl/HelloExtensions;
new sun.security.ssl.ServerNameExtension
dup
aload 1
invokespecial sun.security.ssl.ServerNameExtension.<init>:(Ljava/util/List;)V
invokevirtual sun.security.ssl.HelloExtensions.add:(Lsun/security/ssl/HelloExtension;)V
1: goto 3
StackMap locals:
StackMap stack: java.io.IOException
2: pop
3: StackMap locals:
StackMap stack:
return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lsun/security/ssl/HandshakeMessage$ClientHello;
0 4 1 serverNames Ljava/util/List<Ljavax/net/ssl/SNIServerName;>;
Exception table:
from to target type
0 1 2 Class java.io.IOException
Signature: (Ljava/util/List<Ljavax/net/ssl/SNIServerName;>;)V
MethodParameters:
Name Flags
serverNames
void addSignatureAlgorithmsExtension(java.util.Collection<sun.security.ssl.SignatureAndHashAlgorithm>);
descriptor: (Ljava/util/Collection;)V
flags: (0x0000)
Code:
stack=3, locals=3, args_size=2
start local 0 start local 1 0: new sun.security.ssl.SignatureAlgorithmsExtension
dup
aload 1
invokespecial sun.security.ssl.SignatureAlgorithmsExtension.<init>:(Ljava/util/Collection;)V
1: astore 2
start local 2 2: aload 0
getfield sun.security.ssl.HandshakeMessage$ClientHello.extensions:Lsun/security/ssl/HelloExtensions;
aload 2
invokevirtual sun.security.ssl.HelloExtensions.add:(Lsun/security/ssl/HelloExtension;)V
3: return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lsun/security/ssl/HandshakeMessage$ClientHello;
0 4 1 algorithms Ljava/util/Collection<Lsun/security/ssl/SignatureAndHashAlgorithm;>;
2 4 2 signatureAlgorithm Lsun/security/ssl/HelloExtension;
Signature: (Ljava/util/Collection<Lsun/security/ssl/SignatureAndHashAlgorithm;>;)V
MethodParameters:
Name Flags
algorithms
void addExtendedMasterSecretExtension();
descriptor: ()V
flags: (0x0000)
Code:
stack=3, locals=1, args_size=1
start local 0 0: aload 0
getfield sun.security.ssl.HandshakeMessage$ClientHello.extensions:Lsun/security/ssl/HelloExtensions;
new sun.security.ssl.ExtendedMasterSecretExtension
dup
invokespecial sun.security.ssl.ExtendedMasterSecretExtension.<init>:()V
invokevirtual sun.security.ssl.HelloExtensions.add:(Lsun/security/ssl/HelloExtension;)V
1: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lsun/security/ssl/HandshakeMessage$ClientHello;
void addMFLExtension(int);
descriptor: (I)V
flags: (0x0000)
Code:
stack=3, locals=3, args_size=2
start local 0 start local 1 0: new sun.security.ssl.MaxFragmentLengthExtension
dup
iload 1
invokespecial sun.security.ssl.MaxFragmentLengthExtension.<init>:(I)V
1: astore 2
start local 2 2: aload 0
getfield sun.security.ssl.HandshakeMessage$ClientHello.extensions:Lsun/security/ssl/HelloExtensions;
aload 2
invokevirtual sun.security.ssl.HelloExtensions.add:(Lsun/security/ssl/HelloExtension;)V
3: return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lsun/security/ssl/HandshakeMessage$ClientHello;
0 4 1 maximumPacketSize I
2 4 2 maxFragmentLength Lsun/security/ssl/HelloExtension;
MethodParameters:
Name Flags
maximumPacketSize
void updateHelloCookie(java.security.MessageDigest);
descriptor: (Ljava/security/MessageDigest;)V
flags: (0x0000)
Code:
stack=3, locals=3, args_size=2
start local 0 start local 1 0: new sun.security.ssl.HandshakeOutStream
dup
aconst_null
invokespecial sun.security.ssl.HandshakeOutStream.<init>:(Lsun/security/ssl/OutputRecord;)V
astore 2
start local 2 1: aload 0
aload 2
iconst_0
invokevirtual sun.security.ssl.HandshakeMessage$ClientHello.send:(Lsun/security/ssl/HandshakeOutStream;Z)V
2: goto 4
StackMap locals: sun.security.ssl.HandshakeMessage$ClientHello java.security.MessageDigest sun.security.ssl.HandshakeOutStream
StackMap stack: java.io.IOException
3: pop
4: StackMap locals:
StackMap stack:
aload 1
aload 2
invokevirtual sun.security.ssl.HandshakeOutStream.toByteArray:()[B
invokevirtual java.security.MessageDigest.update:([B)V
5: return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 6 0 this Lsun/security/ssl/HandshakeMessage$ClientHello;
0 6 1 cookieDigest Ljava/security/MessageDigest;
1 6 2 hos Lsun/security/ssl/HandshakeOutStream;
Exception table:
from to target type
1 2 3 Class java.io.IOException
MethodParameters:
Name Flags
cookieDigest
void addCertStatusRequestExtension();
descriptor: ()V
flags: (0x0000)
Code:
stack=6, locals=1, args_size=1
start local 0 0: aload 0
getfield sun.security.ssl.HandshakeMessage$ClientHello.extensions:Lsun/security/ssl/HelloExtensions;
new sun.security.ssl.CertStatusReqExtension
dup
getstatic sun.security.ssl.StatusRequestType.OCSP:Lsun/security/ssl/StatusRequestType;
1: new sun.security.ssl.OCSPStatusRequest
dup
invokespecial sun.security.ssl.OCSPStatusRequest.<init>:()V
invokespecial sun.security.ssl.CertStatusReqExtension.<init>:(Lsun/security/ssl/StatusRequestType;Lsun/security/ssl/StatusRequest;)V
2: invokevirtual sun.security.ssl.HelloExtensions.add:(Lsun/security/ssl/HelloExtension;)V
3: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lsun/security/ssl/HandshakeMessage$ClientHello;
void addCertStatusReqListV2Extension();
descriptor: ()V
flags: (0x0000)
Code:
stack=5, locals=3, args_size=1
start local 0 0: new sun.security.ssl.OCSPStatusRequest
dup
invokespecial sun.security.ssl.OCSPStatusRequest.<init>:()V
astore 1
start local 1 1: new java.util.ArrayList
dup
iconst_2
invokespecial java.util.ArrayList.<init>:(I)V
astore 2
start local 2 2: aload 2
new sun.security.ssl.CertStatusReqItemV2
dup
getstatic sun.security.ssl.StatusRequestType.OCSP_MULTI:Lsun/security/ssl/StatusRequestType;
3: aload 1
invokespecial sun.security.ssl.CertStatusReqItemV2.<init>:(Lsun/security/ssl/StatusRequestType;Lsun/security/ssl/StatusRequest;)V
4: invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
pop
5: aload 2
new sun.security.ssl.CertStatusReqItemV2
dup
getstatic sun.security.ssl.StatusRequestType.OCSP:Lsun/security/ssl/StatusRequestType;
aload 1
invokespecial sun.security.ssl.CertStatusReqItemV2.<init>:(Lsun/security/ssl/StatusRequestType;Lsun/security/ssl/StatusRequest;)V
invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
pop
6: aload 0
getfield sun.security.ssl.HandshakeMessage$ClientHello.extensions:Lsun/security/ssl/HelloExtensions;
new sun.security.ssl.CertStatusReqListV2Extension
dup
aload 2
invokespecial sun.security.ssl.CertStatusReqListV2Extension.<init>:(Ljava/util/List;)V
invokevirtual sun.security.ssl.HelloExtensions.add:(Lsun/security/ssl/HelloExtension;)V
7: return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 8 0 this Lsun/security/ssl/HandshakeMessage$ClientHello;
1 8 1 osr Lsun/security/ssl/OCSPStatusRequest;
2 8 2 itemList Ljava/util/List<Lsun/security/ssl/CertStatusReqItemV2;>;
void addALPNExtension(java.lang.String[]);
descriptor: ([Ljava/lang/String;)V
flags: (0x0000)
Code:
stack=4, locals=2, args_size=2
start local 0 start local 1 0: aload 0
getfield sun.security.ssl.HandshakeMessage$ClientHello.extensions:Lsun/security/ssl/HelloExtensions;
new sun.security.ssl.ALPNExtension
dup
aload 1
invokespecial sun.security.ssl.ALPNExtension.<init>:([Ljava/lang/String;)V
invokevirtual sun.security.ssl.HelloExtensions.add:(Lsun/security/ssl/HelloExtension;)V
1: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lsun/security/ssl/HandshakeMessage$ClientHello;
0 2 1 applicationProtocols [Ljava/lang/String;
Exceptions:
throws javax.net.ssl.SSLException
MethodParameters:
Name Flags
applicationProtocols
int messageType();
descriptor: ()I
flags: (0x0000)
Code:
stack=1, locals=1, args_size=1
start local 0 0: iconst_1
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lsun/security/ssl/HandshakeMessage$ClientHello;
int messageLength();
descriptor: ()I
flags: (0x0000)
Code:
stack=3, locals=1, args_size=1
start local 0 0: bipush 38
1: aload 0
getfield sun.security.ssl.HandshakeMessage$ClientHello.sessionId:Lsun/security/ssl/SessionId;
invokevirtual sun.security.ssl.SessionId.length:()I
2: iadd
3: aload 0
getfield sun.security.ssl.HandshakeMessage$ClientHello.isDTLS:Z
ifeq 4
iconst_1
aload 0
getfield sun.security.ssl.HandshakeMessage$ClientHello.cookie:[B
arraylength
iadd
goto 5
StackMap locals:
StackMap stack: int
4: iconst_0
5: StackMap locals: sun.security.ssl.HandshakeMessage$ClientHello
StackMap stack: int int
iadd
6: aload 0
getfield sun.security.ssl.HandshakeMessage$ClientHello.cipherSuites:Lsun/security/ssl/CipherSuiteList;
invokevirtual sun.security.ssl.CipherSuiteList.size:()I
iconst_2
imul
7: iadd
8: aload 0
getfield sun.security.ssl.HandshakeMessage$ClientHello.compression_methods:[B
arraylength
9: iadd
10: aload 0
getfield sun.security.ssl.HandshakeMessage$ClientHello.extensions:Lsun/security/ssl/HelloExtensions;
invokevirtual sun.security.ssl.HelloExtensions.length:()I
11: iadd
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 12 0 this Lsun/security/ssl/HandshakeMessage$ClientHello;
void send(sun.security.ssl.HandshakeOutStream);
descriptor: (Lsun/security/ssl/HandshakeOutStream;)V
flags: (0x0000)
Code:
stack=3, locals=2, args_size=2
start local 0 start local 1 0: aload 0
aload 1
iconst_1
invokevirtual sun.security.ssl.HandshakeMessage$ClientHello.send:(Lsun/security/ssl/HandshakeOutStream;Z)V
1: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lsun/security/ssl/HandshakeMessage$ClientHello;
0 2 1 s Lsun/security/ssl/HandshakeOutStream;
Exceptions:
throws java.io.IOException
MethodParameters:
Name Flags
s
void print(java.io.PrintStream);
descriptor: (Ljava/io/PrintStream;)V
flags: (0x0000)
Code:
stack=4, locals=2, args_size=2
start local 0 start local 1 0: aload 1
new java.lang.StringBuilder
dup
ldc "*** ClientHello, "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 0
getfield sun.security.ssl.HandshakeMessage$ClientHello.protocolVersion:Lsun/security/ssl/ProtocolVersion;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
1: getstatic sun.security.ssl.HandshakeMessage$ClientHello.debug:Lsun/security/ssl/Debug;
ifnull 12
ldc "verbose"
invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
ifeq 12
2: aload 1
ldc "RandomCookie: "
invokevirtual java.io.PrintStream.print:(Ljava/lang/String;)V
3: aload 0
getfield sun.security.ssl.HandshakeMessage$ClientHello.clnt_random:Lsun/security/ssl/RandomCookie;
aload 1
invokevirtual sun.security.ssl.RandomCookie.print:(Ljava/io/PrintStream;)V
4: aload 1
ldc "Session ID: "
invokevirtual java.io.PrintStream.print:(Ljava/lang/String;)V
5: aload 1
aload 0
getfield sun.security.ssl.HandshakeMessage$ClientHello.sessionId:Lsun/security/ssl/SessionId;
invokevirtual java.io.PrintStream.println:(Ljava/lang/Object;)V
6: aload 0
getfield sun.security.ssl.HandshakeMessage$ClientHello.isDTLS:Z
ifeq 8
7: aload 1
ldc "cookie"
aload 0
getfield sun.security.ssl.HandshakeMessage$ClientHello.cookie:[B
invokestatic sun.security.ssl.Debug.println:(Ljava/io/PrintStream;Ljava/lang/String;[B)V
8: StackMap locals:
StackMap stack:
aload 1
new java.lang.StringBuilder
dup
ldc "Cipher Suites: "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 0
getfield sun.security.ssl.HandshakeMessage$ClientHello.cipherSuites:Lsun/security/ssl/CipherSuiteList;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
9: aload 1
ldc "Compression Methods"
aload 0
getfield sun.security.ssl.HandshakeMessage$ClientHello.compression_methods:[B
invokestatic sun.security.ssl.Debug.println:(Ljava/io/PrintStream;Ljava/lang/String;[B)V
10: aload 0
getfield sun.security.ssl.HandshakeMessage$ClientHello.extensions:Lsun/security/ssl/HelloExtensions;
aload 1
invokevirtual sun.security.ssl.HelloExtensions.print:(Ljava/io/PrintStream;)V
11: aload 1
ldc "***"
invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
12: StackMap locals:
StackMap stack:
return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 13 0 this Lsun/security/ssl/HandshakeMessage$ClientHello;
0 13 1 s Ljava/io/PrintStream;
Exceptions:
throws java.io.IOException
MethodParameters:
Name Flags
s
private void send(sun.security.ssl.HandshakeOutStream, boolean);
descriptor: (Lsun/security/ssl/HandshakeOutStream;Z)V
flags: (0x0002) ACC_PRIVATE
Code:
stack=2, locals=3, args_size=3
start local 0 start local 1 start local 2 0: aload 1
aload 0
getfield sun.security.ssl.HandshakeMessage$ClientHello.protocolVersion:Lsun/security/ssl/ProtocolVersion;
getfield sun.security.ssl.ProtocolVersion.major:B
invokevirtual sun.security.ssl.HandshakeOutStream.putInt8:(I)V
1: aload 1
aload 0
getfield sun.security.ssl.HandshakeMessage$ClientHello.protocolVersion:Lsun/security/ssl/ProtocolVersion;
getfield sun.security.ssl.ProtocolVersion.minor:B
invokevirtual sun.security.ssl.HandshakeOutStream.putInt8:(I)V
2: aload 0
getfield sun.security.ssl.HandshakeMessage$ClientHello.clnt_random:Lsun/security/ssl/RandomCookie;
aload 1
invokevirtual sun.security.ssl.RandomCookie.send:(Lsun/security/ssl/HandshakeOutStream;)V
3: aload 1
aload 0
getfield sun.security.ssl.HandshakeMessage$ClientHello.sessionId:Lsun/security/ssl/SessionId;
invokevirtual sun.security.ssl.SessionId.getId:()[B
invokevirtual sun.security.ssl.HandshakeOutStream.putBytes8:([B)V
4: aload 0
getfield sun.security.ssl.HandshakeMessage$ClientHello.isDTLS:Z
ifeq 6
iload 2
ifeq 6
5: aload 1
aload 0
getfield sun.security.ssl.HandshakeMessage$ClientHello.cookie:[B
invokevirtual sun.security.ssl.HandshakeOutStream.putBytes8:([B)V
6: StackMap locals:
StackMap stack:
aload 0
getfield sun.security.ssl.HandshakeMessage$ClientHello.cipherSuites:Lsun/security/ssl/CipherSuiteList;
aload 1
invokevirtual sun.security.ssl.CipherSuiteList.send:(Lsun/security/ssl/HandshakeOutStream;)V
7: aload 1
aload 0
getfield sun.security.ssl.HandshakeMessage$ClientHello.compression_methods:[B
invokevirtual sun.security.ssl.HandshakeOutStream.putBytes8:([B)V
8: aload 0
getfield sun.security.ssl.HandshakeMessage$ClientHello.extensions:Lsun/security/ssl/HelloExtensions;
aload 1
invokevirtual sun.security.ssl.HelloExtensions.send:(Lsun/security/ssl/HandshakeOutStream;)V
9: return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 10 0 this Lsun/security/ssl/HandshakeMessage$ClientHello;
0 10 1 s Lsun/security/ssl/HandshakeOutStream;
0 10 2 computeCookie Z
Exceptions:
throws java.io.IOException
MethodParameters:
Name Flags
s
computeCookie
}
SourceFile: "HandshakeMessage.java"
NestHost: sun.security.ssl.HandshakeMessage
InnerClasses:
final ClientHello = sun.security.ssl.HandshakeMessage$ClientHello of sun.security.ssl.HandshakeMessage