final class com.sun.crypto.provider.KeyProtector
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: com.sun.crypto.provider.KeyProtector
  super_class: java.lang.Object
{
  private static final java.lang.String PBE_WITH_MD5_AND_DES3_CBC_OID;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "1.3.6.1.4.1.42.2.19.1"

  private static final java.lang.String KEY_PROTECTOR_OID;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "1.3.6.1.4.1.42.2.17.1.1"

  private static final int MAX_ITERATION_COUNT;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 5000000

  private static final int ITERATION_COUNT;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 200000

  private static final int SALT_LEN;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 20

  private static final int DIGEST_LEN;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 20

  private char[] password;
    descriptor: [C
    flags: (0x0002) ACC_PRIVATE

  void <init>(char[]);
    descriptor: ([C)V
    flags: (0x0000) 
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // com.sun.crypto.provider.KeyProtector this
        start local 1 // char[] password
         0: .line 86
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 87
            aload 1 /* password */
            ifnonnull 3
         2: .line 88
            new java.lang.IllegalArgumentException
            dup
            ldc "password can't be null"
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
         3: .line 90
      StackMap locals: com.sun.crypto.provider.KeyProtector char[]
      StackMap stack:
            aload 0 /* this */
            aload 1 /* password */
            putfield com.sun.crypto.provider.KeyProtector.password:[C
         4: .line 91
            return
        end local 1 // char[] password
        end local 0 // com.sun.crypto.provider.KeyProtector this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    5     0      this  Lcom/sun/crypto/provider/KeyProtector;
            0    5     1  password  [C
    MethodParameters:
          Name  Flags
      password  

  byte[] protect(java.security.PrivateKey);
    descriptor: (Ljava/security/PrivateKey;)[B
    flags: (0x0000) 
    Code:
      stack=5, locals=11, args_size=2
        start local 0 // com.sun.crypto.provider.KeyProtector this
        start local 1 // java.security.PrivateKey key
         0: .line 101
            bipush 8
            newarray 8
            astore 2 /* salt */
        start local 2 // byte[] salt
         1: .line 102
            invokestatic com.sun.crypto.provider.SunJCE.getRandom:()Ljava/security/SecureRandom;
            aload 2 /* salt */
            invokevirtual java.security.SecureRandom.nextBytes:([B)V
         2: .line 105
            new javax.crypto.spec.PBEParameterSpec
            dup
            aload 2 /* salt */
            ldc 200000
            invokespecial javax.crypto.spec.PBEParameterSpec.<init>:([BI)V
            astore 3 /* pbeSpec */
        start local 3 // javax.crypto.spec.PBEParameterSpec pbeSpec
         3: .line 108
            new javax.crypto.spec.PBEKeySpec
            dup
            aload 0 /* this */
            getfield com.sun.crypto.provider.KeyProtector.password:[C
            invokespecial javax.crypto.spec.PBEKeySpec.<init>:([C)V
            astore 4 /* pbeKeySpec */
        start local 4 // javax.crypto.spec.PBEKeySpec pbeKeySpec
         4: .line 109
            aconst_null
            astore 5 /* sKey */
        start local 5 // javax.crypto.SecretKey sKey
         5: .line 112
            new com.sun.crypto.provider.PBEKey
            dup
            aload 4 /* pbeKeySpec */
            ldc "PBEWithMD5AndTripleDES"
            iconst_0
            invokespecial com.sun.crypto.provider.PBEKey.<init>:(Ljavax/crypto/spec/PBEKeySpec;Ljava/lang/String;Z)V
            astore 5 /* sKey */
         6: .line 114
            new com.sun.crypto.provider.PBEWithMD5AndTripleDESCipher
            dup
            invokespecial com.sun.crypto.provider.PBEWithMD5AndTripleDESCipher.<init>:()V
            astore 6 /* cipher */
        start local 6 // com.sun.crypto.provider.PBEWithMD5AndTripleDESCipher cipher
         7: .line 115
            aload 6 /* cipher */
            iconst_1
            aload 5 /* sKey */
            aload 3 /* pbeSpec */
            aconst_null
            invokevirtual com.sun.crypto.provider.PBEWithMD5AndTripleDESCipher.engineInit:(ILjava/security/Key;Ljava/security/spec/AlgorithmParameterSpec;Ljava/security/SecureRandom;)V
         8: .line 116
            goto 13
        end local 6 // com.sun.crypto.provider.PBEWithMD5AndTripleDESCipher cipher
      StackMap locals: com.sun.crypto.provider.KeyProtector java.security.PrivateKey byte[] javax.crypto.spec.PBEParameterSpec javax.crypto.spec.PBEKeySpec javax.crypto.SecretKey
      StackMap stack: java.lang.Throwable
         9: astore 7
        10: .line 117
            aload 4 /* pbeKeySpec */
            invokevirtual javax.crypto.spec.PBEKeySpec.clearPassword:()V
        11: .line 118
            aload 5 /* sKey */
            ifnull 12
            aload 5 /* sKey */
            invokeinterface javax.crypto.SecretKey.destroy:()V
        12: .line 119
      StackMap locals: com.sun.crypto.provider.KeyProtector java.security.PrivateKey byte[] javax.crypto.spec.PBEParameterSpec javax.crypto.spec.PBEKeySpec javax.crypto.SecretKey top java.lang.Throwable
      StackMap stack:
            aload 7
            athrow
        start local 6 // com.sun.crypto.provider.PBEWithMD5AndTripleDESCipher cipher
        13: .line 117
      StackMap locals: com.sun.crypto.provider.KeyProtector java.security.PrivateKey byte[] javax.crypto.spec.PBEParameterSpec javax.crypto.spec.PBEKeySpec javax.crypto.SecretKey com.sun.crypto.provider.PBEWithMD5AndTripleDESCipher
      StackMap stack:
            aload 4 /* pbeKeySpec */
            invokevirtual javax.crypto.spec.PBEKeySpec.clearPassword:()V
        14: .line 118
            aload 5 /* sKey */
            ifnull 15
            aload 5 /* sKey */
            invokeinterface javax.crypto.SecretKey.destroy:()V
        15: .line 120
      StackMap locals:
      StackMap stack:
            aload 1 /* key */
            invokeinterface java.security.PrivateKey.getEncoded:()[B
            astore 7 /* plain */
        start local 7 // byte[] plain
        16: .line 121
            aload 6 /* cipher */
            aload 7 /* plain */
            iconst_0
            aload 7 /* plain */
            arraylength
            invokevirtual com.sun.crypto.provider.PBEWithMD5AndTripleDESCipher.engineDoFinal:([BII)[B
            astore 8 /* encrKey */
        start local 8 // byte[] encrKey
        17: .line 122
            aload 7 /* plain */
            iconst_0
            invokestatic java.util.Arrays.fill:([BB)V
        18: .line 127
            ldc "PBE"
            invokestatic com.sun.crypto.provider.SunJCE.getInstance:()Lcom/sun/crypto/provider/SunJCE;
            invokestatic java.security.AlgorithmParameters.getInstance:(Ljava/lang/String;Ljava/security/Provider;)Ljava/security/AlgorithmParameters;
        19: .line 126
            astore 9 /* pbeParams */
        start local 9 // java.security.AlgorithmParameters pbeParams
        20: .line 128
            aload 9 /* pbeParams */
            aload 3 /* pbeSpec */
            invokevirtual java.security.AlgorithmParameters.init:(Ljava/security/spec/AlgorithmParameterSpec;)V
        21: .line 130
            new sun.security.x509.AlgorithmId
            dup
        22: .line 131
            new sun.security.util.ObjectIdentifier
            dup
            ldc "1.3.6.1.4.1.42.2.19.1"
            invokespecial sun.security.util.ObjectIdentifier.<init>:(Ljava/lang/String;)V
            aload 9 /* pbeParams */
        23: .line 130
            invokespecial sun.security.x509.AlgorithmId.<init>:(Lsun/security/util/ObjectIdentifier;Ljava/security/AlgorithmParameters;)V
            astore 10 /* encrAlg */
        start local 10 // sun.security.x509.AlgorithmId encrAlg
        24: .line 132
            new com.sun.crypto.provider.EncryptedPrivateKeyInfo
            dup
            aload 10 /* encrAlg */
            aload 8 /* encrKey */
            invokespecial com.sun.crypto.provider.EncryptedPrivateKeyInfo.<init>:(Lsun/security/x509/AlgorithmId;[B)V
            invokevirtual com.sun.crypto.provider.EncryptedPrivateKeyInfo.getEncoded:()[B
            areturn
        end local 10 // sun.security.x509.AlgorithmId encrAlg
        end local 9 // java.security.AlgorithmParameters pbeParams
        end local 8 // byte[] encrKey
        end local 7 // byte[] plain
        end local 6 // com.sun.crypto.provider.PBEWithMD5AndTripleDESCipher cipher
        end local 5 // javax.crypto.SecretKey sKey
        end local 4 // javax.crypto.spec.PBEKeySpec pbeKeySpec
        end local 3 // javax.crypto.spec.PBEParameterSpec pbeSpec
        end local 2 // byte[] salt
        end local 1 // java.security.PrivateKey key
        end local 0 // com.sun.crypto.provider.KeyProtector this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   25     0        this  Lcom/sun/crypto/provider/KeyProtector;
            0   25     1         key  Ljava/security/PrivateKey;
            1   25     2        salt  [B
            3   25     3     pbeSpec  Ljavax/crypto/spec/PBEParameterSpec;
            4   25     4  pbeKeySpec  Ljavax/crypto/spec/PBEKeySpec;
            5   25     5        sKey  Ljavax/crypto/SecretKey;
            7    9     6      cipher  Lcom/sun/crypto/provider/PBEWithMD5AndTripleDESCipher;
           13   25     6      cipher  Lcom/sun/crypto/provider/PBEWithMD5AndTripleDESCipher;
           16   25     7       plain  [B
           17   25     8     encrKey  [B
           20   25     9   pbeParams  Ljava/security/AlgorithmParameters;
           24   25    10     encrAlg  Lsun/security/x509/AlgorithmId;
      Exception table:
        from    to  target  type
           5     9       9  any
    Exceptions:
      throws java.lang.Exception
    MethodParameters:
      Name  Flags
      key   

  java.security.Key recover(com.sun.crypto.provider.EncryptedPrivateKeyInfo);
    descriptor: (Lcom/sun/crypto/provider/EncryptedPrivateKeyInfo;)Ljava/security/Key;
    flags: (0x0000) 
    Code:
      stack=5, locals=12, args_size=2
        start local 0 // com.sun.crypto.provider.KeyProtector this
        start local 1 // com.sun.crypto.provider.EncryptedPrivateKeyInfo encrInfo
         0: .line 142
            aconst_null
            astore 2 /* plain */
        start local 2 // byte[] plain
         1: .line 143
            aconst_null
            astore 3 /* sKey */
        start local 3 // javax.crypto.SecretKey sKey
         2: .line 145
            aload 1 /* encrInfo */
            invokevirtual com.sun.crypto.provider.EncryptedPrivateKeyInfo.getAlgorithm:()Lsun/security/x509/AlgorithmId;
            invokevirtual sun.security.x509.AlgorithmId.getOID:()Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.toString:()Ljava/lang/String;
            astore 4 /* encrAlg */
        start local 4 // java.lang.String encrAlg
         3: .line 146
            aload 4 /* encrAlg */
            ldc "1.3.6.1.4.1.42.2.19.1"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 6
         4: .line 147
            aload 4 /* encrAlg */
            ldc "1.3.6.1.4.1.42.2.17.1.1"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 6
         5: .line 148
            new java.security.UnrecoverableKeyException
            dup
            ldc "Unsupported encryption algorithm"
            invokespecial java.security.UnrecoverableKeyException.<init>:(Ljava/lang/String;)V
            athrow
         6: .line 152
      StackMap locals: byte[] javax.crypto.SecretKey java.lang.String
      StackMap stack:
            aload 4 /* encrAlg */
            ldc "1.3.6.1.4.1.42.2.17.1.1"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 9
         7: .line 154
            aload 0 /* this */
            aload 1 /* encrInfo */
            invokevirtual com.sun.crypto.provider.EncryptedPrivateKeyInfo.getEncryptedData:()[B
            invokevirtual com.sun.crypto.provider.KeyProtector.recover:([B)[B
            astore 2 /* plain */
         8: .line 155
            goto 26
         9: .line 157
      StackMap locals:
      StackMap stack:
            aload 1 /* encrInfo */
            invokevirtual com.sun.crypto.provider.EncryptedPrivateKeyInfo.getAlgorithm:()Lsun/security/x509/AlgorithmId;
            invokevirtual sun.security.x509.AlgorithmId.getEncodedParams:()[B
        10: .line 156
            astore 5 /* encodedParams */
        start local 5 // byte[] encodedParams
        11: .line 161
            ldc "PBE"
            invokestatic java.security.AlgorithmParameters.getInstance:(Ljava/lang/String;)Ljava/security/AlgorithmParameters;
        12: .line 160
            astore 6 /* pbeParams */
        start local 6 // java.security.AlgorithmParameters pbeParams
        13: .line 162
            aload 6 /* pbeParams */
            aload 5 /* encodedParams */
            invokevirtual java.security.AlgorithmParameters.init:([B)V
        14: .line 164
            aload 6 /* pbeParams */
            ldc Ljavax/crypto/spec/PBEParameterSpec;
            invokevirtual java.security.AlgorithmParameters.getParameterSpec:(Ljava/lang/Class;)Ljava/security/spec/AlgorithmParameterSpec;
            checkcast javax.crypto.spec.PBEParameterSpec
        15: .line 163
            astore 7 /* pbeSpec */
        start local 7 // javax.crypto.spec.PBEParameterSpec pbeSpec
        16: .line 165
            aload 7 /* pbeSpec */
            invokevirtual javax.crypto.spec.PBEParameterSpec.getIterationCount:()I
            ldc 5000000
            if_icmple 18
        17: .line 166
            new java.io.IOException
            dup
            ldc "PBE iteration count too large"
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        18: .line 170
      StackMap locals: byte[] java.security.AlgorithmParameters javax.crypto.spec.PBEParameterSpec
      StackMap stack:
            new javax.crypto.spec.PBEKeySpec
            dup
            aload 0 /* this */
            getfield com.sun.crypto.provider.KeyProtector.password:[C
            invokespecial javax.crypto.spec.PBEKeySpec.<init>:([C)V
            astore 8 /* pbeKeySpec */
        start local 8 // javax.crypto.spec.PBEKeySpec pbeKeySpec
        19: .line 171
            new com.sun.crypto.provider.PBEKey
            dup
            aload 8 /* pbeKeySpec */
            ldc "PBEWithMD5AndTripleDES"
            iconst_0
            invokespecial com.sun.crypto.provider.PBEKey.<init>:(Ljavax/crypto/spec/PBEKeySpec;Ljava/lang/String;Z)V
            astore 3 /* sKey */
        20: .line 172
            aload 8 /* pbeKeySpec */
            invokevirtual javax.crypto.spec.PBEKeySpec.clearPassword:()V
        21: .line 176
            new com.sun.crypto.provider.PBEWithMD5AndTripleDESCipher
            dup
            invokespecial com.sun.crypto.provider.PBEWithMD5AndTripleDESCipher.<init>:()V
            astore 9 /* cipher */
        start local 9 // com.sun.crypto.provider.PBEWithMD5AndTripleDESCipher cipher
        22: .line 177
            aload 9 /* cipher */
            iconst_2
            aload 3 /* sKey */
            aload 7 /* pbeSpec */
            aconst_null
            invokevirtual com.sun.crypto.provider.PBEWithMD5AndTripleDESCipher.engineInit:(ILjava/security/Key;Ljava/security/spec/AlgorithmParameterSpec;Ljava/security/SecureRandom;)V
        23: .line 178
            aload 9 /* cipher */
            aload 1 /* encrInfo */
            invokevirtual com.sun.crypto.provider.EncryptedPrivateKeyInfo.getEncryptedData:()[B
            iconst_0
        24: .line 179
            aload 1 /* encrInfo */
            invokevirtual com.sun.crypto.provider.EncryptedPrivateKeyInfo.getEncryptedData:()[B
            arraylength
        25: .line 178
            invokevirtual com.sun.crypto.provider.PBEWithMD5AndTripleDESCipher.engineDoFinal:([BII)[B
            astore 2 /* plain */
        end local 9 // com.sun.crypto.provider.PBEWithMD5AndTripleDESCipher cipher
        end local 8 // javax.crypto.spec.PBEKeySpec pbeKeySpec
        end local 7 // javax.crypto.spec.PBEParameterSpec pbeSpec
        end local 6 // java.security.AlgorithmParameters pbeParams
        end local 5 // byte[] encodedParams
        26: .line 184
      StackMap locals:
      StackMap stack:
            new sun.security.x509.AlgorithmId
            dup
        27: .line 185
            new com.sun.crypto.provider.PrivateKeyInfo
            dup
            aload 2 /* plain */
            invokespecial com.sun.crypto.provider.PrivateKeyInfo.<init>:([B)V
            invokevirtual com.sun.crypto.provider.PrivateKeyInfo.getAlgorithm:()Lsun/security/x509/AlgorithmId;
            invokevirtual sun.security.x509.AlgorithmId.getOID:()Lsun/security/util/ObjectIdentifier;
        28: .line 184
            invokespecial sun.security.x509.AlgorithmId.<init>:(Lsun/security/util/ObjectIdentifier;)V
        29: .line 185
            invokevirtual sun.security.x509.AlgorithmId.getName:()Ljava/lang/String;
        30: .line 184
            astore 5 /* oidName */
        start local 5 // java.lang.String oidName
        31: .line 186
            aload 5 /* oidName */
            invokestatic java.security.KeyFactory.getInstance:(Ljava/lang/String;)Ljava/security/KeyFactory;
            astore 6 /* kFac */
        start local 6 // java.security.KeyFactory kFac
        32: .line 187
            aload 6 /* kFac */
            new java.security.spec.PKCS8EncodedKeySpec
            dup
            aload 2 /* plain */
            invokespecial java.security.spec.PKCS8EncodedKeySpec.<init>:([B)V
            invokevirtual java.security.KeyFactory.generatePrivate:(Ljava/security/spec/KeySpec;)Ljava/security/PrivateKey;
            astore 11
        33: .line 197
            aload 2 /* plain */
            ifnull 34
            aload 2 /* plain */
            iconst_0
            invokestatic java.util.Arrays.fill:([BB)V
        34: .line 198
      StackMap locals: com.sun.crypto.provider.KeyProtector com.sun.crypto.provider.EncryptedPrivateKeyInfo byte[] javax.crypto.SecretKey java.lang.String java.lang.String java.security.KeyFactory top top top top java.security.Key
      StackMap stack:
            aload 3 /* sKey */
            ifnull 38
        35: .line 200
            aload 3 /* sKey */
            invokeinterface javax.crypto.SecretKey.destroy:()V
        36: .line 201
            goto 38
      StackMap locals:
      StackMap stack: javax.security.auth.DestroyFailedException
        37: pop
        38: .line 187
      StackMap locals:
      StackMap stack:
            aload 11
            areturn
        end local 6 // java.security.KeyFactory kFac
        end local 5 // java.lang.String oidName
        end local 4 // java.lang.String encrAlg
        39: .line 188
      StackMap locals: com.sun.crypto.provider.KeyProtector com.sun.crypto.provider.EncryptedPrivateKeyInfo byte[] javax.crypto.SecretKey
      StackMap stack: java.security.NoSuchAlgorithmException
            astore 4 /* ex */
        start local 4 // java.security.NoSuchAlgorithmException ex
        40: .line 191
            aload 4 /* ex */
            athrow
        end local 4 // java.security.NoSuchAlgorithmException ex
        41: .line 192
      StackMap locals:
      StackMap stack: java.io.IOException
            astore 4 /* ioe */
        start local 4 // java.io.IOException ioe
        42: .line 193
            new java.security.UnrecoverableKeyException
            dup
            aload 4 /* ioe */
            invokevirtual java.io.IOException.getMessage:()Ljava/lang/String;
            invokespecial java.security.UnrecoverableKeyException.<init>:(Ljava/lang/String;)V
            athrow
        end local 4 // java.io.IOException ioe
        43: .line 194
      StackMap locals:
      StackMap stack: java.security.GeneralSecurityException
            astore 4 /* gse */
        start local 4 // java.security.GeneralSecurityException gse
        44: .line 195
            new java.security.UnrecoverableKeyException
            dup
            aload 4 /* gse */
            invokevirtual java.security.GeneralSecurityException.getMessage:()Ljava/lang/String;
            invokespecial java.security.UnrecoverableKeyException.<init>:(Ljava/lang/String;)V
            athrow
        end local 4 // java.security.GeneralSecurityException gse
        45: .line 196
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 10
        46: .line 197
            aload 2 /* plain */
            ifnull 47
            aload 2 /* plain */
            iconst_0
            invokestatic java.util.Arrays.fill:([BB)V
        47: .line 198
      StackMap locals: com.sun.crypto.provider.KeyProtector com.sun.crypto.provider.EncryptedPrivateKeyInfo byte[] javax.crypto.SecretKey top top top top top top java.lang.Throwable
      StackMap stack:
            aload 3 /* sKey */
            ifnull 51
        48: .line 200
            aload 3 /* sKey */
            invokeinterface javax.crypto.SecretKey.destroy:()V
        49: .line 201
            goto 51
      StackMap locals:
      StackMap stack: javax.security.auth.DestroyFailedException
        50: pop
        51: .line 205
      StackMap locals:
      StackMap stack:
            aload 10
            athrow
        end local 3 // javax.crypto.SecretKey sKey
        end local 2 // byte[] plain
        end local 1 // com.sun.crypto.provider.EncryptedPrivateKeyInfo encrInfo
        end local 0 // com.sun.crypto.provider.KeyProtector this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   52     0           this  Lcom/sun/crypto/provider/KeyProtector;
            0   52     1       encrInfo  Lcom/sun/crypto/provider/EncryptedPrivateKeyInfo;
            1   52     2          plain  [B
            2   52     3           sKey  Ljavax/crypto/SecretKey;
            3   39     4        encrAlg  Ljava/lang/String;
           11   26     5  encodedParams  [B
           13   26     6      pbeParams  Ljava/security/AlgorithmParameters;
           16   26     7        pbeSpec  Ljavax/crypto/spec/PBEParameterSpec;
           19   26     8     pbeKeySpec  Ljavax/crypto/spec/PBEKeySpec;
           22   26     9         cipher  Lcom/sun/crypto/provider/PBEWithMD5AndTripleDESCipher;
           31   39     5        oidName  Ljava/lang/String;
           32   39     6           kFac  Ljava/security/KeyFactory;
           40   41     4             ex  Ljava/security/NoSuchAlgorithmException;
           42   43     4            ioe  Ljava/io/IOException;
           44   45     4            gse  Ljava/security/GeneralSecurityException;
      Exception table:
        from    to  target  type
          35    36      37  Class javax.security.auth.DestroyFailedException
           2    33      39  Class java.security.NoSuchAlgorithmException
           2    33      41  Class java.io.IOException
           2    33      43  Class java.security.GeneralSecurityException
           2    33      45  any
          39    45      45  any
          48    49      50  Class javax.security.auth.DestroyFailedException
    Exceptions:
      throws java.security.UnrecoverableKeyException, java.security.NoSuchAlgorithmException
    MethodParameters:
          Name  Flags
      encrInfo  

  private byte[] recover(byte[]);
    descriptor: ([B)[B
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=6, locals=14, args_size=2
        start local 0 // com.sun.crypto.provider.KeyProtector this
        start local 1 // byte[] protectedKey
         0: .line 223
            ldc "SHA"
            invokestatic java.security.MessageDigest.getInstance:(Ljava/lang/String;)Ljava/security/MessageDigest;
            astore 8 /* md */
        start local 8 // java.security.MessageDigest md
         1: .line 227
            bipush 20
            newarray 8
            astore 9 /* salt */
        start local 9 // byte[] salt
         2: .line 228
            aload 1 /* protectedKey */
            iconst_0
            aload 9 /* salt */
            iconst_0
            bipush 20
            invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
         3: .line 231
            aload 1 /* protectedKey */
            arraylength
            bipush 20
            isub
            bipush 20
            isub
            istore 7 /* encrKeyLen */
        start local 7 // int encrKeyLen
         4: .line 232
            iload 7 /* encrKeyLen */
            bipush 20
            idiv
            istore 5 /* numRounds */
        start local 5 // int numRounds
         5: .line 233
            iload 7 /* encrKeyLen */
            bipush 20
            irem
            ifeq 7
         6: .line 234
            iinc 5 /* numRounds */ 1
         7: .line 237
      StackMap locals: com.sun.crypto.provider.KeyProtector byte[] top top top int top int java.security.MessageDigest byte[]
      StackMap stack:
            iload 7 /* encrKeyLen */
            newarray 8
            astore 10 /* encrKey */
        start local 10 // byte[] encrKey
         8: .line 238
            aload 1 /* protectedKey */
            bipush 20
            aload 10 /* encrKey */
            iconst_0
            iload 7 /* encrKeyLen */
            invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
         9: .line 241
            aload 10 /* encrKey */
            arraylength
            newarray 8
            astore 11 /* xorKey */
        start local 11 // byte[] xorKey
        10: .line 244
            aload 0 /* this */
            getfield com.sun.crypto.provider.KeyProtector.password:[C
            arraylength
            iconst_2
            imul
            newarray 8
            astore 12 /* passwdBytes */
        start local 12 // byte[] passwdBytes
        11: .line 245
            iconst_0
            istore 2 /* i */
        start local 2 // int i
        12: iconst_0
            istore 3 /* j */
        start local 3 // int j
        13: goto 17
        14: .line 246
      StackMap locals: com.sun.crypto.provider.KeyProtector byte[] int int top int top int java.security.MessageDigest byte[] byte[] byte[] byte[]
      StackMap stack:
            aload 12 /* passwdBytes */
            iload 3 /* j */
            iinc 3 /* j */ 1
            aload 0 /* this */
            getfield com.sun.crypto.provider.KeyProtector.password:[C
            iload 2 /* i */
            caload
            bipush 8
            ishr
            i2b
            bastore
        15: .line 247
            aload 12 /* passwdBytes */
            iload 3 /* j */
            iinc 3 /* j */ 1
            aload 0 /* this */
            getfield com.sun.crypto.provider.KeyProtector.password:[C
            iload 2 /* i */
            caload
            i2b
            bastore
        16: .line 245
            iinc 2 /* i */ 1
      StackMap locals:
      StackMap stack:
        17: iload 2 /* i */
            aload 0 /* this */
            getfield com.sun.crypto.provider.KeyProtector.password:[C
            arraylength
            if_icmplt 14
        18: .line 251
            iconst_0
            istore 2 /* i */
            iconst_0
            istore 6 /* xorOffset */
        start local 6 // int xorOffset
        19: aload 9 /* salt */
            astore 4 /* digest */
        start local 4 // byte[] digest
        20: .line 252
            goto 34
        21: .line 254
      StackMap locals: com.sun.crypto.provider.KeyProtector byte[] int int byte[] int int int java.security.MessageDigest byte[] byte[] byte[] byte[]
      StackMap stack:
            aload 8 /* md */
            aload 12 /* passwdBytes */
            invokevirtual java.security.MessageDigest.update:([B)V
        22: .line 255
            aload 8 /* md */
            aload 4 /* digest */
            invokevirtual java.security.MessageDigest.update:([B)V
        23: .line 256
            aload 8 /* md */
            invokevirtual java.security.MessageDigest.digest:()[B
            astore 4 /* digest */
        24: .line 257
            aload 8 /* md */
            invokevirtual java.security.MessageDigest.reset:()V
        25: .line 259
            iload 2 /* i */
            iload 5 /* numRounds */
            iconst_1
            isub
            if_icmpge 30
        26: .line 260
            aload 4 /* digest */
            iconst_0
            aload 11 /* xorKey */
            iload 6 /* xorOffset */
        27: .line 261
            aload 4 /* digest */
            arraylength
        28: .line 260
            invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
        29: .line 262
            goto 33
        30: .line 263
      StackMap locals:
      StackMap stack:
            aload 4 /* digest */
            iconst_0
            aload 11 /* xorKey */
            iload 6 /* xorOffset */
        31: .line 264
            aload 11 /* xorKey */
            arraylength
            iload 6 /* xorOffset */
            isub
        32: .line 263
            invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
        33: .line 253
      StackMap locals:
      StackMap stack:
            iinc 2 /* i */ 1
            iinc 6 /* xorOffset */ 20
        34: .line 252
      StackMap locals:
      StackMap stack:
            iload 2 /* i */
            iload 5 /* numRounds */
        35: .line 251
            if_icmplt 21
        36: .line 269
            aload 10 /* encrKey */
            arraylength
            newarray 8
            astore 13 /* plainKey */
        start local 13 // byte[] plainKey
        37: .line 270
            iconst_0
            istore 2 /* i */
            goto 40
        38: .line 271
      StackMap locals: byte[]
      StackMap stack:
            aload 13 /* plainKey */
            iload 2 /* i */
            aload 10 /* encrKey */
            iload 2 /* i */
            baload
            aload 11 /* xorKey */
            iload 2 /* i */
            baload
            ixor
            i2b
            bastore
        39: .line 270
            iinc 2 /* i */ 1
      StackMap locals:
      StackMap stack:
        40: iload 2 /* i */
            aload 13 /* plainKey */
            arraylength
            if_icmplt 38
        41: .line 279
            aload 8 /* md */
            aload 12 /* passwdBytes */
            invokevirtual java.security.MessageDigest.update:([B)V
        42: .line 280
            aload 12 /* passwdBytes */
            iconst_0
            invokestatic java.util.Arrays.fill:([BB)V
        43: .line 281
            aconst_null
            astore 12 /* passwdBytes */
        44: .line 282
            aload 8 /* md */
            aload 13 /* plainKey */
            invokevirtual java.security.MessageDigest.update:([B)V
        45: .line 283
            aload 8 /* md */
            invokevirtual java.security.MessageDigest.digest:()[B
            astore 4 /* digest */
        46: .line 284
            aload 8 /* md */
            invokevirtual java.security.MessageDigest.reset:()V
        47: .line 285
            iconst_0
            istore 2 /* i */
            goto 51
        48: .line 286
      StackMap locals:
      StackMap stack:
            aload 4 /* digest */
            iload 2 /* i */
            baload
            aload 1 /* protectedKey */
            bipush 20
            iload 7 /* encrKeyLen */
            iadd
            iload 2 /* i */
            iadd
            baload
            if_icmpeq 50
        49: .line 287
            new java.security.UnrecoverableKeyException
            dup
            ldc "Cannot recover key"
            invokespecial java.security.UnrecoverableKeyException.<init>:(Ljava/lang/String;)V
            athrow
        50: .line 285
      StackMap locals:
      StackMap stack:
            iinc 2 /* i */ 1
      StackMap locals:
      StackMap stack:
        51: iload 2 /* i */
            aload 4 /* digest */
            arraylength
            if_icmplt 48
        52: .line 290
            aload 13 /* plainKey */
            areturn
        end local 13 // byte[] plainKey
        end local 12 // byte[] passwdBytes
        end local 11 // byte[] xorKey
        end local 10 // byte[] encrKey
        end local 9 // byte[] salt
        end local 8 // java.security.MessageDigest md
        end local 7 // int encrKeyLen
        end local 6 // int xorOffset
        end local 5 // int numRounds
        end local 4 // byte[] digest
        end local 3 // int j
        end local 2 // int i
        end local 1 // byte[] protectedKey
        end local 0 // com.sun.crypto.provider.KeyProtector this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   53     0          this  Lcom/sun/crypto/provider/KeyProtector;
            0   53     1  protectedKey  [B
           12   53     2             i  I
           13   53     3             j  I
           20   53     4        digest  [B
            5   53     5     numRounds  I
           19   53     6     xorOffset  I
            4   53     7    encrKeyLen  I
            1   53     8            md  Ljava/security/MessageDigest;
            2   53     9          salt  [B
            8   53    10       encrKey  [B
           10   53    11        xorKey  [B
           11   53    12   passwdBytes  [B
           37   53    13      plainKey  [B
    Exceptions:
      throws java.security.UnrecoverableKeyException, java.security.NoSuchAlgorithmException
    MethodParameters:
              Name  Flags
      protectedKey  

  javax.crypto.SealedObject seal(java.security.Key);
    descriptor: (Ljava/security/Key;)Ljavax/crypto/SealedObject;
    flags: (0x0000) 
    Code:
      stack=5, locals=9, args_size=2
        start local 0 // com.sun.crypto.provider.KeyProtector this
        start local 1 // java.security.Key key
         0: .line 301
            bipush 8
            newarray 8
            astore 2 /* salt */
        start local 2 // byte[] salt
         1: .line 302
            invokestatic com.sun.crypto.provider.SunJCE.getRandom:()Ljava/security/SecureRandom;
            aload 2 /* salt */
            invokevirtual java.security.SecureRandom.nextBytes:([B)V
         2: .line 305
            new javax.crypto.spec.PBEParameterSpec
            dup
            aload 2 /* salt */
            ldc 200000
            invokespecial javax.crypto.spec.PBEParameterSpec.<init>:([BI)V
            astore 3 /* pbeSpec */
        start local 3 // javax.crypto.spec.PBEParameterSpec pbeSpec
         3: .line 308
            new javax.crypto.spec.PBEKeySpec
            dup
            aload 0 /* this */
            getfield com.sun.crypto.provider.KeyProtector.password:[C
            invokespecial javax.crypto.spec.PBEKeySpec.<init>:([C)V
            astore 4 /* pbeKeySpec */
        start local 4 // javax.crypto.spec.PBEKeySpec pbeKeySpec
         4: .line 309
            aconst_null
            astore 5 /* sKey */
        start local 5 // javax.crypto.SecretKey sKey
         5: .line 312
            new com.sun.crypto.provider.PBEKey
            dup
            aload 4 /* pbeKeySpec */
            ldc "PBEWithMD5AndTripleDES"
            iconst_0
            invokespecial com.sun.crypto.provider.PBEKey.<init>:(Ljavax/crypto/spec/PBEKeySpec;Ljava/lang/String;Z)V
            astore 5 /* sKey */
         6: .line 313
            aload 4 /* pbeKeySpec */
            invokevirtual javax.crypto.spec.PBEKeySpec.clearPassword:()V
         7: .line 317
            new com.sun.crypto.provider.PBEWithMD5AndTripleDESCipher
            dup
            invokespecial com.sun.crypto.provider.PBEWithMD5AndTripleDESCipher.<init>:()V
            astore 7 /* cipherSpi */
        start local 7 // com.sun.crypto.provider.PBEWithMD5AndTripleDESCipher cipherSpi
         8: .line 318
            new com.sun.crypto.provider.CipherForKeyProtector
            dup
            aload 7 /* cipherSpi */
            invokestatic com.sun.crypto.provider.SunJCE.getInstance:()Lcom/sun/crypto/provider/SunJCE;
         9: .line 319
            ldc "PBEWithMD5AndTripleDES"
        10: .line 318
            invokespecial com.sun.crypto.provider.CipherForKeyProtector.<init>:(Ljavax/crypto/CipherSpi;Ljava/security/Provider;Ljava/lang/String;)V
            astore 6 /* cipher */
        start local 6 // javax.crypto.Cipher cipher
        11: .line 320
            aload 6 /* cipher */
            iconst_1
            aload 5 /* sKey */
            aload 3 /* pbeSpec */
            invokevirtual javax.crypto.Cipher.init:(ILjava/security/Key;Ljava/security/spec/AlgorithmParameterSpec;)V
        end local 7 // com.sun.crypto.provider.PBEWithMD5AndTripleDESCipher cipherSpi
        12: .line 321
            goto 16
        end local 6 // javax.crypto.Cipher cipher
      StackMap locals: com.sun.crypto.provider.KeyProtector java.security.Key byte[] javax.crypto.spec.PBEParameterSpec javax.crypto.spec.PBEKeySpec javax.crypto.SecretKey
      StackMap stack: java.lang.Throwable
        13: astore 8
        14: .line 322
            aload 5 /* sKey */
            ifnull 15
            aload 5 /* sKey */
            invokeinterface javax.crypto.SecretKey.destroy:()V
        15: .line 323
      StackMap locals: com.sun.crypto.provider.KeyProtector java.security.Key byte[] javax.crypto.spec.PBEParameterSpec javax.crypto.spec.PBEKeySpec javax.crypto.SecretKey top top java.lang.Throwable
      StackMap stack:
            aload 8
            athrow
        start local 6 // javax.crypto.Cipher cipher
        16: .line 322
      StackMap locals: com.sun.crypto.provider.KeyProtector java.security.Key byte[] javax.crypto.spec.PBEParameterSpec javax.crypto.spec.PBEKeySpec javax.crypto.SecretKey javax.crypto.Cipher
      StackMap stack:
            aload 5 /* sKey */
            ifnull 17
            aload 5 /* sKey */
            invokeinterface javax.crypto.SecretKey.destroy:()V
        17: .line 324
      StackMap locals:
      StackMap stack:
            new com.sun.crypto.provider.SealedObjectForKeyProtector
            dup
            aload 1 /* key */
            aload 6 /* cipher */
            invokespecial com.sun.crypto.provider.SealedObjectForKeyProtector.<init>:(Ljava/io/Serializable;Ljavax/crypto/Cipher;)V
            areturn
        end local 6 // javax.crypto.Cipher cipher
        end local 5 // javax.crypto.SecretKey sKey
        end local 4 // javax.crypto.spec.PBEKeySpec pbeKeySpec
        end local 3 // javax.crypto.spec.PBEParameterSpec pbeSpec
        end local 2 // byte[] salt
        end local 1 // java.security.Key key
        end local 0 // com.sun.crypto.provider.KeyProtector this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   18     0        this  Lcom/sun/crypto/provider/KeyProtector;
            0   18     1         key  Ljava/security/Key;
            1   18     2        salt  [B
            3   18     3     pbeSpec  Ljavax/crypto/spec/PBEParameterSpec;
            4   18     4  pbeKeySpec  Ljavax/crypto/spec/PBEKeySpec;
            5   18     5        sKey  Ljavax/crypto/SecretKey;
           11   13     6      cipher  Ljavax/crypto/Cipher;
           16   18     6      cipher  Ljavax/crypto/Cipher;
            8   12     7   cipherSpi  Lcom/sun/crypto/provider/PBEWithMD5AndTripleDESCipher;
      Exception table:
        from    to  target  type
           5    13      13  any
    Exceptions:
      throws java.lang.Exception
    MethodParameters:
      Name  Flags
      key   

  java.security.Key unseal(javax.crypto.SealedObject, int);
    descriptor: (Ljavax/crypto/SealedObject;I)Ljava/security/Key;
    flags: (0x0000) 
    Code:
      stack=5, locals=12, args_size=3
        start local 0 // com.sun.crypto.provider.KeyProtector this
        start local 1 // javax.crypto.SealedObject so
        start local 2 // int maxLength
         0: .line 335
            aconst_null
            astore 3 /* sKey */
        start local 3 // javax.crypto.SecretKey sKey
         1: .line 338
            new javax.crypto.spec.PBEKeySpec
            dup
            aload 0 /* this */
            getfield com.sun.crypto.provider.KeyProtector.password:[C
            invokespecial javax.crypto.spec.PBEKeySpec.<init>:([C)V
            astore 4 /* pbeKeySpec */
        start local 4 // javax.crypto.spec.PBEKeySpec pbeKeySpec
         2: .line 339
            new com.sun.crypto.provider.PBEKey
            dup
            aload 4 /* pbeKeySpec */
         3: .line 340
            ldc "PBEWithMD5AndTripleDES"
            iconst_0
         4: .line 339
            invokespecial com.sun.crypto.provider.PBEKey.<init>:(Ljavax/crypto/spec/PBEKeySpec;Ljava/lang/String;Z)V
            astore 3 /* sKey */
         5: .line 341
            aload 4 /* pbeKeySpec */
            invokevirtual javax.crypto.spec.PBEKeySpec.clearPassword:()V
         6: .line 343
            aconst_null
            astore 5 /* soForKeyProtector */
        start local 5 // com.sun.crypto.provider.SealedObjectForKeyProtector soForKeyProtector
         7: .line 344
            aload 1 /* so */
            instanceof com.sun.crypto.provider.SealedObjectForKeyProtector
            ifne 10
         8: .line 345
            new com.sun.crypto.provider.SealedObjectForKeyProtector
            dup
            aload 1 /* so */
            invokespecial com.sun.crypto.provider.SealedObjectForKeyProtector.<init>:(Ljavax/crypto/SealedObject;)V
            astore 5 /* soForKeyProtector */
         9: .line 346
            goto 11
        10: .line 347
      StackMap locals: javax.crypto.SecretKey javax.crypto.spec.PBEKeySpec com.sun.crypto.provider.SealedObjectForKeyProtector
      StackMap stack:
            aload 1 /* so */
            checkcast com.sun.crypto.provider.SealedObjectForKeyProtector
            astore 5 /* soForKeyProtector */
        11: .line 349
      StackMap locals:
      StackMap stack:
            aload 5 /* soForKeyProtector */
            invokevirtual com.sun.crypto.provider.SealedObjectForKeyProtector.getParameters:()Ljava/security/AlgorithmParameters;
            astore 6 /* params */
        start local 6 // java.security.AlgorithmParameters params
        12: .line 350
            aload 6 /* params */
            ifnonnull 14
        13: .line 351
            new java.security.UnrecoverableKeyException
            dup
            ldc "Cannot get algorithm parameters"
            invokespecial java.security.UnrecoverableKeyException.<init>:(Ljava/lang/String;)V
            athrow
        14: .line 356
      StackMap locals: java.security.AlgorithmParameters
      StackMap stack:
            aload 6 /* params */
            ldc Ljavax/crypto/spec/PBEParameterSpec;
            invokevirtual java.security.AlgorithmParameters.getParameterSpec:(Ljava/lang/Class;)Ljava/security/spec/AlgorithmParameterSpec;
            checkcast javax.crypto.spec.PBEParameterSpec
            astore 7 /* pbeSpec */
        start local 7 // javax.crypto.spec.PBEParameterSpec pbeSpec
        15: .line 357
            goto 18
        end local 7 // javax.crypto.spec.PBEParameterSpec pbeSpec
      StackMap locals:
      StackMap stack: java.security.spec.InvalidParameterSpecException
        16: pop
        17: .line 358
            new java.io.IOException
            dup
            ldc "Invalid PBE algorithm parameters"
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        start local 7 // javax.crypto.spec.PBEParameterSpec pbeSpec
        18: .line 360
      StackMap locals: javax.crypto.spec.PBEParameterSpec
      StackMap stack:
            aload 7 /* pbeSpec */
            invokevirtual javax.crypto.spec.PBEParameterSpec.getIterationCount:()I
            ldc 5000000
            if_icmple 20
        19: .line 361
            new java.io.IOException
            dup
            ldc "PBE iteration count too large"
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        20: .line 364
      StackMap locals:
      StackMap stack:
            new com.sun.crypto.provider.PBEWithMD5AndTripleDESCipher
            dup
            invokespecial com.sun.crypto.provider.PBEWithMD5AndTripleDESCipher.<init>:()V
            astore 8 /* cipherSpi */
        start local 8 // com.sun.crypto.provider.PBEWithMD5AndTripleDESCipher cipherSpi
        21: .line 365
            new com.sun.crypto.provider.CipherForKeyProtector
            dup
            aload 8 /* cipherSpi */
        22: .line 366
            invokestatic com.sun.crypto.provider.SunJCE.getInstance:()Lcom/sun/crypto/provider/SunJCE;
        23: .line 367
            ldc "PBEWithMD5AndTripleDES"
        24: .line 365
            invokespecial com.sun.crypto.provider.CipherForKeyProtector.<init>:(Ljavax/crypto/CipherSpi;Ljava/security/Provider;Ljava/lang/String;)V
            astore 9 /* cipher */
        start local 9 // javax.crypto.Cipher cipher
        25: .line 368
            aload 9 /* cipher */
            iconst_2
            aload 3 /* sKey */
            aload 6 /* params */
            invokevirtual javax.crypto.Cipher.init:(ILjava/security/Key;Ljava/security/AlgorithmParameters;)V
        26: .line 369
            aload 5 /* soForKeyProtector */
            aload 9 /* cipher */
            iload 2 /* maxLength */
            invokevirtual com.sun.crypto.provider.SealedObjectForKeyProtector.getKey:(Ljavax/crypto/Cipher;I)Ljava/security/Key;
            astore 11
        27: .line 381
            aload 3 /* sKey */
            ifnull 31
        28: .line 383
            aload 3 /* sKey */
            invokeinterface javax.crypto.SecretKey.destroy:()V
        29: .line 384
            goto 31
      StackMap locals: com.sun.crypto.provider.KeyProtector javax.crypto.SealedObject int javax.crypto.SecretKey javax.crypto.spec.PBEKeySpec com.sun.crypto.provider.SealedObjectForKeyProtector java.security.AlgorithmParameters javax.crypto.spec.PBEParameterSpec com.sun.crypto.provider.PBEWithMD5AndTripleDESCipher javax.crypto.Cipher top java.security.Key
      StackMap stack: javax.security.auth.DestroyFailedException
        30: pop
        31: .line 369
      StackMap locals:
      StackMap stack:
            aload 11
            areturn
        end local 9 // javax.crypto.Cipher cipher
        end local 8 // com.sun.crypto.provider.PBEWithMD5AndTripleDESCipher cipherSpi
        end local 7 // javax.crypto.spec.PBEParameterSpec pbeSpec
        end local 6 // java.security.AlgorithmParameters params
        end local 5 // com.sun.crypto.provider.SealedObjectForKeyProtector soForKeyProtector
        end local 4 // javax.crypto.spec.PBEKeySpec pbeKeySpec
        32: .line 370
      StackMap locals: com.sun.crypto.provider.KeyProtector javax.crypto.SealedObject int javax.crypto.SecretKey
      StackMap stack: java.security.NoSuchAlgorithmException
            astore 4 /* ex */
        start local 4 // java.security.NoSuchAlgorithmException ex
        33: .line 373
            aload 4 /* ex */
            athrow
        end local 4 // java.security.NoSuchAlgorithmException ex
        34: .line 374
      StackMap locals:
      StackMap stack: java.io.IOException
            astore 4 /* ioe */
        start local 4 // java.io.IOException ioe
        35: .line 375
            new java.security.UnrecoverableKeyException
            dup
            aload 4 /* ioe */
            invokevirtual java.io.IOException.getMessage:()Ljava/lang/String;
            invokespecial java.security.UnrecoverableKeyException.<init>:(Ljava/lang/String;)V
            athrow
        end local 4 // java.io.IOException ioe
        36: .line 376
      StackMap locals:
      StackMap stack: java.lang.ClassNotFoundException
            astore 4 /* cnfe */
        start local 4 // java.lang.ClassNotFoundException cnfe
        37: .line 377
            new java.security.UnrecoverableKeyException
            dup
            aload 4 /* cnfe */
            invokevirtual java.lang.ClassNotFoundException.getMessage:()Ljava/lang/String;
            invokespecial java.security.UnrecoverableKeyException.<init>:(Ljava/lang/String;)V
            athrow
        end local 4 // java.lang.ClassNotFoundException cnfe
        38: .line 378
      StackMap locals:
      StackMap stack: java.security.GeneralSecurityException
            astore 4 /* gse */
        start local 4 // java.security.GeneralSecurityException gse
        39: .line 379
            new java.security.UnrecoverableKeyException
            dup
            aload 4 /* gse */
            invokevirtual java.security.GeneralSecurityException.getMessage:()Ljava/lang/String;
            invokespecial java.security.UnrecoverableKeyException.<init>:(Ljava/lang/String;)V
            athrow
        end local 4 // java.security.GeneralSecurityException gse
        40: .line 380
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 10
        41: .line 381
            aload 3 /* sKey */
            ifnull 45
        42: .line 383
            aload 3 /* sKey */
            invokeinterface javax.crypto.SecretKey.destroy:()V
        43: .line 384
            goto 45
      StackMap locals: com.sun.crypto.provider.KeyProtector javax.crypto.SealedObject int javax.crypto.SecretKey top top top top top top java.lang.Throwable
      StackMap stack: javax.security.auth.DestroyFailedException
        44: pop
        45: .line 388
      StackMap locals:
      StackMap stack:
            aload 10
            athrow
        end local 3 // javax.crypto.SecretKey sKey
        end local 2 // int maxLength
        end local 1 // javax.crypto.SealedObject so
        end local 0 // com.sun.crypto.provider.KeyProtector this
      LocalVariableTable:
        Start  End  Slot               Name  Signature
            0   46     0               this  Lcom/sun/crypto/provider/KeyProtector;
            0   46     1                 so  Ljavax/crypto/SealedObject;
            0   46     2          maxLength  I
            1   46     3               sKey  Ljavax/crypto/SecretKey;
            2   32     4         pbeKeySpec  Ljavax/crypto/spec/PBEKeySpec;
            7   32     5  soForKeyProtector  Lcom/sun/crypto/provider/SealedObjectForKeyProtector;
           12   32     6             params  Ljava/security/AlgorithmParameters;
           15   16     7            pbeSpec  Ljavax/crypto/spec/PBEParameterSpec;
           18   32     7            pbeSpec  Ljavax/crypto/spec/PBEParameterSpec;
           21   32     8          cipherSpi  Lcom/sun/crypto/provider/PBEWithMD5AndTripleDESCipher;
           25   32     9             cipher  Ljavax/crypto/Cipher;
           33   34     4                 ex  Ljava/security/NoSuchAlgorithmException;
           35   36     4                ioe  Ljava/io/IOException;
           37   38     4               cnfe  Ljava/lang/ClassNotFoundException;
           39   40     4                gse  Ljava/security/GeneralSecurityException;
      Exception table:
        from    to  target  type
          14    15      16  Class java.security.spec.InvalidParameterSpecException
          28    29      30  Class javax.security.auth.DestroyFailedException
           1    27      32  Class java.security.NoSuchAlgorithmException
           1    27      34  Class java.io.IOException
           1    27      36  Class java.lang.ClassNotFoundException
           1    27      38  Class java.security.GeneralSecurityException
           1    27      40  any
          32    40      40  any
          42    43      44  Class javax.security.auth.DestroyFailedException
    Exceptions:
      throws java.security.NoSuchAlgorithmException, java.security.UnrecoverableKeyException
    MethodParameters:
           Name  Flags
      so         
      maxLength  
}
SourceFile: "KeyProtector.java"