final class sun.security.ssl.KrbClientKeyExchange$KrbClientKeyExchangeMessage extends sun.security.ssl.SSLHandshake$HandshakeMessage
minor version: 0
major version: 59
flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
this_class: sun.security.ssl.KrbClientKeyExchange$KrbClientKeyExchangeMessage
super_class: sun.security.ssl.SSLHandshake$HandshakeMessage
{
private static final java.lang.String KRB5_CLASS_NAME;
descriptor: Ljava/lang/String;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
ConstantValue: "sun.security.ssl.krb5.KrbClientKeyExchangeHelperImpl"
private static final java.lang.Class<?> krb5Class;
descriptor: Ljava/lang/Class;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
Signature: Ljava/lang/Class<*>;
private final sun.security.ssl.KrbClientKeyExchangeHelper krb5Helper;
descriptor: Lsun/security/ssl/KrbClientKeyExchangeHelper;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
static void <clinit>();
descriptor: ()V
flags: (0x0008) ACC_STATIC
Code:
stack=2, locals=0, args_size=0
0: new sun.security.ssl.KrbClientKeyExchange$KrbClientKeyExchangeMessage$1
dup
invokespecial sun.security.ssl.KrbClientKeyExchange$KrbClientKeyExchangeMessage$1.<init>:()V
1: invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedAction;)Ljava/lang/Object;
checkcast java.lang.Class
putstatic sun.security.ssl.KrbClientKeyExchange$KrbClientKeyExchangeMessage.krb5Class:Ljava/lang/Class;
2: return
LocalVariableTable:
Start End Slot Name Signature
private static sun.security.ssl.KrbClientKeyExchangeHelper newKrb5Instance();
descriptor: ()Lsun/security/ssl/KrbClientKeyExchangeHelper;
flags: (0x000a) ACC_PRIVATE, ACC_STATIC
Code:
stack=3, locals=1, args_size=0
0: getstatic sun.security.ssl.KrbClientKeyExchange$KrbClientKeyExchangeMessage.krb5Class:Ljava/lang/Class;
ifnull 6
1: getstatic sun.security.ssl.KrbClientKeyExchange$KrbClientKeyExchangeMessage.krb5Class:Ljava/lang/Class;
iconst_0
anewarray java.lang.Class
2: invokevirtual java.lang.Class.getDeclaredConstructor:([Ljava/lang/Class;)Ljava/lang/reflect/Constructor;
iconst_0
anewarray java.lang.Object
invokevirtual java.lang.reflect.Constructor.newInstance:([Ljava/lang/Object;)Ljava/lang/Object;
checkcast sun.security.ssl.KrbClientKeyExchangeHelper
3: areturn
4: StackMap locals:
StackMap stack: java.lang.ReflectiveOperationException
astore 0
start local 0 5: new java.lang.AssertionError
dup
aload 0
invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
athrow
end local 0 6: StackMap locals:
StackMap stack:
aconst_null
areturn
LocalVariableTable:
Start End Slot Name Signature
5 6 0 e Ljava/lang/ReflectiveOperationException;
Exception table:
from to target type
1 3 4 Class java.lang.InstantiationException
1 3 4 Class java.lang.IllegalAccessException
1 3 4 Class java.lang.NoSuchMethodException
1 3 4 Class java.lang.reflect.InvocationTargetException
private void <init>(sun.security.ssl.HandshakeContext);
descriptor: (Lsun/security/ssl/HandshakeContext;)V
flags: (0x0002) ACC_PRIVATE
Code:
stack=3, locals=2, 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 0
invokestatic sun.security.ssl.KrbClientKeyExchange$KrbClientKeyExchangeMessage.newKrb5Instance:()Lsun/security/ssl/KrbClientKeyExchangeHelper;
dup_x1
putfield sun.security.ssl.KrbClientKeyExchange$KrbClientKeyExchangeMessage.krb5Helper:Lsun/security/ssl/KrbClientKeyExchangeHelper;
ifnonnull 3
2: new java.lang.IllegalStateException
dup
ldc "Kerberos is unavailable"
invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
athrow
3: StackMap locals: sun.security.ssl.KrbClientKeyExchange$KrbClientKeyExchangeMessage sun.security.ssl.HandshakeContext
StackMap stack:
return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lsun/security/ssl/KrbClientKeyExchange$KrbClientKeyExchangeMessage;
0 4 1 context Lsun/security/ssl/HandshakeContext;
MethodParameters:
Name Flags
context
void <init>(sun.security.ssl.HandshakeContext, byte[], java.lang.String, java.security.AccessControlContext);
descriptor: (Lsun/security/ssl/HandshakeContext;[BLjava/lang/String;Ljava/security/AccessControlContext;)V
flags: (0x0000)
Code:
stack=4, locals=5, args_size=5
start local 0 start local 1 start local 2 start local 3 start local 4 0: aload 0
aload 1
invokespecial sun.security.ssl.KrbClientKeyExchange$KrbClientKeyExchangeMessage.<init>:(Lsun/security/ssl/HandshakeContext;)V
1: aload 0
getfield sun.security.ssl.KrbClientKeyExchange$KrbClientKeyExchangeMessage.krb5Helper:Lsun/security/ssl/KrbClientKeyExchangeHelper;
aload 2
aload 3
aload 4
invokeinterface sun.security.ssl.KrbClientKeyExchangeHelper.init:([BLjava/lang/String;Ljava/security/AccessControlContext;)V
2: return
end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lsun/security/ssl/KrbClientKeyExchange$KrbClientKeyExchangeMessage;
0 3 1 context Lsun/security/ssl/HandshakeContext;
0 3 2 preMaster [B
0 3 3 serverName Ljava/lang/String;
0 3 4 acc Ljava/security/AccessControlContext;
Exceptions:
throws java.io.IOException
MethodParameters:
Name Flags
context
preMaster
serverName
acc
void <init>(sun.security.ssl.HandshakeContext, java.nio.ByteBuffer, java.lang.Object, java.security.AccessControlContext);
descriptor: (Lsun/security/ssl/HandshakeContext;Ljava/nio/ByteBuffer;Ljava/lang/Object;Ljava/security/AccessControlContext;)V
flags: (0x0000)
Code:
stack=5, locals=7, args_size=5
start local 0 start local 1 start local 2 start local 3 start local 4 0: aload 0
aload 1
invokespecial sun.security.ssl.KrbClientKeyExchange$KrbClientKeyExchangeMessage.<init>:(Lsun/security/ssl/HandshakeContext;)V
1: aload 2
invokestatic sun.security.ssl.Record.getBytes16:(Ljava/nio/ByteBuffer;)[B
astore 5
start local 5 2: getstatic sun.security.ssl.SSLLogger.isOn:Z
ifeq 6
ldc "ssl,handshake"
invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
ifeq 6
3: ldc "encoded Kerberos service ticket"
iconst_1
anewarray java.lang.Object
dup
iconst_0
4: aload 5
aastore
5: invokestatic sun.security.ssl.SSLLogger.fine:(Ljava/lang/String;[Ljava/lang/Object;)V
6: StackMap locals: sun.security.ssl.KrbClientKeyExchange$KrbClientKeyExchangeMessage sun.security.ssl.HandshakeContext java.nio.ByteBuffer java.lang.Object java.security.AccessControlContext byte[]
StackMap stack:
aload 2
invokestatic sun.security.ssl.Record.getBytes16:(Ljava/nio/ByteBuffer;)[B
pop
7: aload 2
invokestatic sun.security.ssl.Record.getBytes16:(Ljava/nio/ByteBuffer;)[B
astore 6
start local 6 8: aload 6
ifnull 13
getstatic sun.security.ssl.SSLLogger.isOn:Z
ifeq 13
9: ldc "ssl,handshake"
invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
ifeq 13
10: ldc "encrypted Kerberos pre-master secret"
iconst_1
anewarray java.lang.Object
dup
iconst_0
11: aload 6
aastore
12: invokestatic sun.security.ssl.SSLLogger.fine:(Ljava/lang/String;[Ljava/lang/Object;)V
13: StackMap locals: byte[]
StackMap stack:
aload 0
getfield sun.security.ssl.KrbClientKeyExchange$KrbClientKeyExchangeMessage.krb5Helper:Lsun/security/ssl/KrbClientKeyExchangeHelper;
aload 5
aload 6
14: aload 3
aload 4
15: invokeinterface sun.security.ssl.KrbClientKeyExchangeHelper.init:([B[BLjava/lang/Object;Ljava/security/AccessControlContext;)V
16: return
end local 6 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 17 0 this Lsun/security/ssl/KrbClientKeyExchange$KrbClientKeyExchangeMessage;
0 17 1 context Lsun/security/ssl/HandshakeContext;
0 17 2 message Ljava/nio/ByteBuffer;
0 17 3 serverKeys Ljava/lang/Object;
0 17 4 acc Ljava/security/AccessControlContext;
2 17 5 encodedTicket [B
8 17 6 encryptedPreMasterSecret [B
Exceptions:
throws java.io.IOException
MethodParameters:
Name Flags
context
message
serverKeys
acc
sun.security.ssl.SSLHandshake handshakeType();
descriptor: ()Lsun/security/ssl/SSLHandshake;
flags: (0x0000)
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/KrbClientKeyExchange$KrbClientKeyExchangeMessage;
int messageLength();
descriptor: ()I
flags: (0x0000)
Code:
stack=2, locals=1, args_size=1
start local 0 0: bipush 6
aload 0
getfield sun.security.ssl.KrbClientKeyExchange$KrbClientKeyExchangeMessage.krb5Helper:Lsun/security/ssl/KrbClientKeyExchangeHelper;
invokeinterface sun.security.ssl.KrbClientKeyExchangeHelper.getEncodedTicket:()[B
arraylength
iadd
1: aload 0
getfield sun.security.ssl.KrbClientKeyExchange$KrbClientKeyExchangeMessage.krb5Helper:Lsun/security/ssl/KrbClientKeyExchangeHelper;
invokeinterface sun.security.ssl.KrbClientKeyExchangeHelper.getEncryptedPreMasterSecret:()[B
arraylength
2: iadd
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lsun/security/ssl/KrbClientKeyExchange$KrbClientKeyExchangeMessage;
void send(sun.security.ssl.HandshakeOutStream);
descriptor: (Lsun/security/ssl/HandshakeOutStream;)V
flags: (0x0000)
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 1
aload 0
getfield sun.security.ssl.KrbClientKeyExchange$KrbClientKeyExchangeMessage.krb5Helper:Lsun/security/ssl/KrbClientKeyExchangeHelper;
invokeinterface sun.security.ssl.KrbClientKeyExchangeHelper.getEncodedTicket:()[B
invokevirtual sun.security.ssl.HandshakeOutStream.putBytes16:([B)V
1: aload 1
aconst_null
invokevirtual sun.security.ssl.HandshakeOutStream.putBytes16:([B)V
2: aload 1
aload 0
getfield sun.security.ssl.KrbClientKeyExchange$KrbClientKeyExchangeMessage.krb5Helper:Lsun/security/ssl/KrbClientKeyExchangeHelper;
invokeinterface sun.security.ssl.KrbClientKeyExchangeHelper.getEncryptedPreMasterSecret:()[B
invokevirtual sun.security.ssl.HandshakeOutStream.putBytes16:([B)V
3: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lsun/security/ssl/KrbClientKeyExchange$KrbClientKeyExchangeMessage;
0 4 1 hos Lsun/security/ssl/HandshakeOutStream;
Exceptions:
throws java.io.IOException
MethodParameters:
Name Flags
hos
byte[] getPlainPreMasterSecret();
descriptor: ()[B
flags: (0x0000)
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield sun.security.ssl.KrbClientKeyExchange$KrbClientKeyExchangeMessage.krb5Helper:Lsun/security/ssl/KrbClientKeyExchangeHelper;
invokeinterface sun.security.ssl.KrbClientKeyExchangeHelper.getPlainPreMasterSecret:()[B
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lsun/security/ssl/KrbClientKeyExchange$KrbClientKeyExchangeMessage;
java.security.Principal getPeerPrincipal();
descriptor: ()Ljava/security/Principal;
flags: (0x0000)
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield sun.security.ssl.KrbClientKeyExchange$KrbClientKeyExchangeMessage.krb5Helper:Lsun/security/ssl/KrbClientKeyExchangeHelper;
invokeinterface sun.security.ssl.KrbClientKeyExchangeHelper.getPeerPrincipal:()Ljava/security/Principal;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lsun/security/ssl/KrbClientKeyExchange$KrbClientKeyExchangeMessage;
java.security.Principal getLocalPrincipal();
descriptor: ()Ljava/security/Principal;
flags: (0x0000)
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield sun.security.ssl.KrbClientKeyExchange$KrbClientKeyExchangeMessage.krb5Helper:Lsun/security/ssl/KrbClientKeyExchangeHelper;
invokeinterface sun.security.ssl.KrbClientKeyExchangeHelper.getLocalPrincipal:()Ljava/security/Principal;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lsun/security/ssl/KrbClientKeyExchange$KrbClientKeyExchangeMessage;
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 "\"KRB5 ClientKeyExchange\": '{'\n \"ticket\": '{'\n{0}\n '}'\n \"pre-master\": '{'\n \"plain\": '{'\n{1}\n '}'\n \"encrypted\": '{'\n{2}\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.misc.HexDumpEncoder
dup
invokespecial sun.misc.HexDumpEncoder.<init>:()V
astore 2
start local 2 5: iconst_3
anewarray java.lang.Object
dup
iconst_0
6: aload 2
7: aload 0
getfield sun.security.ssl.KrbClientKeyExchange$KrbClientKeyExchangeMessage.krb5Helper:Lsun/security/ssl/KrbClientKeyExchangeHelper;
invokeinterface sun.security.ssl.KrbClientKeyExchangeHelper.getEncodedTicket:()[B
8: invokevirtual sun.misc.HexDumpEncoder.encodeBuffer:([B)Ljava/lang/String;
9: ldc " "
10: invokestatic sun.security.ssl.Utilities.indent:(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
aastore
dup
iconst_1
11: aload 2
12: aload 0
getfield sun.security.ssl.KrbClientKeyExchange$KrbClientKeyExchangeMessage.krb5Helper:Lsun/security/ssl/KrbClientKeyExchangeHelper;
invokeinterface sun.security.ssl.KrbClientKeyExchangeHelper.getPlainPreMasterSecret:()[B
13: invokevirtual sun.misc.HexDumpEncoder.encodeBuffer:([B)Ljava/lang/String;
14: ldc " "
15: invokestatic sun.security.ssl.Utilities.indent:(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
aastore
dup
iconst_2
16: aload 2
17: aload 0
getfield sun.security.ssl.KrbClientKeyExchange$KrbClientKeyExchangeMessage.krb5Helper:Lsun/security/ssl/KrbClientKeyExchangeHelper;
invokeinterface sun.security.ssl.KrbClientKeyExchangeHelper.getEncryptedPreMasterSecret:()[B
18: invokevirtual sun.misc.HexDumpEncoder.encodeBuffer:([B)Ljava/lang/String;
19: ldc " "
20: invokestatic sun.security.ssl.Utilities.indent:(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
aastore
21: astore 3
start local 3 22: 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 23 0 this Lsun/security/ssl/KrbClientKeyExchange$KrbClientKeyExchangeMessage;
4 23 1 messageFormat Ljava/text/MessageFormat;
5 23 2 hexEncoder Lsun/misc/HexDumpEncoder;
22 23 3 messageFields [Ljava/lang/Object;
}
SourceFile: "KrbClientKeyExchange.java"
NestHost: sun.security.ssl.KrbClientKeyExchange
InnerClasses:
private final KrbClientKeyExchangeMessage = sun.security.ssl.KrbClientKeyExchange$KrbClientKeyExchangeMessage of sun.security.ssl.KrbClientKeyExchange
sun.security.ssl.KrbClientKeyExchange$KrbClientKeyExchangeMessage$1
abstract HandshakeMessage = sun.security.ssl.SSLHandshake$HandshakeMessage of sun.security.ssl.SSLHandshake