public final class sun.security.ssl.krb5.KerberosClientKeyExchangeImpl extends sun.security.ssl.KerberosClientKeyExchange
  minor version: 0
  major version: 59
  flags: flags: (0x0031) ACC_PUBLIC, ACC_FINAL, ACC_SUPER
  this_class: sun.security.ssl.krb5.KerberosClientKeyExchangeImpl
  super_class: sun.security.ssl.KerberosClientKeyExchange
{
  private sun.security.ssl.krb5.KerberosPreMasterSecret preMaster;
    descriptor: Lsun/security/ssl/krb5/KerberosPreMasterSecret;
    flags: (0x0002) ACC_PRIVATE

  private byte[] encodedTicket;
    descriptor: [B
    flags: (0x0002) ACC_PRIVATE

  private javax.security.auth.kerberos.KerberosPrincipal peerPrincipal;
    descriptor: Ljavax/security/auth/kerberos/KerberosPrincipal;
    flags: (0x0002) ACC_PRIVATE

  private javax.security.auth.kerberos.KerberosPrincipal localPrincipal;
    descriptor: Ljavax/security/auth/kerberos/KerberosPrincipal;
    flags: (0x0002) ACC_PRIVATE

  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.ssl.krb5.KerberosClientKeyExchangeImpl this
         0: .line 91
            aload 0 /* this */
            invokespecial sun.security.ssl.KerberosClientKeyExchange.<init>:()V
         1: .line 92
            return
        end local 0 // sun.security.ssl.krb5.KerberosClientKeyExchangeImpl this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lsun/security/ssl/krb5/KerberosClientKeyExchangeImpl;

  public void init(java.lang.String, boolean, java.security.AccessControlContext, sun.security.ssl.ProtocolVersion, java.security.SecureRandom);
    descriptor: (Ljava/lang/String;ZLjava/security/AccessControlContext;Lsun/security/ssl/ProtocolVersion;Ljava/security/SecureRandom;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=8, args_size=6
        start local 0 // sun.security.ssl.krb5.KerberosClientKeyExchangeImpl this
        start local 1 // java.lang.String serverName
        start local 2 // boolean isLoopback
        start local 3 // java.security.AccessControlContext acc
        start local 4 // sun.security.ssl.ProtocolVersion protocolVersion
        start local 5 // java.security.SecureRandom rand
         0: .line 112
            aload 1 /* serverName */
            iload 2 /* isLoopback */
            aload 3 /* acc */
            invokestatic sun.security.ssl.krb5.KerberosClientKeyExchangeImpl.getServiceTicket:(Ljava/lang/String;ZLjava/security/AccessControlContext;)Ljavax/security/auth/kerberos/KerberosTicket;
            astore 6 /* ticket */
        start local 6 // javax.security.auth.kerberos.KerberosTicket ticket
         1: .line 113
            aload 0 /* this */
            aload 6 /* ticket */
            invokevirtual javax.security.auth.kerberos.KerberosTicket.getEncoded:()[B
            putfield sun.security.ssl.krb5.KerberosClientKeyExchangeImpl.encodedTicket:[B
         2: .line 116
            aload 0 /* this */
            aload 6 /* ticket */
            invokevirtual javax.security.auth.kerberos.KerberosTicket.getServer:()Ljavax/security/auth/kerberos/KerberosPrincipal;
            putfield sun.security.ssl.krb5.KerberosClientKeyExchangeImpl.peerPrincipal:Ljavax/security/auth/kerberos/KerberosPrincipal;
         3: .line 117
            aload 0 /* this */
            aload 6 /* ticket */
            invokevirtual javax.security.auth.kerberos.KerberosTicket.getClient:()Ljavax/security/auth/kerberos/KerberosPrincipal;
            putfield sun.security.ssl.krb5.KerberosClientKeyExchangeImpl.localPrincipal:Ljavax/security/auth/kerberos/KerberosPrincipal;
         4: .line 123
            new sun.security.krb5.EncryptionKey
            dup
         5: .line 124
            aload 6 /* ticket */
            invokevirtual javax.security.auth.kerberos.KerberosTicket.getSessionKeyType:()I
         6: .line 125
            aload 6 /* ticket */
            invokevirtual javax.security.auth.kerberos.KerberosTicket.getSessionKey:()Ljavax/crypto/SecretKey;
            invokeinterface javax.crypto.SecretKey.getEncoded:()[B
         7: .line 123
            invokespecial sun.security.krb5.EncryptionKey.<init>:(I[B)V
            astore 7 /* sessionKey */
        start local 7 // sun.security.krb5.EncryptionKey sessionKey
         8: .line 127
            aload 0 /* this */
            new sun.security.ssl.krb5.KerberosPreMasterSecret
            dup
            aload 4 /* protocolVersion */
         9: .line 128
            aload 5 /* rand */
            aload 7 /* sessionKey */
            invokespecial sun.security.ssl.krb5.KerberosPreMasterSecret.<init>:(Lsun/security/ssl/ProtocolVersion;Ljava/security/SecureRandom;Lsun/security/krb5/EncryptionKey;)V
        10: .line 127
            putfield sun.security.ssl.krb5.KerberosClientKeyExchangeImpl.preMaster:Lsun/security/ssl/krb5/KerberosPreMasterSecret;
        11: .line 129
            return
        end local 7 // sun.security.krb5.EncryptionKey sessionKey
        end local 6 // javax.security.auth.kerberos.KerberosTicket ticket
        end local 5 // java.security.SecureRandom rand
        end local 4 // sun.security.ssl.ProtocolVersion protocolVersion
        end local 3 // java.security.AccessControlContext acc
        end local 2 // boolean isLoopback
        end local 1 // java.lang.String serverName
        end local 0 // sun.security.ssl.krb5.KerberosClientKeyExchangeImpl this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0   12     0             this  Lsun/security/ssl/krb5/KerberosClientKeyExchangeImpl;
            0   12     1       serverName  Ljava/lang/String;
            0   12     2       isLoopback  Z
            0   12     3              acc  Ljava/security/AccessControlContext;
            0   12     4  protocolVersion  Lsun/security/ssl/ProtocolVersion;
            0   12     5             rand  Ljava/security/SecureRandom;
            1   12     6           ticket  Ljavax/security/auth/kerberos/KerberosTicket;
            8   12     7       sessionKey  Lsun/security/krb5/EncryptionKey;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
                 Name  Flags
      serverName       
      isLoopback       
      acc              
      protocolVersion  
      rand             

  public void init(sun.security.ssl.ProtocolVersion, sun.security.ssl.ProtocolVersion, java.security.SecureRandom, sun.security.ssl.HandshakeInStream, javax.crypto.SecretKey[]);
    descriptor: (Lsun/security/ssl/ProtocolVersion;Lsun/security/ssl/ProtocolVersion;Ljava/security/SecureRandom;Lsun/security/ssl/HandshakeInStream;[Ljavax/crypto/SecretKey;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=8, locals=20, args_size=6
        start local 0 // sun.security.ssl.krb5.KerberosClientKeyExchangeImpl this
        start local 1 // sun.security.ssl.ProtocolVersion protocolVersion
        start local 2 // sun.security.ssl.ProtocolVersion clientVersion
        start local 3 // java.security.SecureRandom rand
        start local 4 // sun.security.ssl.HandshakeInStream input
        start local 5 // javax.crypto.SecretKey[] secretKeys
         0: .line 149
            aload 5 /* secretKeys */
            checkcast javax.security.auth.kerberos.KerberosKey[]
            astore 6 /* serverKeys */
        start local 6 // javax.security.auth.kerberos.KerberosKey[] serverKeys
         1: .line 152
            aload 0 /* this */
            aload 4 /* input */
            invokevirtual sun.security.ssl.HandshakeInStream.getBytes16:()[B
            putfield sun.security.ssl.krb5.KerberosClientKeyExchangeImpl.encodedTicket:[B
         2: .line 154
            getstatic sun.security.ssl.krb5.KerberosClientKeyExchangeImpl.debug:Lsun/security/ssl/Debug;
            ifnull 6
            ldc "verbose"
            invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
            ifeq 6
         3: .line 155
            getstatic java.lang.System.out:Ljava/io/PrintStream;
         4: .line 156
            ldc "encoded Kerberos service ticket"
            aload 0 /* this */
            getfield sun.security.ssl.krb5.KerberosClientKeyExchangeImpl.encodedTicket:[B
         5: .line 155
            invokestatic sun.security.ssl.Debug.println:(Ljava/io/PrintStream;Ljava/lang/String;[B)V
         6: .line 159
      StackMap locals: javax.security.auth.kerberos.KerberosKey[]
      StackMap stack:
            aconst_null
            astore 7 /* sessionKey */
        start local 7 // sun.security.krb5.EncryptionKey sessionKey
         7: .line 162
            new sun.security.krb5.internal.Ticket
            dup
            aload 0 /* this */
            getfield sun.security.ssl.krb5.KerberosClientKeyExchangeImpl.encodedTicket:[B
            invokespecial sun.security.krb5.internal.Ticket.<init>:([B)V
            astore 8 /* t */
        start local 8 // sun.security.krb5.internal.Ticket t
         8: .line 164
            aload 8 /* t */
            getfield sun.security.krb5.internal.Ticket.encPart:Lsun/security/krb5/EncryptedData;
            astore 9 /* encPart */
        start local 9 // sun.security.krb5.EncryptedData encPart
         9: .line 165
            aload 8 /* t */
            getfield sun.security.krb5.internal.Ticket.sname:Lsun/security/krb5/PrincipalName;
            astore 10 /* ticketSname */
        start local 10 // sun.security.krb5.PrincipalName ticketSname
        10: .line 166
            aload 8 /* t */
            getfield sun.security.krb5.internal.Ticket.sname:Lsun/security/krb5/PrincipalName;
            invokevirtual sun.security.krb5.PrincipalName.getRealm:()Lsun/security/krb5/Realm;
            pop
        11: .line 168
            aload 6 /* serverKeys */
            iconst_0
            aaload
            invokevirtual javax.security.auth.kerberos.KerberosKey.getPrincipal:()Ljavax/security/auth/kerberos/KerberosPrincipal;
            invokevirtual javax.security.auth.kerberos.KerberosPrincipal.getName:()Ljava/lang/String;
            astore 11 /* serverPrincipal */
        start local 11 // java.lang.String serverPrincipal
        12: .line 178
            aload 10 /* ticketSname */
            invokevirtual sun.security.krb5.PrincipalName.toString:()Ljava/lang/String;
            astore 12 /* ticketPrinc */
        start local 12 // java.lang.String ticketPrinc
        13: .line 179
            aload 12 /* ticketPrinc */
            aload 11 /* serverPrincipal */
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 20
        14: .line 180
            getstatic sun.security.ssl.krb5.KerberosClientKeyExchangeImpl.debug:Lsun/security/ssl/Debug;
            ifnull 16
            ldc "handshake"
            invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
            ifeq 16
        15: .line 181
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc "Service principal in Ticket does not match associated principal in KerberosKey"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        16: .line 183
      StackMap locals: sun.security.ssl.krb5.KerberosClientKeyExchangeImpl sun.security.ssl.ProtocolVersion sun.security.ssl.ProtocolVersion java.security.SecureRandom sun.security.ssl.HandshakeInStream javax.crypto.SecretKey[] javax.security.auth.kerberos.KerberosKey[] sun.security.krb5.EncryptionKey sun.security.krb5.internal.Ticket sun.security.krb5.EncryptedData sun.security.krb5.PrincipalName java.lang.String java.lang.String
      StackMap stack:
            new java.io.IOException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Server principal is "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        17: .line 184
            aload 11 /* serverPrincipal */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc " but ticket is for "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        18: .line 185
            aload 12 /* ticketPrinc */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        19: .line 183
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        20: .line 190
      StackMap locals:
      StackMap stack:
            aload 9 /* encPart */
            invokevirtual sun.security.krb5.EncryptedData.getEType:()I
            istore 13 /* encPartKeyType */
        start local 13 // int encPartKeyType
        21: .line 191
            aload 9 /* encPart */
            invokevirtual sun.security.krb5.EncryptedData.getKeyVersionNumber:()Ljava/lang/Integer;
            astore 14 /* encPartKeyVersion */
        start local 14 // java.lang.Integer encPartKeyVersion
        22: .line 192
            aconst_null
            astore 15 /* dkey */
        start local 15 // javax.security.auth.kerberos.KerberosKey dkey
        23: .line 194
            iload 13 /* encPartKeyType */
            aload 14 /* encPartKeyVersion */
            aload 6 /* serverKeys */
            invokestatic sun.security.ssl.krb5.KerberosClientKeyExchangeImpl.findKey:(ILjava/lang/Integer;[Ljavax/security/auth/kerberos/KerberosKey;)Ljavax/security/auth/kerberos/KerberosKey;
            astore 15 /* dkey */
        24: .line 195
            goto 29
      StackMap locals: sun.security.ssl.krb5.KerberosClientKeyExchangeImpl sun.security.ssl.ProtocolVersion sun.security.ssl.ProtocolVersion java.security.SecureRandom sun.security.ssl.HandshakeInStream javax.crypto.SecretKey[] javax.security.auth.kerberos.KerberosKey[] sun.security.krb5.EncryptionKey sun.security.krb5.internal.Ticket sun.security.krb5.EncryptedData sun.security.krb5.PrincipalName java.lang.String java.lang.String int java.lang.Integer javax.security.auth.kerberos.KerberosKey
      StackMap stack: sun.security.krb5.KrbException
        25: astore 16 /* ke */
        start local 16 // sun.security.krb5.KrbException ke
        26: .line 196
            new java.io.IOException
            dup
        27: .line 197
            ldc "Cannot find key matching version number"
            aload 16 /* ke */
        28: .line 196
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 16 // sun.security.krb5.KrbException ke
        29: .line 199
      StackMap locals:
      StackMap stack:
            aload 15 /* dkey */
            ifnonnull 35
        30: .line 201
            new java.io.IOException
            dup
        31: .line 202
            new java.lang.StringBuilder
            dup
            ldc "Cannot find key of appropriate type to decrypt ticket - need etype "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        32: .line 203
            iload 13 /* encPartKeyType */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
        33: .line 202
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        34: .line 201
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        35: .line 206
      StackMap locals:
      StackMap stack:
            new sun.security.krb5.EncryptionKey
            dup
        36: .line 207
            iload 13 /* encPartKeyType */
        37: .line 208
            aload 15 /* dkey */
            invokevirtual javax.security.auth.kerberos.KerberosKey.getEncoded:()[B
        38: .line 206
            invokespecial sun.security.krb5.EncryptionKey.<init>:(I[B)V
            astore 16 /* secretKey */
        start local 16 // sun.security.krb5.EncryptionKey secretKey
        39: .line 211
            aload 9 /* encPart */
            aload 16 /* secretKey */
            iconst_2
            invokevirtual sun.security.krb5.EncryptedData.decrypt:(Lsun/security/krb5/EncryptionKey;I)[B
            astore 17 /* bytes */
        start local 17 // byte[] bytes
        40: .line 214
            aload 9 /* encPart */
            aload 17 /* bytes */
            invokevirtual sun.security.krb5.EncryptedData.reset:([B)[B
            astore 18 /* temp */
        start local 18 // byte[] temp
        41: .line 215
            new sun.security.krb5.internal.EncTicketPart
            dup
            aload 18 /* temp */
            invokespecial sun.security.krb5.internal.EncTicketPart.<init>:([B)V
            astore 19 /* encTicketPart */
        start local 19 // sun.security.krb5.internal.EncTicketPart encTicketPart
        42: .line 218
            aload 0 /* this */
        43: .line 219
            new javax.security.auth.kerberos.KerberosPrincipal
            dup
            aload 19 /* encTicketPart */
            getfield sun.security.krb5.internal.EncTicketPart.cname:Lsun/security/krb5/PrincipalName;
            invokevirtual sun.security.krb5.PrincipalName.getName:()Ljava/lang/String;
            invokespecial javax.security.auth.kerberos.KerberosPrincipal.<init>:(Ljava/lang/String;)V
        44: .line 218
            putfield sun.security.ssl.krb5.KerberosClientKeyExchangeImpl.peerPrincipal:Ljavax/security/auth/kerberos/KerberosPrincipal;
        45: .line 220
            aload 0 /* this */
            new javax.security.auth.kerberos.KerberosPrincipal
            dup
            aload 10 /* ticketSname */
            invokevirtual sun.security.krb5.PrincipalName.getName:()Ljava/lang/String;
            invokespecial javax.security.auth.kerberos.KerberosPrincipal.<init>:(Ljava/lang/String;)V
            putfield sun.security.ssl.krb5.KerberosClientKeyExchangeImpl.localPrincipal:Ljavax/security/auth/kerberos/KerberosPrincipal;
        46: .line 222
            aload 19 /* encTicketPart */
            getfield sun.security.krb5.internal.EncTicketPart.key:Lsun/security/krb5/EncryptionKey;
            astore 7 /* sessionKey */
        47: .line 224
            getstatic sun.security.ssl.krb5.KerberosClientKeyExchangeImpl.debug:Lsun/security/ssl/Debug;
            ifnull 59
            ldc "handshake"
            invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
            ifeq 59
        48: .line 225
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "server principal: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 11 /* serverPrincipal */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        49: .line 226
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "cname: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 19 /* encTicketPart */
            getfield sun.security.krb5.internal.EncTicketPart.cname:Lsun/security/krb5/PrincipalName;
            invokevirtual sun.security.krb5.PrincipalName.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        end local 19 // sun.security.krb5.internal.EncTicketPart encTicketPart
        end local 18 // byte[] temp
        end local 17 // byte[] bytes
        end local 16 // sun.security.krb5.EncryptionKey secretKey
        end local 15 // javax.security.auth.kerberos.KerberosKey dkey
        end local 14 // java.lang.Integer encPartKeyVersion
        end local 13 // int encPartKeyType
        end local 12 // java.lang.String ticketPrinc
        end local 11 // java.lang.String serverPrincipal
        end local 10 // sun.security.krb5.PrincipalName ticketSname
        end local 9 // sun.security.krb5.EncryptedData encPart
        end local 8 // sun.security.krb5.internal.Ticket t
        50: .line 228
            goto 59
      StackMap locals: sun.security.ssl.krb5.KerberosClientKeyExchangeImpl sun.security.ssl.ProtocolVersion sun.security.ssl.ProtocolVersion java.security.SecureRandom sun.security.ssl.HandshakeInStream javax.crypto.SecretKey[] javax.security.auth.kerberos.KerberosKey[] sun.security.krb5.EncryptionKey
      StackMap stack: java.io.IOException
        51: astore 8 /* e */
        start local 8 // java.io.IOException e
        52: .line 229
            aload 8 /* e */
            athrow
        end local 8 // java.io.IOException e
        53: .line 230
      StackMap locals:
      StackMap stack: java.lang.Exception
            astore 8 /* e */
        start local 8 // java.lang.Exception e
        54: .line 231
            getstatic sun.security.ssl.krb5.KerberosClientKeyExchangeImpl.debug:Lsun/security/ssl/Debug;
            ifnull 58
            ldc "handshake"
            invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
            ifeq 58
        55: .line 232
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "KerberosWrapper error getting session key, generating random secret ("
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        56: .line 233
            aload 8 /* e */
            invokevirtual java.lang.Exception.getMessage:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc ")"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        57: .line 232
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        58: .line 235
      StackMap locals: java.lang.Exception
      StackMap stack:
            aconst_null
            astore 7 /* sessionKey */
        end local 8 // java.lang.Exception e
        59: .line 238
      StackMap locals:
      StackMap stack:
            aload 4 /* input */
            invokevirtual sun.security.ssl.HandshakeInStream.getBytes16:()[B
            pop
        60: .line 240
            aload 7 /* sessionKey */
            ifnull 65
        61: .line 241
            aload 0 /* this */
            new sun.security.ssl.krb5.KerberosPreMasterSecret
            dup
            aload 1 /* protocolVersion */
        62: .line 242
            aload 2 /* clientVersion */
            aload 3 /* rand */
            aload 4 /* input */
            aload 7 /* sessionKey */
            invokespecial sun.security.ssl.krb5.KerberosPreMasterSecret.<init>:(Lsun/security/ssl/ProtocolVersion;Lsun/security/ssl/ProtocolVersion;Ljava/security/SecureRandom;Lsun/security/ssl/HandshakeInStream;Lsun/security/krb5/EncryptionKey;)V
        63: .line 241
            putfield sun.security.ssl.krb5.KerberosClientKeyExchangeImpl.preMaster:Lsun/security/ssl/krb5/KerberosPreMasterSecret;
        64: .line 243
            goto 66
        65: .line 245
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            new sun.security.ssl.krb5.KerberosPreMasterSecret
            dup
            aload 2 /* clientVersion */
            aload 3 /* rand */
            invokespecial sun.security.ssl.krb5.KerberosPreMasterSecret.<init>:(Lsun/security/ssl/ProtocolVersion;Ljava/security/SecureRandom;)V
            putfield sun.security.ssl.krb5.KerberosClientKeyExchangeImpl.preMaster:Lsun/security/ssl/krb5/KerberosPreMasterSecret;
        66: .line 247
      StackMap locals:
      StackMap stack:
            return
        end local 7 // sun.security.krb5.EncryptionKey sessionKey
        end local 6 // javax.security.auth.kerberos.KerberosKey[] serverKeys
        end local 5 // javax.crypto.SecretKey[] secretKeys
        end local 4 // sun.security.ssl.HandshakeInStream input
        end local 3 // java.security.SecureRandom rand
        end local 2 // sun.security.ssl.ProtocolVersion clientVersion
        end local 1 // sun.security.ssl.ProtocolVersion protocolVersion
        end local 0 // sun.security.ssl.krb5.KerberosClientKeyExchangeImpl this
      LocalVariableTable:
        Start  End  Slot               Name  Signature
            0   67     0               this  Lsun/security/ssl/krb5/KerberosClientKeyExchangeImpl;
            0   67     1    protocolVersion  Lsun/security/ssl/ProtocolVersion;
            0   67     2      clientVersion  Lsun/security/ssl/ProtocolVersion;
            0   67     3               rand  Ljava/security/SecureRandom;
            0   67     4              input  Lsun/security/ssl/HandshakeInStream;
            0   67     5         secretKeys  [Ljavax/crypto/SecretKey;
            1   67     6         serverKeys  [Ljavax/security/auth/kerberos/KerberosKey;
            7   67     7         sessionKey  Lsun/security/krb5/EncryptionKey;
            8   50     8                  t  Lsun/security/krb5/internal/Ticket;
            9   50     9            encPart  Lsun/security/krb5/EncryptedData;
           10   50    10        ticketSname  Lsun/security/krb5/PrincipalName;
           12   50    11    serverPrincipal  Ljava/lang/String;
           13   50    12        ticketPrinc  Ljava/lang/String;
           21   50    13     encPartKeyType  I
           22   50    14  encPartKeyVersion  Ljava/lang/Integer;
           23   50    15               dkey  Ljavax/security/auth/kerberos/KerberosKey;
           26   29    16                 ke  Lsun/security/krb5/KrbException;
           39   50    16          secretKey  Lsun/security/krb5/EncryptionKey;
           40   50    17              bytes  [B
           41   50    18               temp  [B
           42   50    19      encTicketPart  Lsun/security/krb5/internal/EncTicketPart;
           52   53     8                  e  Ljava/io/IOException;
           54   59     8                  e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
          23    24      25  Class sun.security.krb5.KrbException
           7    50      51  Class java.io.IOException
           7    50      53  Class java.lang.Exception
    Exceptions:
      throws java.io.IOException
    MethodParameters:
                 Name  Flags
      protocolVersion  
      clientVersion    
      rand             
      input            
      secretKeys       

  public int messageLength();
    descriptor: ()I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // sun.security.ssl.krb5.KerberosClientKeyExchangeImpl this
         0: .line 251
            bipush 6
            aload 0 /* this */
            getfield sun.security.ssl.krb5.KerberosClientKeyExchangeImpl.encodedTicket:[B
            arraylength
            iadd
            aload 0 /* this */
            getfield sun.security.ssl.krb5.KerberosClientKeyExchangeImpl.preMaster:Lsun/security/ssl/krb5/KerberosPreMasterSecret;
            invokevirtual sun.security.ssl.krb5.KerberosPreMasterSecret.getEncrypted:()[B
            arraylength
            iadd
            ireturn
        end local 0 // sun.security.ssl.krb5.KerberosClientKeyExchangeImpl this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/ssl/krb5/KerberosClientKeyExchangeImpl;

  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 // sun.security.ssl.krb5.KerberosClientKeyExchangeImpl this
        start local 1 // sun.security.ssl.HandshakeOutStream s
         0: .line 256
            aload 1 /* s */
            aload 0 /* this */
            getfield sun.security.ssl.krb5.KerberosClientKeyExchangeImpl.encodedTicket:[B
            invokevirtual sun.security.ssl.HandshakeOutStream.putBytes16:([B)V
         1: .line 257
            aload 1 /* s */
            aconst_null
            invokevirtual sun.security.ssl.HandshakeOutStream.putBytes16:([B)V
         2: .line 258
            aload 1 /* s */
            aload 0 /* this */
            getfield sun.security.ssl.krb5.KerberosClientKeyExchangeImpl.preMaster:Lsun/security/ssl/krb5/KerberosPreMasterSecret;
            invokevirtual sun.security.ssl.krb5.KerberosPreMasterSecret.getEncrypted:()[B
            invokevirtual sun.security.ssl.HandshakeOutStream.putBytes16:([B)V
         3: .line 259
            return
        end local 1 // sun.security.ssl.HandshakeOutStream s
        end local 0 // sun.security.ssl.krb5.KerberosClientKeyExchangeImpl this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lsun/security/ssl/krb5/KerberosClientKeyExchangeImpl;
            0    4     1     s  Lsun/security/ssl/HandshakeOutStream;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
      Name  Flags
      s     

  public void print(java.io.PrintStream);
    descriptor: (Ljava/io/PrintStream;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // sun.security.ssl.krb5.KerberosClientKeyExchangeImpl this
        start local 1 // java.io.PrintStream s
         0: .line 263
            aload 1 /* s */
            ldc "*** ClientKeyExchange, Kerberos"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
         1: .line 265
            getstatic sun.security.ssl.krb5.KerberosClientKeyExchangeImpl.debug:Lsun/security/ssl/Debug;
            ifnull 7
            ldc "verbose"
            invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
            ifeq 7
         2: .line 266
            aload 1 /* s */
            ldc "Kerberos service ticket"
            aload 0 /* this */
            getfield sun.security.ssl.krb5.KerberosClientKeyExchangeImpl.encodedTicket:[B
            invokestatic sun.security.ssl.Debug.println:(Ljava/io/PrintStream;Ljava/lang/String;[B)V
         3: .line 267
            aload 1 /* s */
            ldc "Random Secret"
            aload 0 /* this */
            getfield sun.security.ssl.krb5.KerberosClientKeyExchangeImpl.preMaster:Lsun/security/ssl/krb5/KerberosPreMasterSecret;
            invokevirtual sun.security.ssl.krb5.KerberosPreMasterSecret.getUnencrypted:()[B
            invokestatic sun.security.ssl.Debug.println:(Ljava/io/PrintStream;Ljava/lang/String;[B)V
         4: .line 268
            aload 1 /* s */
            ldc "Encrypted random Secret"
         5: .line 269
            aload 0 /* this */
            getfield sun.security.ssl.krb5.KerberosClientKeyExchangeImpl.preMaster:Lsun/security/ssl/krb5/KerberosPreMasterSecret;
            invokevirtual sun.security.ssl.krb5.KerberosPreMasterSecret.getEncrypted:()[B
         6: .line 268
            invokestatic sun.security.ssl.Debug.println:(Ljava/io/PrintStream;Ljava/lang/String;[B)V
         7: .line 271
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.io.PrintStream s
        end local 0 // sun.security.ssl.krb5.KerberosClientKeyExchangeImpl this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    8     0  this  Lsun/security/ssl/krb5/KerberosClientKeyExchangeImpl;
            0    8     1     s  Ljava/io/PrintStream;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
      Name  Flags
      s     

  private static javax.security.auth.kerberos.KerberosTicket getServiceTicket(java.lang.String, boolean, java.security.AccessControlContext);
    descriptor: (Ljava/lang/String;ZLjava/security/AccessControlContext;)Ljavax/security/auth/kerberos/KerberosTicket;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=6, locals=13, args_size=3
        start local 0 // java.lang.String srvName
        start local 1 // boolean isLoopback
        start local 2 // java.security.AccessControlContext acc
         0: .line 278
            aload 0 /* srvName */
            astore 3 /* serverName */
        start local 3 // java.lang.String serverName
         1: .line 279
            iload 1 /* isLoopback */
            ifeq 5
         2: .line 281
            new sun.security.ssl.krb5.KerberosClientKeyExchangeImpl$1
            dup
            invokespecial sun.security.ssl.krb5.KerberosClientKeyExchangeImpl$1.<init>:()V
         3: .line 280
            invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedAction;)Ljava/lang/Object;
            checkcast java.lang.String
            astore 4 /* localHost */
        start local 4 // java.lang.String localHost
         4: .line 292
            aload 4 /* localHost */
            astore 3 /* serverName */
        end local 4 // java.lang.String localHost
         5: .line 297
      StackMap locals: java.lang.String
      StackMap stack:
            new java.lang.StringBuilder
            dup
            ldc "host/"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 3 /* serverName */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            astore 4 /* serviceName */
        start local 4 // java.lang.String serviceName
         6: .line 300
            new sun.security.krb5.PrincipalName
            dup
            aload 4 /* serviceName */
         7: .line 301
            iconst_3
         8: .line 300
            invokespecial sun.security.krb5.PrincipalName.<init>:(Ljava/lang/String;I)V
            astore 5 /* principal */
        start local 5 // sun.security.krb5.PrincipalName principal
         9: .line 302
            goto 18
        end local 5 // sun.security.krb5.PrincipalName principal
      StackMap locals: java.lang.String int java.security.AccessControlContext java.lang.String java.lang.String
      StackMap stack: java.lang.SecurityException
        10: astore 6 /* se */
        start local 6 // java.lang.SecurityException se
        11: .line 303
            aload 6 /* se */
            athrow
        end local 6 // java.lang.SecurityException se
        12: .line 304
      StackMap locals:
      StackMap stack: java.lang.Exception
            astore 6 /* e */
        start local 6 // java.lang.Exception e
        13: .line 305
            new java.io.IOException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Invalid service principal name: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        14: .line 306
            aload 4 /* serviceName */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        15: .line 305
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            astore 7 /* ioe */
        start local 7 // java.io.IOException ioe
        16: .line 307
            aload 7 /* ioe */
            aload 6 /* e */
            invokevirtual java.io.IOException.initCause:(Ljava/lang/Throwable;)Ljava/lang/Throwable;
            pop
        17: .line 308
            aload 7 /* ioe */
            athrow
        end local 7 // java.io.IOException ioe
        end local 6 // java.lang.Exception e
        start local 5 // sun.security.krb5.PrincipalName principal
        18: .line 310
      StackMap locals: sun.security.krb5.PrincipalName
      StackMap stack:
            aload 5 /* principal */
            invokevirtual sun.security.krb5.PrincipalName.getRealmAsString:()Ljava/lang/String;
            astore 6 /* realm */
        start local 6 // java.lang.String realm
        19: .line 312
            aload 5 /* principal */
            invokevirtual sun.security.krb5.PrincipalName.toString:()Ljava/lang/String;
            astore 7 /* serverPrincipal */
        start local 7 // java.lang.String serverPrincipal
        20: .line 313
            new java.lang.StringBuilder
            dup
            ldc "krbtgt/"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 6 /* realm */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "@"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 6 /* realm */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            astore 8 /* tgsPrincipal */
        start local 8 // java.lang.String tgsPrincipal
        21: .line 314
            aconst_null
            astore 9 /* clientPrincipal */
        start local 9 // java.lang.String clientPrincipal
        22: .line 319
            invokestatic java.lang.System.getSecurityManager:()Ljava/lang/SecurityManager;
            astore 10 /* sm */
        start local 10 // java.lang.SecurityManager sm
        23: .line 320
            aload 10 /* sm */
            ifnull 27
        24: .line 321
            aload 10 /* sm */
            new javax.security.auth.kerberos.ServicePermission
            dup
            aload 7 /* serverPrincipal */
        25: .line 322
            ldc "initiate"
            invokespecial javax.security.auth.kerberos.ServicePermission.<init>:(Ljava/lang/String;Ljava/lang/String;)V
            aload 2 /* acc */
        26: .line 321
            invokevirtual java.lang.SecurityManager.checkPermission:(Ljava/security/Permission;Ljava/lang/Object;)V
        27: .line 327
      StackMap locals: java.lang.String int java.security.AccessControlContext java.lang.String java.lang.String sun.security.krb5.PrincipalName java.lang.String java.lang.String java.lang.String java.lang.String java.lang.SecurityManager
      StackMap stack:
            new sun.security.ssl.krb5.KerberosClientKeyExchangeImpl$2
            dup
            aload 9 /* clientPrincipal */
            aload 7 /* serverPrincipal */
            aload 8 /* tgsPrincipal */
            aload 2 /* acc */
            invokespecial sun.security.ssl.krb5.KerberosClientKeyExchangeImpl$2.<init>:(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/security/AccessControlContext;)V
        28: .line 326
            invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedExceptionAction;)Ljava/lang/Object;
            checkcast javax.security.auth.kerberos.KerberosTicket
            astore 11 /* ticket */
        start local 11 // javax.security.auth.kerberos.KerberosTicket ticket
        29: .line 335
            aload 11 /* ticket */
            ifnonnull 33
        30: .line 336
            new java.io.IOException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Failed to find any kerberos service ticket for "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        31: .line 337
            aload 7 /* serverPrincipal */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        32: .line 336
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        33: .line 339
      StackMap locals: javax.security.auth.kerberos.KerberosTicket
      StackMap stack:
            aload 11 /* ticket */
        34: areturn
        end local 11 // javax.security.auth.kerberos.KerberosTicket ticket
        35: .line 340
      StackMap locals: java.lang.String int java.security.AccessControlContext java.lang.String java.lang.String sun.security.krb5.PrincipalName java.lang.String java.lang.String java.lang.String java.lang.String java.lang.SecurityManager
      StackMap stack: java.security.PrivilegedActionException
            astore 11 /* e */
        start local 11 // java.security.PrivilegedActionException e
        36: .line 341
            new java.io.IOException
            dup
        37: .line 342
            new java.lang.StringBuilder
            dup
            ldc "Attempt to obtain kerberos service ticket for "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        38: .line 343
            aload 7 /* serverPrincipal */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc " failed!"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        39: .line 342
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        40: .line 341
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            astore 12 /* ioe */
        start local 12 // java.io.IOException ioe
        41: .line 344
            aload 12 /* ioe */
            aload 11 /* e */
            invokevirtual java.io.IOException.initCause:(Ljava/lang/Throwable;)Ljava/lang/Throwable;
            pop
        42: .line 345
            aload 12 /* ioe */
            athrow
        end local 12 // java.io.IOException ioe
        end local 11 // java.security.PrivilegedActionException e
        end local 10 // java.lang.SecurityManager sm
        end local 9 // java.lang.String clientPrincipal
        end local 8 // java.lang.String tgsPrincipal
        end local 7 // java.lang.String serverPrincipal
        end local 6 // java.lang.String realm
        end local 5 // sun.security.krb5.PrincipalName principal
        end local 4 // java.lang.String serviceName
        end local 3 // java.lang.String serverName
        end local 2 // java.security.AccessControlContext acc
        end local 1 // boolean isLoopback
        end local 0 // java.lang.String srvName
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0   43     0          srvName  Ljava/lang/String;
            0   43     1       isLoopback  Z
            0   43     2              acc  Ljava/security/AccessControlContext;
            1   43     3       serverName  Ljava/lang/String;
            4    5     4        localHost  Ljava/lang/String;
            6   43     4      serviceName  Ljava/lang/String;
            9   10     5        principal  Lsun/security/krb5/PrincipalName;
           18   43     5        principal  Lsun/security/krb5/PrincipalName;
           11   12     6               se  Ljava/lang/SecurityException;
           13   18     6                e  Ljava/lang/Exception;
           16   18     7              ioe  Ljava/io/IOException;
           19   43     6            realm  Ljava/lang/String;
           20   43     7  serverPrincipal  Ljava/lang/String;
           21   43     8     tgsPrincipal  Ljava/lang/String;
           22   43     9  clientPrincipal  Ljava/lang/String;
           23   43    10               sm  Ljava/lang/SecurityManager;
           29   35    11           ticket  Ljavax/security/auth/kerberos/KerberosTicket;
           36   43    11                e  Ljava/security/PrivilegedActionException;
           41   43    12              ioe  Ljava/io/IOException;
      Exception table:
        from    to  target  type
           6     9      10  Class java.lang.SecurityException
           6     9      12  Class java.lang.Exception
          27    34      35  Class java.security.PrivilegedActionException
    Exceptions:
      throws java.io.IOException
    MethodParameters:
            Name  Flags
      srvName     
      isLoopback  
      acc         final

  public byte[] getUnencryptedPreMasterSecret();
    descriptor: ()[B
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.ssl.krb5.KerberosClientKeyExchangeImpl this
         0: .line 351
            aload 0 /* this */
            getfield sun.security.ssl.krb5.KerberosClientKeyExchangeImpl.preMaster:Lsun/security/ssl/krb5/KerberosPreMasterSecret;
            invokevirtual sun.security.ssl.krb5.KerberosPreMasterSecret.getUnencrypted:()[B
            areturn
        end local 0 // sun.security.ssl.krb5.KerberosClientKeyExchangeImpl this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/ssl/krb5/KerberosClientKeyExchangeImpl;

  public javax.security.auth.kerberos.KerberosPrincipal getPeerPrincipal();
    descriptor: ()Ljavax/security/auth/kerberos/KerberosPrincipal;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.ssl.krb5.KerberosClientKeyExchangeImpl this
         0: .line 356
            aload 0 /* this */
            getfield sun.security.ssl.krb5.KerberosClientKeyExchangeImpl.peerPrincipal:Ljavax/security/auth/kerberos/KerberosPrincipal;
            areturn
        end local 0 // sun.security.ssl.krb5.KerberosClientKeyExchangeImpl this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/ssl/krb5/KerberosClientKeyExchangeImpl;

  public javax.security.auth.kerberos.KerberosPrincipal getLocalPrincipal();
    descriptor: ()Ljavax/security/auth/kerberos/KerberosPrincipal;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.ssl.krb5.KerberosClientKeyExchangeImpl this
         0: .line 361
            aload 0 /* this */
            getfield sun.security.ssl.krb5.KerberosClientKeyExchangeImpl.localPrincipal:Ljavax/security/auth/kerberos/KerberosPrincipal;
            areturn
        end local 0 // sun.security.ssl.krb5.KerberosClientKeyExchangeImpl this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/ssl/krb5/KerberosClientKeyExchangeImpl;

  private static boolean versionMatches(java.lang.Integer, int);
    descriptor: (Ljava/lang/Integer;I)Z
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // java.lang.Integer v1
        start local 1 // int v2
         0: .line 375
            aload 0 /* v1 */
            ifnull 1
            aload 0 /* v1 */
            invokevirtual java.lang.Integer.intValue:()I
            ifeq 1
            iload 1 /* v2 */
            ifne 2
         1: .line 376
      StackMap locals:
      StackMap stack:
            iconst_1
            ireturn
         2: .line 378
      StackMap locals:
      StackMap stack:
            aload 0 /* v1 */
            iload 1 /* v2 */
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            invokevirtual java.lang.Integer.equals:(Ljava/lang/Object;)Z
            ireturn
        end local 1 // int v2
        end local 0 // java.lang.Integer v1
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0    v1  Ljava/lang/Integer;
            0    3     1    v2  I
    MethodParameters:
      Name  Flags
      v1    
      v2    

  private static javax.security.auth.kerberos.KerberosKey findKey(int, java.lang.Integer, javax.security.auth.kerberos.KerberosKey[]);
    descriptor: (ILjava/lang/Integer;[Ljavax/security/auth/kerberos/KerberosKey;)Ljavax/security/auth/kerberos/KerberosKey;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=7, locals=6, args_size=3
        start local 0 // int etype
        start local 1 // java.lang.Integer version
        start local 2 // javax.security.auth.kerberos.KerberosKey[] keys
         0: .line 384
            iconst_0
            istore 4 /* etypeFound */
        start local 4 // boolean etypeFound
         1: .line 385
            iconst_0
            istore 5 /* i */
        start local 5 // int i
         2: goto 9
         3: .line 386
      StackMap locals: int java.lang.Integer javax.security.auth.kerberos.KerberosKey[] top int int
      StackMap stack:
            aload 2 /* keys */
            iload 5 /* i */
            aaload
            invokevirtual javax.security.auth.kerberos.KerberosKey.getKeyType:()I
            istore 3 /* ktype */
        start local 3 // int ktype
         4: .line 387
            iload 0 /* etype */
            iload 3 /* ktype */
            if_icmpne 8
         5: .line 388
            iconst_1
            istore 4 /* etypeFound */
         6: .line 389
            aload 1 /* version */
            aload 2 /* keys */
            iload 5 /* i */
            aaload
            invokevirtual javax.security.auth.kerberos.KerberosKey.getVersionNumber:()I
            invokestatic sun.security.ssl.krb5.KerberosClientKeyExchangeImpl.versionMatches:(Ljava/lang/Integer;I)Z
            ifeq 8
         7: .line 390
            aload 2 /* keys */
            iload 5 /* i */
            aaload
            areturn
         8: .line 385
      StackMap locals: int java.lang.Integer javax.security.auth.kerberos.KerberosKey[] int int int
      StackMap stack:
            iinc 5 /* i */ 1
        end local 3 // int ktype
      StackMap locals: int java.lang.Integer javax.security.auth.kerberos.KerberosKey[] top int int
      StackMap stack:
         9: iload 5 /* i */
            aload 2 /* keys */
            arraylength
            if_icmplt 3
        end local 5 // int i
        10: .line 396
            iload 0 /* etype */
            iconst_1
            if_icmpeq 12
        11: .line 397
            iload 0 /* etype */
            iconst_3
            if_icmpne 26
        12: .line 398
      StackMap locals:
      StackMap stack:
            iconst_0
            istore 5 /* i */
        start local 5 // int i
        13: goto 25
        14: .line 399
      StackMap locals: int
      StackMap stack:
            aload 2 /* keys */
            iload 5 /* i */
            aaload
            invokevirtual javax.security.auth.kerberos.KerberosKey.getKeyType:()I
            istore 3 /* ktype */
        start local 3 // int ktype
        15: .line 400
            iload 3 /* ktype */
            iconst_1
            if_icmpeq 17
        16: .line 401
            iload 3 /* ktype */
            iconst_3
            if_icmpne 24
        17: .line 402
      StackMap locals: int java.lang.Integer javax.security.auth.kerberos.KerberosKey[] int int int
      StackMap stack:
            iconst_1
            istore 4 /* etypeFound */
        18: .line 403
            aload 1 /* version */
            aload 2 /* keys */
            iload 5 /* i */
            aaload
            invokevirtual javax.security.auth.kerberos.KerberosKey.getVersionNumber:()I
            invokestatic sun.security.ssl.krb5.KerberosClientKeyExchangeImpl.versionMatches:(Ljava/lang/Integer;I)Z
            ifeq 24
        19: .line 404
            new javax.security.auth.kerberos.KerberosKey
            dup
            aload 2 /* keys */
            iload 5 /* i */
            aaload
            invokevirtual javax.security.auth.kerberos.KerberosKey.getPrincipal:()Ljavax/security/auth/kerberos/KerberosPrincipal;
        20: .line 405
            aload 2 /* keys */
            iload 5 /* i */
            aaload
            invokevirtual javax.security.auth.kerberos.KerberosKey.getEncoded:()[B
        21: .line 406
            iload 0 /* etype */
        22: .line 407
            aload 2 /* keys */
            iload 5 /* i */
            aaload
            invokevirtual javax.security.auth.kerberos.KerberosKey.getVersionNumber:()I
        23: .line 404
            invokespecial javax.security.auth.kerberos.KerberosKey.<init>:(Ljavax/security/auth/kerberos/KerberosPrincipal;[BII)V
            areturn
        24: .line 398
      StackMap locals:
      StackMap stack:
            iinc 5 /* i */ 1
        end local 3 // int ktype
      StackMap locals: int java.lang.Integer javax.security.auth.kerberos.KerberosKey[] top int int
      StackMap stack:
        25: iload 5 /* i */
            aload 2 /* keys */
            arraylength
            if_icmplt 14
        end local 5 // int i
        26: .line 412
      StackMap locals:
      StackMap stack:
            iload 4 /* etypeFound */
            ifeq 28
        27: .line 413
            new sun.security.krb5.KrbException
            dup
            bipush 44
            invokespecial sun.security.krb5.KrbException.<init>:(I)V
            athrow
        28: .line 415
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        end local 4 // boolean etypeFound
        end local 2 // javax.security.auth.kerberos.KerberosKey[] keys
        end local 1 // java.lang.Integer version
        end local 0 // int etype
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   29     0       etype  I
            0   29     1     version  Ljava/lang/Integer;
            0   29     2        keys  [Ljavax/security/auth/kerberos/KerberosKey;
            4    9     3       ktype  I
           15   25     3       ktype  I
            1   29     4  etypeFound  Z
            2   10     5           i  I
           13   26     5           i  I
    Exceptions:
      throws sun.security.krb5.KrbException
    MethodParameters:
         Name  Flags
      etype    
      version  
      keys     

  public java.security.Principal getPeerPrincipal();
    descriptor: ()Ljava/security/Principal;
    flags: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
    Code:
      stack=1, locals=1, args_size=1
         0: .line 1
            aload 0
            invokevirtual sun.security.ssl.krb5.KerberosClientKeyExchangeImpl.getPeerPrincipal:()Ljavax/security/auth/kerberos/KerberosPrincipal;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public java.security.Principal getLocalPrincipal();
    descriptor: ()Ljava/security/Principal;
    flags: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
    Code:
      stack=1, locals=1, args_size=1
         0: .line 1
            aload 0
            invokevirtual sun.security.ssl.krb5.KerberosClientKeyExchangeImpl.getLocalPrincipal:()Ljavax/security/auth/kerberos/KerberosPrincipal;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature
}
SourceFile: "KerberosClientKeyExchangeImpl.java"
NestMembers:
  sun.security.ssl.krb5.KerberosClientKeyExchangeImpl$1  sun.security.ssl.krb5.KerberosClientKeyExchangeImpl$2
InnerClasses:
  sun.security.ssl.krb5.KerberosClientKeyExchangeImpl$1
  sun.security.ssl.krb5.KerberosClientKeyExchangeImpl$2