abstract class com.sun.crypto.provider.PBES2Parameters extends java.security.AlgorithmParametersSpi
  minor version: 0
  major version: 59
  flags: flags: (0x0420) ACC_SUPER, ACC_ABSTRACT
  this_class: com.sun.crypto.provider.PBES2Parameters
  super_class: java.security.AlgorithmParametersSpi
{
  private static final int[] pkcs5PBKDF2;
    descriptor: [I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final int[] pkcs5PBES2;
    descriptor: [I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final int[] hmacWithSHA1;
    descriptor: [I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final int[] hmacWithSHA224;
    descriptor: [I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final int[] hmacWithSHA256;
    descriptor: [I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final int[] hmacWithSHA384;
    descriptor: [I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final int[] hmacWithSHA512;
    descriptor: [I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final int[] aes128CBC;
    descriptor: [I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final int[] aes192CBC;
    descriptor: [I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final int[] aes256CBC;
    descriptor: [I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static sun.security.util.ObjectIdentifier pkcs5PBKDF2_OID;
    descriptor: Lsun/security/util/ObjectIdentifier;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC

  private static sun.security.util.ObjectIdentifier pkcs5PBES2_OID;
    descriptor: Lsun/security/util/ObjectIdentifier;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC

  private static sun.security.util.ObjectIdentifier hmacWithSHA1_OID;
    descriptor: Lsun/security/util/ObjectIdentifier;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC

  private static sun.security.util.ObjectIdentifier hmacWithSHA224_OID;
    descriptor: Lsun/security/util/ObjectIdentifier;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC

  private static sun.security.util.ObjectIdentifier hmacWithSHA256_OID;
    descriptor: Lsun/security/util/ObjectIdentifier;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC

  private static sun.security.util.ObjectIdentifier hmacWithSHA384_OID;
    descriptor: Lsun/security/util/ObjectIdentifier;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC

  private static sun.security.util.ObjectIdentifier hmacWithSHA512_OID;
    descriptor: Lsun/security/util/ObjectIdentifier;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC

  private static sun.security.util.ObjectIdentifier aes128CBC_OID;
    descriptor: Lsun/security/util/ObjectIdentifier;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC

  private static sun.security.util.ObjectIdentifier aes192CBC_OID;
    descriptor: Lsun/security/util/ObjectIdentifier;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC

  private static sun.security.util.ObjectIdentifier aes256CBC_OID;
    descriptor: Lsun/security/util/ObjectIdentifier;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC

  private java.lang.String pbes2AlgorithmName;
    descriptor: Ljava/lang/String;
    flags: (0x0002) ACC_PRIVATE

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

  private int iCount;
    descriptor: I
    flags: (0x0002) ACC_PRIVATE

  private java.security.spec.AlgorithmParameterSpec cipherParam;
    descriptor: Ljava/security/spec/AlgorithmParameterSpec;
    flags: (0x0002) ACC_PRIVATE

  private sun.security.util.ObjectIdentifier kdfAlgo_OID;
    descriptor: Lsun/security/util/ObjectIdentifier;
    flags: (0x0002) ACC_PRIVATE

  private sun.security.util.ObjectIdentifier cipherAlgo_OID;
    descriptor: Lsun/security/util/ObjectIdentifier;
    flags: (0x0002) ACC_PRIVATE

  private int keysize;
    descriptor: I
    flags: (0x0002) ACC_PRIVATE

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=4, locals=0, args_size=0
         0: .line 101
            bipush 7
            newarray 10
            dup
            iconst_0
            iconst_1
            iastore
            dup
            iconst_1
            iconst_2
            iastore
            dup
            iconst_2
            sipush 840
            iastore
            dup
            iconst_3
            ldc 113549
            iastore
            dup
            iconst_4
            iconst_1
            iastore
            dup
            iconst_5
            iconst_5
            iastore
            dup
            bipush 6
            bipush 12
            iastore
         1: .line 100
            putstatic com.sun.crypto.provider.PBES2Parameters.pkcs5PBKDF2:[I
         2: .line 103
            bipush 7
            newarray 10
            dup
            iconst_0
            iconst_1
            iastore
            dup
            iconst_1
            iconst_2
            iastore
            dup
            iconst_2
            sipush 840
            iastore
            dup
            iconst_3
            ldc 113549
            iastore
            dup
            iconst_4
            iconst_1
            iastore
            dup
            iconst_5
            iconst_5
            iastore
            dup
            bipush 6
            bipush 13
            iastore
         3: .line 102
            putstatic com.sun.crypto.provider.PBES2Parameters.pkcs5PBES2:[I
         4: .line 105
            bipush 6
            newarray 10
            dup
            iconst_0
            iconst_1
            iastore
            dup
            iconst_1
            iconst_2
            iastore
            dup
            iconst_2
            sipush 840
            iastore
            dup
            iconst_3
            ldc 113549
            iastore
            dup
            iconst_4
            iconst_2
            iastore
            dup
            iconst_5
            bipush 7
            iastore
         5: .line 104
            putstatic com.sun.crypto.provider.PBES2Parameters.hmacWithSHA1:[I
         6: .line 107
            bipush 6
            newarray 10
            dup
            iconst_0
            iconst_1
            iastore
            dup
            iconst_1
            iconst_2
            iastore
            dup
            iconst_2
            sipush 840
            iastore
            dup
            iconst_3
            ldc 113549
            iastore
            dup
            iconst_4
            iconst_2
            iastore
            dup
            iconst_5
            bipush 8
            iastore
         7: .line 106
            putstatic com.sun.crypto.provider.PBES2Parameters.hmacWithSHA224:[I
         8: .line 109
            bipush 6
            newarray 10
            dup
            iconst_0
            iconst_1
            iastore
            dup
            iconst_1
            iconst_2
            iastore
            dup
            iconst_2
            sipush 840
            iastore
            dup
            iconst_3
            ldc 113549
            iastore
            dup
            iconst_4
            iconst_2
            iastore
            dup
            iconst_5
            bipush 9
            iastore
         9: .line 108
            putstatic com.sun.crypto.provider.PBES2Parameters.hmacWithSHA256:[I
        10: .line 111
            bipush 6
            newarray 10
            dup
            iconst_0
            iconst_1
            iastore
            dup
            iconst_1
            iconst_2
            iastore
            dup
            iconst_2
            sipush 840
            iastore
            dup
            iconst_3
            ldc 113549
            iastore
            dup
            iconst_4
            iconst_2
            iastore
            dup
            iconst_5
            bipush 10
            iastore
        11: .line 110
            putstatic com.sun.crypto.provider.PBES2Parameters.hmacWithSHA384:[I
        12: .line 113
            bipush 6
            newarray 10
            dup
            iconst_0
            iconst_1
            iastore
            dup
            iconst_1
            iconst_2
            iastore
            dup
            iconst_2
            sipush 840
            iastore
            dup
            iconst_3
            ldc 113549
            iastore
            dup
            iconst_4
            iconst_2
            iastore
            dup
            iconst_5
            bipush 11
            iastore
        13: .line 112
            putstatic com.sun.crypto.provider.PBES2Parameters.hmacWithSHA512:[I
        14: .line 115
            bipush 9
            newarray 10
            dup
            iconst_0
            iconst_2
            iastore
            dup
            iconst_1
            bipush 16
            iastore
            dup
            iconst_2
            sipush 840
            iastore
            dup
            iconst_3
            iconst_1
            iastore
            dup
            iconst_4
            bipush 101
            iastore
            dup
            iconst_5
            iconst_3
            iastore
            dup
            bipush 6
            iconst_4
            iastore
            dup
            bipush 7
            iconst_1
            iastore
            dup
            bipush 8
            iconst_2
            iastore
        15: .line 114
            putstatic com.sun.crypto.provider.PBES2Parameters.aes128CBC:[I
        16: .line 117
            bipush 9
            newarray 10
            dup
            iconst_0
            iconst_2
            iastore
            dup
            iconst_1
            bipush 16
            iastore
            dup
            iconst_2
            sipush 840
            iastore
            dup
            iconst_3
            iconst_1
            iastore
            dup
            iconst_4
            bipush 101
            iastore
            dup
            iconst_5
            iconst_3
            iastore
            dup
            bipush 6
            iconst_4
            iastore
            dup
            bipush 7
            iconst_1
            iastore
            dup
            bipush 8
            bipush 22
            iastore
        17: .line 116
            putstatic com.sun.crypto.provider.PBES2Parameters.aes192CBC:[I
        18: .line 119
            bipush 9
            newarray 10
            dup
            iconst_0
            iconst_2
            iastore
            dup
            iconst_1
            bipush 16
            iastore
            dup
            iconst_2
            sipush 840
            iastore
            dup
            iconst_3
            iconst_1
            iastore
            dup
            iconst_4
            bipush 101
            iastore
            dup
            iconst_5
            iconst_3
            iastore
            dup
            bipush 6
            iconst_4
            iastore
            dup
            bipush 7
            iconst_1
            iastore
            dup
            bipush 8
            bipush 42
            iastore
        19: .line 118
            putstatic com.sun.crypto.provider.PBES2Parameters.aes256CBC:[I
        20: .line 134
            new sun.security.util.ObjectIdentifier
            dup
            getstatic com.sun.crypto.provider.PBES2Parameters.pkcs5PBKDF2:[I
            invokespecial sun.security.util.ObjectIdentifier.<init>:([I)V
            putstatic com.sun.crypto.provider.PBES2Parameters.pkcs5PBKDF2_OID:Lsun/security/util/ObjectIdentifier;
        21: .line 135
            new sun.security.util.ObjectIdentifier
            dup
            getstatic com.sun.crypto.provider.PBES2Parameters.pkcs5PBES2:[I
            invokespecial sun.security.util.ObjectIdentifier.<init>:([I)V
            putstatic com.sun.crypto.provider.PBES2Parameters.pkcs5PBES2_OID:Lsun/security/util/ObjectIdentifier;
        22: .line 136
            new sun.security.util.ObjectIdentifier
            dup
            getstatic com.sun.crypto.provider.PBES2Parameters.hmacWithSHA1:[I
            invokespecial sun.security.util.ObjectIdentifier.<init>:([I)V
            putstatic com.sun.crypto.provider.PBES2Parameters.hmacWithSHA1_OID:Lsun/security/util/ObjectIdentifier;
        23: .line 137
            new sun.security.util.ObjectIdentifier
            dup
            getstatic com.sun.crypto.provider.PBES2Parameters.hmacWithSHA224:[I
            invokespecial sun.security.util.ObjectIdentifier.<init>:([I)V
            putstatic com.sun.crypto.provider.PBES2Parameters.hmacWithSHA224_OID:Lsun/security/util/ObjectIdentifier;
        24: .line 138
            new sun.security.util.ObjectIdentifier
            dup
            getstatic com.sun.crypto.provider.PBES2Parameters.hmacWithSHA256:[I
            invokespecial sun.security.util.ObjectIdentifier.<init>:([I)V
            putstatic com.sun.crypto.provider.PBES2Parameters.hmacWithSHA256_OID:Lsun/security/util/ObjectIdentifier;
        25: .line 139
            new sun.security.util.ObjectIdentifier
            dup
            getstatic com.sun.crypto.provider.PBES2Parameters.hmacWithSHA384:[I
            invokespecial sun.security.util.ObjectIdentifier.<init>:([I)V
            putstatic com.sun.crypto.provider.PBES2Parameters.hmacWithSHA384_OID:Lsun/security/util/ObjectIdentifier;
        26: .line 140
            new sun.security.util.ObjectIdentifier
            dup
            getstatic com.sun.crypto.provider.PBES2Parameters.hmacWithSHA512:[I
            invokespecial sun.security.util.ObjectIdentifier.<init>:([I)V
            putstatic com.sun.crypto.provider.PBES2Parameters.hmacWithSHA512_OID:Lsun/security/util/ObjectIdentifier;
        27: .line 141
            new sun.security.util.ObjectIdentifier
            dup
            getstatic com.sun.crypto.provider.PBES2Parameters.aes128CBC:[I
            invokespecial sun.security.util.ObjectIdentifier.<init>:([I)V
            putstatic com.sun.crypto.provider.PBES2Parameters.aes128CBC_OID:Lsun/security/util/ObjectIdentifier;
        28: .line 142
            new sun.security.util.ObjectIdentifier
            dup
            getstatic com.sun.crypto.provider.PBES2Parameters.aes192CBC:[I
            invokespecial sun.security.util.ObjectIdentifier.<init>:([I)V
            putstatic com.sun.crypto.provider.PBES2Parameters.aes192CBC_OID:Lsun/security/util/ObjectIdentifier;
        29: .line 143
            new sun.security.util.ObjectIdentifier
            dup
            getstatic com.sun.crypto.provider.PBES2Parameters.aes256CBC:[I
            invokespecial sun.security.util.ObjectIdentifier.<init>:([I)V
            putstatic com.sun.crypto.provider.PBES2Parameters.aes256CBC_OID:Lsun/security/util/ObjectIdentifier;
        30: .line 144
            goto 32
      StackMap locals:
      StackMap stack: java.io.IOException
        31: pop
        32: .line 147
      StackMap locals:
      StackMap stack:
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature
      Exception table:
        from    to  target  type
          20    30      31  Class java.io.IOException

  void <init>();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // com.sun.crypto.provider.PBES2Parameters this
         0: .line 170
            aload 0 /* this */
            invokespecial java.security.AlgorithmParametersSpi.<init>:()V
         1: .line 150
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.PBES2Parameters.pbes2AlgorithmName:Ljava/lang/String;
         2: .line 153
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.PBES2Parameters.salt:[B
         3: .line 156
            aload 0 /* this */
            iconst_0
            putfield com.sun.crypto.provider.PBES2Parameters.iCount:I
         4: .line 159
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.PBES2Parameters.cipherParam:Ljava/security/spec/AlgorithmParameterSpec;
         5: .line 162
            aload 0 /* this */
            getstatic com.sun.crypto.provider.PBES2Parameters.hmacWithSHA1_OID:Lsun/security/util/ObjectIdentifier;
            putfield com.sun.crypto.provider.PBES2Parameters.kdfAlgo_OID:Lsun/security/util/ObjectIdentifier;
         6: .line 165
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.PBES2Parameters.cipherAlgo_OID:Lsun/security/util/ObjectIdentifier;
         7: .line 168
            aload 0 /* this */
            iconst_m1
            putfield com.sun.crypto.provider.PBES2Parameters.keysize:I
         8: .line 172
            return
        end local 0 // com.sun.crypto.provider.PBES2Parameters this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    9     0  this  Lcom/sun/crypto/provider/PBES2Parameters;

  void <init>(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0000) 
    Code:
      stack=5, locals=7, args_size=2
        start local 0 // com.sun.crypto.provider.PBES2Parameters this
        start local 1 // java.lang.String pbes2AlgorithmName
         0: .line 174
            aload 0 /* this */
            invokespecial java.security.AlgorithmParametersSpi.<init>:()V
         1: .line 150
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.PBES2Parameters.pbes2AlgorithmName:Ljava/lang/String;
         2: .line 153
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.PBES2Parameters.salt:[B
         3: .line 156
            aload 0 /* this */
            iconst_0
            putfield com.sun.crypto.provider.PBES2Parameters.iCount:I
         4: .line 159
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.PBES2Parameters.cipherParam:Ljava/security/spec/AlgorithmParameterSpec;
         5: .line 162
            aload 0 /* this */
            getstatic com.sun.crypto.provider.PBES2Parameters.hmacWithSHA1_OID:Lsun/security/util/ObjectIdentifier;
            putfield com.sun.crypto.provider.PBES2Parameters.kdfAlgo_OID:Lsun/security/util/ObjectIdentifier;
         6: .line 165
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.PBES2Parameters.cipherAlgo_OID:Lsun/security/util/ObjectIdentifier;
         7: .line 168
            aload 0 /* this */
            iconst_m1
            putfield com.sun.crypto.provider.PBES2Parameters.keysize:I
         8: .line 176
            aconst_null
            astore 3 /* kdfAlgo */
        start local 3 // java.lang.String kdfAlgo
         9: .line 177
            aconst_null
            astore 4 /* cipherAlgo */
        start local 4 // java.lang.String cipherAlgo
        10: .line 180
            aload 0 /* this */
            aload 1 /* pbes2AlgorithmName */
            putfield com.sun.crypto.provider.PBES2Parameters.pbes2AlgorithmName:Ljava/lang/String;
        11: .line 181
            aload 1 /* pbes2AlgorithmName */
            ldc "PBEWith"
            invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
            ifeq 31
        12: .line 182
            aload 1 /* pbes2AlgorithmName */
            ldc "And"
            bipush 8
            invokevirtual java.lang.String.indexOf:(Ljava/lang/String;I)I
            dup
            istore 2 /* and */
        start local 2 // int and
        13: ifle 31
        14: .line 183
            aload 1 /* pbes2AlgorithmName */
            bipush 7
            iload 2 /* and */
            invokevirtual java.lang.String.substring:(II)Ljava/lang/String;
            astore 3 /* kdfAlgo */
        15: .line 184
            aload 1 /* pbes2AlgorithmName */
            iload 2 /* and */
            iconst_3
            iadd
            invokevirtual java.lang.String.substring:(I)Ljava/lang/String;
            astore 4 /* cipherAlgo */
        16: .line 188
            aload 4 /* cipherAlgo */
            bipush 95
            invokevirtual java.lang.String.indexOf:(I)I
            dup
            istore 5 /* underscore */
        start local 5 // int underscore
        17: ifle 34
        18: .line 190
            aload 4 /* cipherAlgo */
            bipush 47
            iload 5 /* underscore */
            iconst_1
            iadd
            invokevirtual java.lang.String.indexOf:(II)I
            dup
            istore 6 /* slash */
        start local 6 // int slash
        19: ifle 26
        20: .line 191
            aload 0 /* this */
        21: .line 192
            aload 4 /* cipherAlgo */
            iload 5 /* underscore */
            iconst_1
            iadd
        22: .line 193
            iload 6 /* slash */
        23: .line 192
            invokevirtual java.lang.String.substring:(II)Ljava/lang/String;
            invokestatic java.lang.Integer.parseInt:(Ljava/lang/String;)I
        24: .line 191
            putfield com.sun.crypto.provider.PBES2Parameters.keysize:I
        25: .line 194
            goto 29
        26: .line 195
      StackMap locals: com.sun.crypto.provider.PBES2Parameters java.lang.String int java.lang.String java.lang.String int int
      StackMap stack:
            aload 0 /* this */
        27: .line 196
            aload 4 /* cipherAlgo */
            iload 5 /* underscore */
            iconst_1
            iadd
            invokevirtual java.lang.String.substring:(I)Ljava/lang/String;
            invokestatic java.lang.Integer.parseInt:(Ljava/lang/String;)I
        28: .line 195
            putfield com.sun.crypto.provider.PBES2Parameters.keysize:I
        29: .line 198
      StackMap locals:
      StackMap stack:
            aload 4 /* cipherAlgo */
            iconst_0
            iload 5 /* underscore */
            invokevirtual java.lang.String.substring:(II)Ljava/lang/String;
            astore 4 /* cipherAlgo */
        end local 6 // int slash
        end local 5 // int underscore
        30: .line 200
            goto 34
        end local 2 // int and
        31: .line 201
      StackMap locals: com.sun.crypto.provider.PBES2Parameters java.lang.String top java.lang.String java.lang.String
      StackMap stack:
            new java.security.NoSuchAlgorithmException
            dup
            new java.lang.StringBuilder
            dup
            ldc "No crypto implementation for "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        32: .line 202
            aload 1 /* pbes2AlgorithmName */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        33: .line 201
            invokespecial java.security.NoSuchAlgorithmException.<init>:(Ljava/lang/String;)V
            athrow
        start local 2 // int and
        34: .line 205
      StackMap locals: com.sun.crypto.provider.PBES2Parameters java.lang.String int java.lang.String java.lang.String
      StackMap stack:
            aload 3 /* kdfAlgo */
            dup
            astore 5
            invokevirtual java.lang.String.hashCode:()I
            lookupswitch { // 5
            954016943: 35
            954017038: 36
            954018090: 37
            954019793: 38
           1752946092: 39
              default: 50
          }
      StackMap locals: java.lang.String
      StackMap stack:
        35: aload 5
            ldc "HmacSHA224"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 42
            goto 50
      StackMap locals:
      StackMap stack:
        36: aload 5
            ldc "HmacSHA256"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 44
            goto 50
      StackMap locals:
      StackMap stack:
        37: aload 5
            ldc "HmacSHA384"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 46
            goto 50
      StackMap locals:
      StackMap stack:
        38: aload 5
            ldc "HmacSHA512"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 48
            goto 50
      StackMap locals:
      StackMap stack:
        39: aload 5
            ldc "HmacSHA1"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 40
            goto 50
        40: .line 207
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getstatic com.sun.crypto.provider.PBES2Parameters.hmacWithSHA1_OID:Lsun/security/util/ObjectIdentifier;
            putfield com.sun.crypto.provider.PBES2Parameters.kdfAlgo_OID:Lsun/security/util/ObjectIdentifier;
        41: .line 208
            goto 53
        42: .line 210
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getstatic com.sun.crypto.provider.PBES2Parameters.hmacWithSHA224_OID:Lsun/security/util/ObjectIdentifier;
            putfield com.sun.crypto.provider.PBES2Parameters.kdfAlgo_OID:Lsun/security/util/ObjectIdentifier;
        43: .line 211
            goto 53
        44: .line 213
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getstatic com.sun.crypto.provider.PBES2Parameters.hmacWithSHA256_OID:Lsun/security/util/ObjectIdentifier;
            putfield com.sun.crypto.provider.PBES2Parameters.kdfAlgo_OID:Lsun/security/util/ObjectIdentifier;
        45: .line 214
            goto 53
        46: .line 216
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getstatic com.sun.crypto.provider.PBES2Parameters.hmacWithSHA384_OID:Lsun/security/util/ObjectIdentifier;
            putfield com.sun.crypto.provider.PBES2Parameters.kdfAlgo_OID:Lsun/security/util/ObjectIdentifier;
        47: .line 217
            goto 53
        48: .line 219
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getstatic com.sun.crypto.provider.PBES2Parameters.hmacWithSHA512_OID:Lsun/security/util/ObjectIdentifier;
            putfield com.sun.crypto.provider.PBES2Parameters.kdfAlgo_OID:Lsun/security/util/ObjectIdentifier;
        49: .line 220
            goto 53
        50: .line 222
      StackMap locals:
      StackMap stack:
            new java.security.NoSuchAlgorithmException
            dup
        51: .line 223
            new java.lang.StringBuilder
            dup
            ldc "No crypto implementation for "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 3 /* kdfAlgo */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        52: .line 222
            invokespecial java.security.NoSuchAlgorithmException.<init>:(Ljava/lang/String;)V
            athrow
        53: .line 226
      StackMap locals:
      StackMap stack:
            aload 4 /* cipherAlgo */
            ldc "AES"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 66
        54: .line 227
            aload 0 /* this */
            aload 0 /* this */
            getfield com.sun.crypto.provider.PBES2Parameters.keysize:I
            putfield com.sun.crypto.provider.PBES2Parameters.keysize:I
        55: .line 228
            aload 0 /* this */
            getfield com.sun.crypto.provider.PBES2Parameters.keysize:I
            lookupswitch { // 2
                  128: 56
                  256: 58
              default: 60
          }
        56: .line 230
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getstatic com.sun.crypto.provider.PBES2Parameters.aes128CBC_OID:Lsun/security/util/ObjectIdentifier;
            putfield com.sun.crypto.provider.PBES2Parameters.cipherAlgo_OID:Lsun/security/util/ObjectIdentifier;
        57: .line 231
            goto 69
        58: .line 233
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getstatic com.sun.crypto.provider.PBES2Parameters.aes256CBC_OID:Lsun/security/util/ObjectIdentifier;
            putfield com.sun.crypto.provider.PBES2Parameters.cipherAlgo_OID:Lsun/security/util/ObjectIdentifier;
        59: .line 234
            goto 69
        60: .line 236
      StackMap locals:
      StackMap stack:
            new java.security.NoSuchAlgorithmException
            dup
        61: .line 237
            new java.lang.StringBuilder
            dup
            ldc "No Cipher implementation for "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield com.sun.crypto.provider.PBES2Parameters.keysize:I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc "-bit "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        62: .line 238
            aload 4 /* cipherAlgo */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        63: .line 237
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        64: .line 236
            invokespecial java.security.NoSuchAlgorithmException.<init>:(Ljava/lang/String;)V
            athrow
        65: .line 240
      StackMap locals:
      StackMap stack:
            goto 69
        66: .line 241
      StackMap locals:
      StackMap stack:
            new java.security.NoSuchAlgorithmException
            dup
            new java.lang.StringBuilder
            dup
            ldc "No Cipher implementation for "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        67: .line 242
            aload 4 /* cipherAlgo */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        68: .line 241
            invokespecial java.security.NoSuchAlgorithmException.<init>:(Ljava/lang/String;)V
            athrow
        69: .line 244
      StackMap locals:
      StackMap stack:
            return
        end local 4 // java.lang.String cipherAlgo
        end local 3 // java.lang.String kdfAlgo
        end local 2 // int and
        end local 1 // java.lang.String pbes2AlgorithmName
        end local 0 // com.sun.crypto.provider.PBES2Parameters this
      LocalVariableTable:
        Start  End  Slot                Name  Signature
            0   70     0                this  Lcom/sun/crypto/provider/PBES2Parameters;
            0   70     1  pbes2AlgorithmName  Ljava/lang/String;
           13   31     2                 and  I
           34   70     2                 and  I
            9   70     3             kdfAlgo  Ljava/lang/String;
           10   70     4          cipherAlgo  Ljava/lang/String;
           17   30     5          underscore  I
           19   30     6               slash  I
    Exceptions:
      throws java.security.NoSuchAlgorithmException
    MethodParameters:
                    Name  Flags
      pbes2AlgorithmName  

  protected void engineInit(java.security.spec.AlgorithmParameterSpec);
    descriptor: (Ljava/security/spec/AlgorithmParameterSpec;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // com.sun.crypto.provider.PBES2Parameters this
        start local 1 // java.security.spec.AlgorithmParameterSpec paramSpec
         0: .line 249
            aload 1 /* paramSpec */
            instanceof javax.crypto.spec.PBEParameterSpec
            ifne 4
         1: .line 250
            new java.security.spec.InvalidParameterSpecException
            dup
         2: .line 251
            ldc "Inappropriate parameter specification"
         3: .line 250
            invokespecial java.security.spec.InvalidParameterSpecException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 253
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* paramSpec */
            checkcast javax.crypto.spec.PBEParameterSpec
            invokevirtual javax.crypto.spec.PBEParameterSpec.getSalt:()[B
            invokevirtual byte[].clone:()Ljava/lang/Object;
            checkcast byte[]
            putfield com.sun.crypto.provider.PBES2Parameters.salt:[B
         5: .line 254
            aload 0 /* this */
            aload 1 /* paramSpec */
            checkcast javax.crypto.spec.PBEParameterSpec
            invokevirtual javax.crypto.spec.PBEParameterSpec.getIterationCount:()I
            putfield com.sun.crypto.provider.PBES2Parameters.iCount:I
         6: .line 255
            aload 1 /* paramSpec */
            instanceof com.sun.crypto.spec.PBE2ParameterSpec
            ifeq 8
         7: .line 256
            aload 0 /* this */
            aload 1 /* paramSpec */
            checkcast com.sun.crypto.spec.PBE2ParameterSpec
            invokevirtual com.sun.crypto.spec.PBE2ParameterSpec.getParameterSpec:()Ljava/security/spec/AlgorithmParameterSpec;
            putfield com.sun.crypto.provider.PBES2Parameters.cipherParam:Ljava/security/spec/AlgorithmParameterSpec;
         8: .line 258
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.security.spec.AlgorithmParameterSpec paramSpec
        end local 0 // com.sun.crypto.provider.PBES2Parameters this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    9     0       this  Lcom/sun/crypto/provider/PBES2Parameters;
            0    9     1  paramSpec  Ljava/security/spec/AlgorithmParameterSpec;
    Exceptions:
      throws java.security.spec.InvalidParameterSpecException
    MethodParameters:
           Name  Flags
      paramSpec  

  protected void engineInit(byte[]);
    descriptor: ([B)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=3, locals=6, args_size=2
        start local 0 // com.sun.crypto.provider.PBES2Parameters this
        start local 1 // byte[] encoded
         0: .line 263
            aconst_null
            astore 2 /* kdfAlgo */
        start local 2 // java.lang.String kdfAlgo
         1: .line 264
            aconst_null
            astore 3 /* cipherAlgo */
        start local 3 // java.lang.String cipherAlgo
         2: .line 266
            new sun.security.util.DerValue
            dup
            aload 1 /* encoded */
            invokespecial sun.security.util.DerValue.<init>:([B)V
            astore 4 /* pBES2Algorithms */
        start local 4 // sun.security.util.DerValue pBES2Algorithms
         3: .line 267
            aload 4 /* pBES2Algorithms */
            getfield sun.security.util.DerValue.tag:B
            bipush 48
            if_icmpeq 5
         4: .line 268
            new java.io.IOException
            dup
            ldc "PBE parameter parsing error: not an ASN.1 SEQUENCE tag"
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
         5: .line 271
      StackMap locals: java.lang.String java.lang.String sun.security.util.DerValue
      StackMap stack:
            getstatic com.sun.crypto.provider.PBES2Parameters.pkcs5PBES2_OID:Lsun/security/util/ObjectIdentifier;
            aload 4 /* pBES2Algorithms */
            getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
            invokevirtual sun.security.util.DerInputStream.getOID:()Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.equals:(Lsun/security/util/ObjectIdentifier;)Z
            ifne 7
         6: .line 272
            new java.io.IOException
            dup
            ldc "PBE parameter parsing error: expecting the object identifier for PBES2"
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
         7: .line 275
      StackMap locals:
      StackMap stack:
            aload 4 /* pBES2Algorithms */
            getfield sun.security.util.DerValue.tag:B
            bipush 48
            if_icmpeq 9
         8: .line 276
            new java.io.IOException
            dup
            ldc "PBE parameter parsing error: not an ASN.1 SEQUENCE tag"
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
         9: .line 280
      StackMap locals:
      StackMap stack:
            aload 4 /* pBES2Algorithms */
            getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
            invokevirtual sun.security.util.DerInputStream.getDerValue:()Lsun/security/util/DerValue;
            astore 5 /* pBES2_params */
        start local 5 // sun.security.util.DerValue pBES2_params
        10: .line 281
            aload 5 /* pBES2_params */
            getfield sun.security.util.DerValue.tag:B
            bipush 48
            if_icmpeq 12
        11: .line 282
            new java.io.IOException
            dup
            ldc "PBE parameter parsing error: not an ASN.1 SEQUENCE tag"
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        12: .line 285
      StackMap locals: sun.security.util.DerValue
      StackMap stack:
            aload 0 /* this */
            aload 5 /* pBES2_params */
            getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
            invokevirtual sun.security.util.DerInputStream.getDerValue:()Lsun/security/util/DerValue;
            invokevirtual com.sun.crypto.provider.PBES2Parameters.parseKDF:(Lsun/security/util/DerValue;)Ljava/lang/String;
            astore 2 /* kdfAlgo */
        13: .line 287
            aload 5 /* pBES2_params */
            getfield sun.security.util.DerValue.tag:B
            bipush 48
            if_icmpeq 15
        14: .line 288
            new java.io.IOException
            dup
            ldc "PBE parameter parsing error: not an ASN.1 SEQUENCE tag"
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        15: .line 291
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 5 /* pBES2_params */
            getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
            invokevirtual sun.security.util.DerInputStream.getDerValue:()Lsun/security/util/DerValue;
            invokevirtual com.sun.crypto.provider.PBES2Parameters.parseES:(Lsun/security/util/DerValue;)Ljava/lang/String;
            astore 3 /* cipherAlgo */
        16: .line 293
            aload 0 /* this */
            new java.lang.StringBuilder
            dup
            invokespecial java.lang.StringBuilder.<init>:()V
            ldc "PBEWith"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        17: .line 294
            aload 2 /* kdfAlgo */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "And"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 3 /* cipherAlgo */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        18: .line 293
            putfield com.sun.crypto.provider.PBES2Parameters.pbes2AlgorithmName:Ljava/lang/String;
        19: .line 295
            return
        end local 5 // sun.security.util.DerValue pBES2_params
        end local 4 // sun.security.util.DerValue pBES2Algorithms
        end local 3 // java.lang.String cipherAlgo
        end local 2 // java.lang.String kdfAlgo
        end local 1 // byte[] encoded
        end local 0 // com.sun.crypto.provider.PBES2Parameters this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0   20     0             this  Lcom/sun/crypto/provider/PBES2Parameters;
            0   20     1          encoded  [B
            1   20     2          kdfAlgo  Ljava/lang/String;
            2   20     3       cipherAlgo  Ljava/lang/String;
            3   20     4  pBES2Algorithms  Lsun/security/util/DerValue;
           10   20     5     pBES2_params  Lsun/security/util/DerValue;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
         Name  Flags
      encoded  

  private java.lang.String parseKDF(sun.security.util.DerValue);
    descriptor: (Lsun/security/util/DerValue;)Ljava/lang/String;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=8, args_size=2
        start local 0 // com.sun.crypto.provider.PBES2Parameters this
        start local 1 // sun.security.util.DerValue keyDerivationFunc
         0: .line 298
            aconst_null
            astore 2 /* kdfAlgo */
        start local 2 // java.lang.String kdfAlgo
         1: .line 300
            getstatic com.sun.crypto.provider.PBES2Parameters.pkcs5PBKDF2_OID:Lsun/security/util/ObjectIdentifier;
            aload 1 /* keyDerivationFunc */
            getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
            invokevirtual sun.security.util.DerInputStream.getOID:()Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.equals:(Lsun/security/util/ObjectIdentifier;)Z
            ifne 3
         2: .line 301
            new java.io.IOException
            dup
            ldc "PBE parameter parsing error: expecting the object identifier for PBKDF2"
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
         3: .line 304
      StackMap locals: java.lang.String
      StackMap stack:
            aload 1 /* keyDerivationFunc */
            getfield sun.security.util.DerValue.tag:B
            bipush 48
            if_icmpeq 5
         4: .line 305
            new java.io.IOException
            dup
            ldc "PBE parameter parsing error: not an ASN.1 SEQUENCE tag"
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
         5: .line 308
      StackMap locals:
      StackMap stack:
            aload 1 /* keyDerivationFunc */
            getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
            invokevirtual sun.security.util.DerInputStream.getDerValue:()Lsun/security/util/DerValue;
            astore 3 /* pBKDF2_params */
        start local 3 // sun.security.util.DerValue pBKDF2_params
         6: .line 309
            aload 3 /* pBKDF2_params */
            getfield sun.security.util.DerValue.tag:B
            bipush 48
            if_icmpeq 8
         7: .line 310
            new java.io.IOException
            dup
            ldc "PBE parameter parsing error: not an ASN.1 SEQUENCE tag"
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
         8: .line 313
      StackMap locals: sun.security.util.DerValue
      StackMap stack:
            aload 3 /* pBKDF2_params */
            getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
            invokevirtual sun.security.util.DerInputStream.getDerValue:()Lsun/security/util/DerValue;
            astore 4 /* specified */
        start local 4 // sun.security.util.DerValue specified
         9: .line 315
            aload 4 /* specified */
            getfield sun.security.util.DerValue.tag:B
            iconst_4
            if_icmpne 12
        10: .line 316
            aload 0 /* this */
            aload 4 /* specified */
            invokevirtual sun.security.util.DerValue.getOctetString:()[B
            putfield com.sun.crypto.provider.PBES2Parameters.salt:[B
        11: .line 317
            goto 13
        12: .line 319
      StackMap locals: sun.security.util.DerValue
      StackMap stack:
            new java.io.IOException
            dup
            ldc "PBE parameter parsing error: not an ASN.1 OCTET STRING tag"
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        13: .line 322
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 3 /* pBKDF2_params */
            getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
            invokevirtual sun.security.util.DerInputStream.getInteger:()I
            putfield com.sun.crypto.provider.PBES2Parameters.iCount:I
        14: .line 323
            aload 3 /* pBKDF2_params */
            getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
            invokevirtual sun.security.util.DerInputStream.getDerValue:()Lsun/security/util/DerValue;
            astore 5 /* keyLength */
        start local 5 // sun.security.util.DerValue keyLength
        15: .line 324
            aload 5 /* keyLength */
            getfield sun.security.util.DerValue.tag:B
            iconst_2
            if_icmpne 17
        16: .line 325
            aload 0 /* this */
            aload 5 /* keyLength */
            invokevirtual sun.security.util.DerValue.getInteger:()I
            bipush 8
            imul
            putfield com.sun.crypto.provider.PBES2Parameters.keysize:I
        17: .line 327
      StackMap locals: sun.security.util.DerValue
      StackMap stack:
            aload 3 /* pBKDF2_params */
            getfield sun.security.util.DerValue.tag:B
            bipush 48
            if_icmpne 40
        18: .line 328
            aload 3 /* pBKDF2_params */
            getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
            invokevirtual sun.security.util.DerInputStream.getDerValue:()Lsun/security/util/DerValue;
            astore 6 /* prf */
        start local 6 // sun.security.util.DerValue prf
        19: .line 329
            aload 0 /* this */
            aload 6 /* prf */
            getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
            invokevirtual sun.security.util.DerInputStream.getOID:()Lsun/security/util/ObjectIdentifier;
            putfield com.sun.crypto.provider.PBES2Parameters.kdfAlgo_OID:Lsun/security/util/ObjectIdentifier;
        20: .line 330
            getstatic com.sun.crypto.provider.PBES2Parameters.hmacWithSHA1_OID:Lsun/security/util/ObjectIdentifier;
            aload 0 /* this */
            getfield com.sun.crypto.provider.PBES2Parameters.kdfAlgo_OID:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.equals:(Lsun/security/util/ObjectIdentifier;)Z
            ifeq 23
        21: .line 331
            ldc "HmacSHA1"
            astore 2 /* kdfAlgo */
        22: .line 332
            goto 36
      StackMap locals: sun.security.util.DerValue
      StackMap stack:
        23: getstatic com.sun.crypto.provider.PBES2Parameters.hmacWithSHA224_OID:Lsun/security/util/ObjectIdentifier;
            aload 0 /* this */
            getfield com.sun.crypto.provider.PBES2Parameters.kdfAlgo_OID:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.equals:(Lsun/security/util/ObjectIdentifier;)Z
            ifeq 26
        24: .line 333
            ldc "HmacSHA224"
            astore 2 /* kdfAlgo */
        25: .line 334
            goto 36
      StackMap locals:
      StackMap stack:
        26: getstatic com.sun.crypto.provider.PBES2Parameters.hmacWithSHA256_OID:Lsun/security/util/ObjectIdentifier;
            aload 0 /* this */
            getfield com.sun.crypto.provider.PBES2Parameters.kdfAlgo_OID:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.equals:(Lsun/security/util/ObjectIdentifier;)Z
            ifeq 29
        27: .line 335
            ldc "HmacSHA256"
            astore 2 /* kdfAlgo */
        28: .line 336
            goto 36
      StackMap locals:
      StackMap stack:
        29: getstatic com.sun.crypto.provider.PBES2Parameters.hmacWithSHA384_OID:Lsun/security/util/ObjectIdentifier;
            aload 0 /* this */
            getfield com.sun.crypto.provider.PBES2Parameters.kdfAlgo_OID:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.equals:(Lsun/security/util/ObjectIdentifier;)Z
            ifeq 32
        30: .line 337
            ldc "HmacSHA384"
            astore 2 /* kdfAlgo */
        31: .line 338
            goto 36
      StackMap locals:
      StackMap stack:
        32: getstatic com.sun.crypto.provider.PBES2Parameters.hmacWithSHA512_OID:Lsun/security/util/ObjectIdentifier;
            aload 0 /* this */
            getfield com.sun.crypto.provider.PBES2Parameters.kdfAlgo_OID:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.equals:(Lsun/security/util/ObjectIdentifier;)Z
            ifeq 35
        33: .line 339
            ldc "HmacSHA512"
            astore 2 /* kdfAlgo */
        34: .line 340
            goto 36
        35: .line 341
      StackMap locals:
      StackMap stack:
            new java.io.IOException
            dup
            ldc "PBE parameter parsing error: expecting the object identifier for a HmacSHA key derivation function"
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        36: .line 345
      StackMap locals:
      StackMap stack:
            aload 6 /* prf */
            getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
            invokevirtual sun.security.util.DerInputStream.available:()I
            ifeq 40
        37: .line 347
            aload 6 /* prf */
            getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
            invokevirtual sun.security.util.DerInputStream.getDerValue:()Lsun/security/util/DerValue;
            astore 7 /* parameter */
        start local 7 // sun.security.util.DerValue parameter
        38: .line 348
            aload 7 /* parameter */
            getfield sun.security.util.DerValue.tag:B
            iconst_5
            if_icmpeq 40
        39: .line 349
            new java.io.IOException
            dup
            ldc "PBE parameter parsing error: not an ASN.1 NULL tag"
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        end local 7 // sun.security.util.DerValue parameter
        end local 6 // sun.security.util.DerValue prf
        40: .line 355
      StackMap locals:
      StackMap stack:
            aload 2 /* kdfAlgo */
            areturn
        end local 5 // sun.security.util.DerValue keyLength
        end local 4 // sun.security.util.DerValue specified
        end local 3 // sun.security.util.DerValue pBKDF2_params
        end local 2 // java.lang.String kdfAlgo
        end local 1 // sun.security.util.DerValue keyDerivationFunc
        end local 0 // com.sun.crypto.provider.PBES2Parameters this
      LocalVariableTable:
        Start  End  Slot               Name  Signature
            0   41     0               this  Lcom/sun/crypto/provider/PBES2Parameters;
            0   41     1  keyDerivationFunc  Lsun/security/util/DerValue;
            1   41     2            kdfAlgo  Ljava/lang/String;
            6   41     3      pBKDF2_params  Lsun/security/util/DerValue;
            9   41     4          specified  Lsun/security/util/DerValue;
           15   41     5          keyLength  Lsun/security/util/DerValue;
           19   40     6                prf  Lsun/security/util/DerValue;
           38   40     7          parameter  Lsun/security/util/DerValue;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
                   Name  Flags
      keyDerivationFunc  

  private java.lang.String parseES(sun.security.util.DerValue);
    descriptor: (Lsun/security/util/DerValue;)Ljava/lang/String;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=3, args_size=2
        start local 0 // com.sun.crypto.provider.PBES2Parameters this
        start local 1 // sun.security.util.DerValue encryptionScheme
         0: .line 359
            aconst_null
            astore 2 /* cipherAlgo */
        start local 2 // java.lang.String cipherAlgo
         1: .line 361
            aload 0 /* this */
            aload 1 /* encryptionScheme */
            getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
            invokevirtual sun.security.util.DerInputStream.getOID:()Lsun/security/util/ObjectIdentifier;
            putfield com.sun.crypto.provider.PBES2Parameters.cipherAlgo_OID:Lsun/security/util/ObjectIdentifier;
         2: .line 362
            getstatic com.sun.crypto.provider.PBES2Parameters.aes128CBC_OID:Lsun/security/util/ObjectIdentifier;
            aload 0 /* this */
            getfield com.sun.crypto.provider.PBES2Parameters.cipherAlgo_OID:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.equals:(Lsun/security/util/ObjectIdentifier;)Z
            ifeq 9
         3: .line 363
            ldc "AES_128"
            astore 2 /* cipherAlgo */
         4: .line 365
            aload 0 /* this */
         5: .line 366
            new javax.crypto.spec.IvParameterSpec
            dup
            aload 1 /* encryptionScheme */
            getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
            invokevirtual sun.security.util.DerInputStream.getOctetString:()[B
            invokespecial javax.crypto.spec.IvParameterSpec.<init>:([B)V
         6: .line 365
            putfield com.sun.crypto.provider.PBES2Parameters.cipherParam:Ljava/security/spec/AlgorithmParameterSpec;
         7: .line 367
            aload 0 /* this */
            sipush 128
            putfield com.sun.crypto.provider.PBES2Parameters.keysize:I
         8: .line 368
            goto 17
      StackMap locals: java.lang.String
      StackMap stack:
         9: getstatic com.sun.crypto.provider.PBES2Parameters.aes256CBC_OID:Lsun/security/util/ObjectIdentifier;
            aload 0 /* this */
            getfield com.sun.crypto.provider.PBES2Parameters.cipherAlgo_OID:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.equals:(Lsun/security/util/ObjectIdentifier;)Z
            ifeq 16
        10: .line 369
            ldc "AES_256"
            astore 2 /* cipherAlgo */
        11: .line 371
            aload 0 /* this */
        12: .line 372
            new javax.crypto.spec.IvParameterSpec
            dup
            aload 1 /* encryptionScheme */
            getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
            invokevirtual sun.security.util.DerInputStream.getOctetString:()[B
            invokespecial javax.crypto.spec.IvParameterSpec.<init>:([B)V
        13: .line 371
            putfield com.sun.crypto.provider.PBES2Parameters.cipherParam:Ljava/security/spec/AlgorithmParameterSpec;
        14: .line 373
            aload 0 /* this */
            sipush 256
            putfield com.sun.crypto.provider.PBES2Parameters.keysize:I
        15: .line 374
            goto 17
        16: .line 375
      StackMap locals:
      StackMap stack:
            new java.io.IOException
            dup
            ldc "PBE parameter parsing error: expecting the object identifier for AES cipher"
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        17: .line 379
      StackMap locals:
      StackMap stack:
            aload 2 /* cipherAlgo */
            areturn
        end local 2 // java.lang.String cipherAlgo
        end local 1 // sun.security.util.DerValue encryptionScheme
        end local 0 // com.sun.crypto.provider.PBES2Parameters this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0   18     0              this  Lcom/sun/crypto/provider/PBES2Parameters;
            0   18     1  encryptionScheme  Lsun/security/util/DerValue;
            1   18     2        cipherAlgo  Ljava/lang/String;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
                  Name  Flags
      encryptionScheme  

  protected void engineInit(byte[], java.lang.String);
    descriptor: ([BLjava/lang/String;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=2, locals=3, args_size=3
        start local 0 // com.sun.crypto.provider.PBES2Parameters this
        start local 1 // byte[] encoded
        start local 2 // java.lang.String decodingMethod
         0: .line 385
            aload 0 /* this */
            aload 1 /* encoded */
            invokevirtual com.sun.crypto.provider.PBES2Parameters.engineInit:([B)V
         1: .line 386
            return
        end local 2 // java.lang.String decodingMethod
        end local 1 // byte[] encoded
        end local 0 // com.sun.crypto.provider.PBES2Parameters this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0    2     0            this  Lcom/sun/crypto/provider/PBES2Parameters;
            0    2     1         encoded  [B
            0    2     2  decodingMethod  Ljava/lang/String;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
                Name  Flags
      encoded         
      decodingMethod  

  protected <T extends java.security.spec.AlgorithmParameterSpec> T engineGetParameterSpec(java.lang.Class<T>);
    descriptor: (Ljava/lang/Class;)Ljava/security/spec/AlgorithmParameterSpec;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=6, locals=2, args_size=2
        start local 0 // com.sun.crypto.provider.PBES2Parameters this
        start local 1 // java.lang.Class paramSpec
         0: .line 392
            ldc Ljavax/crypto/spec/PBEParameterSpec;
            aload 1 /* paramSpec */
            invokevirtual java.lang.Class.isAssignableFrom:(Ljava/lang/Class;)Z
            ifeq 4
         1: .line 393
            aload 1 /* paramSpec */
         2: .line 394
            new com.sun.crypto.spec.PBE2ParameterSpec
            dup
            aload 0 /* this */
            getfield com.sun.crypto.provider.PBES2Parameters.salt:[B
            aload 0 /* this */
            getfield com.sun.crypto.provider.PBES2Parameters.iCount:I
            aload 0 /* this */
            getfield com.sun.crypto.provider.PBES2Parameters.cipherParam:Ljava/security/spec/AlgorithmParameterSpec;
            invokespecial com.sun.crypto.spec.PBE2ParameterSpec.<init>:([BILjava/security/spec/AlgorithmParameterSpec;)V
         3: .line 393
            invokevirtual java.lang.Class.cast:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.security.spec.AlgorithmParameterSpec
            areturn
         4: .line 396
      StackMap locals:
      StackMap stack:
            new java.security.spec.InvalidParameterSpecException
            dup
         5: .line 397
            ldc "Inappropriate parameter specification"
         6: .line 396
            invokespecial java.security.spec.InvalidParameterSpecException.<init>:(Ljava/lang/String;)V
            athrow
        end local 1 // java.lang.Class paramSpec
        end local 0 // com.sun.crypto.provider.PBES2Parameters this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    7     0       this  Lcom/sun/crypto/provider/PBES2Parameters;
            0    7     1  paramSpec  Ljava/lang/Class<TT;>;
    Exceptions:
      throws java.security.spec.InvalidParameterSpecException
    Signature: <T::Ljava/security/spec/AlgorithmParameterSpec;>(Ljava/lang/Class<TT;>;)TT;
    MethodParameters:
           Name  Flags
      paramSpec  

  protected byte[] engineGetEncoded();
    descriptor: ()[B
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=3, locals=8, args_size=1
        start local 0 // com.sun.crypto.provider.PBES2Parameters this
         0: .line 402
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 1 /* out */
        start local 1 // sun.security.util.DerOutputStream out
         1: .line 403
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 2 /* pBES2Algorithms */
        start local 2 // sun.security.util.DerOutputStream pBES2Algorithms
         2: .line 404
            aload 2 /* pBES2Algorithms */
            getstatic com.sun.crypto.provider.PBES2Parameters.pkcs5PBES2_OID:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.DerOutputStream.putOID:(Lsun/security/util/ObjectIdentifier;)V
         3: .line 406
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 3 /* pBES2_params */
        start local 3 // sun.security.util.DerOutputStream pBES2_params
         4: .line 408
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 4 /* keyDerivationFunc */
        start local 4 // sun.security.util.DerOutputStream keyDerivationFunc
         5: .line 409
            aload 4 /* keyDerivationFunc */
            getstatic com.sun.crypto.provider.PBES2Parameters.pkcs5PBKDF2_OID:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.DerOutputStream.putOID:(Lsun/security/util/ObjectIdentifier;)V
         6: .line 411
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 5 /* pBKDF2_params */
        start local 5 // sun.security.util.DerOutputStream pBKDF2_params
         7: .line 412
            aload 5 /* pBKDF2_params */
            aload 0 /* this */
            getfield com.sun.crypto.provider.PBES2Parameters.salt:[B
            invokevirtual sun.security.util.DerOutputStream.putOctetString:([B)V
         8: .line 413
            aload 5 /* pBKDF2_params */
            aload 0 /* this */
            getfield com.sun.crypto.provider.PBES2Parameters.iCount:I
            invokevirtual sun.security.util.DerOutputStream.putInteger:(I)V
         9: .line 414
            aload 5 /* pBKDF2_params */
            aload 0 /* this */
            getfield com.sun.crypto.provider.PBES2Parameters.keysize:I
            bipush 8
            idiv
            invokevirtual sun.security.util.DerOutputStream.putInteger:(I)V
        10: .line 416
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 6 /* prf */
        start local 6 // sun.security.util.DerOutputStream prf
        11: .line 418
            aload 6 /* prf */
            aload 0 /* this */
            getfield com.sun.crypto.provider.PBES2Parameters.kdfAlgo_OID:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.DerOutputStream.putOID:(Lsun/security/util/ObjectIdentifier;)V
        12: .line 420
            aload 6 /* prf */
            invokevirtual sun.security.util.DerOutputStream.putNull:()V
        13: .line 421
            aload 5 /* pBKDF2_params */
            bipush 48
            aload 6 /* prf */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        14: .line 423
            aload 4 /* keyDerivationFunc */
            bipush 48
            aload 5 /* pBKDF2_params */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        15: .line 424
            aload 3 /* pBES2_params */
            bipush 48
            aload 4 /* keyDerivationFunc */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        16: .line 426
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 7 /* encryptionScheme */
        start local 7 // sun.security.util.DerOutputStream encryptionScheme
        17: .line 428
            aload 7 /* encryptionScheme */
            aload 0 /* this */
            getfield com.sun.crypto.provider.PBES2Parameters.cipherAlgo_OID:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.DerOutputStream.putOID:(Lsun/security/util/ObjectIdentifier;)V
        18: .line 430
            aload 0 /* this */
            getfield com.sun.crypto.provider.PBES2Parameters.cipherParam:Ljava/security/spec/AlgorithmParameterSpec;
            ifnull 23
            aload 0 /* this */
            getfield com.sun.crypto.provider.PBES2Parameters.cipherParam:Ljava/security/spec/AlgorithmParameterSpec;
            instanceof javax.crypto.spec.IvParameterSpec
            ifeq 23
        19: .line 431
            aload 7 /* encryptionScheme */
        20: .line 432
            aload 0 /* this */
            getfield com.sun.crypto.provider.PBES2Parameters.cipherParam:Ljava/security/spec/AlgorithmParameterSpec;
            checkcast javax.crypto.spec.IvParameterSpec
            invokevirtual javax.crypto.spec.IvParameterSpec.getIV:()[B
        21: .line 431
            invokevirtual sun.security.util.DerOutputStream.putOctetString:([B)V
        22: .line 433
            goto 24
        23: .line 434
      StackMap locals: com.sun.crypto.provider.PBES2Parameters sun.security.util.DerOutputStream sun.security.util.DerOutputStream sun.security.util.DerOutputStream sun.security.util.DerOutputStream sun.security.util.DerOutputStream sun.security.util.DerOutputStream sun.security.util.DerOutputStream
      StackMap stack:
            new java.io.IOException
            dup
            ldc "Wrong parameter type: IV expected"
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        24: .line 436
      StackMap locals:
      StackMap stack:
            aload 3 /* pBES2_params */
            bipush 48
            aload 7 /* encryptionScheme */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        25: .line 438
            aload 2 /* pBES2Algorithms */
            bipush 48
            aload 3 /* pBES2_params */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        26: .line 439
            aload 1 /* out */
            bipush 48
            aload 2 /* pBES2Algorithms */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        27: .line 441
            aload 1 /* out */
            invokevirtual sun.security.util.DerOutputStream.toByteArray:()[B
            areturn
        end local 7 // sun.security.util.DerOutputStream encryptionScheme
        end local 6 // sun.security.util.DerOutputStream prf
        end local 5 // sun.security.util.DerOutputStream pBKDF2_params
        end local 4 // sun.security.util.DerOutputStream keyDerivationFunc
        end local 3 // sun.security.util.DerOutputStream pBES2_params
        end local 2 // sun.security.util.DerOutputStream pBES2Algorithms
        end local 1 // sun.security.util.DerOutputStream out
        end local 0 // com.sun.crypto.provider.PBES2Parameters this
      LocalVariableTable:
        Start  End  Slot               Name  Signature
            0   28     0               this  Lcom/sun/crypto/provider/PBES2Parameters;
            1   28     1                out  Lsun/security/util/DerOutputStream;
            2   28     2    pBES2Algorithms  Lsun/security/util/DerOutputStream;
            4   28     3       pBES2_params  Lsun/security/util/DerOutputStream;
            5   28     4  keyDerivationFunc  Lsun/security/util/DerOutputStream;
            7   28     5      pBKDF2_params  Lsun/security/util/DerOutputStream;
           11   28     6                prf  Lsun/security/util/DerOutputStream;
           17   28     7   encryptionScheme  Lsun/security/util/DerOutputStream;
    Exceptions:
      throws java.io.IOException

  protected byte[] engineGetEncoded(java.lang.String);
    descriptor: (Ljava/lang/String;)[B
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=1, locals=2, args_size=2
        start local 0 // com.sun.crypto.provider.PBES2Parameters this
        start local 1 // java.lang.String encodingMethod
         0: .line 447
            aload 0 /* this */
            invokevirtual com.sun.crypto.provider.PBES2Parameters.engineGetEncoded:()[B
            areturn
        end local 1 // java.lang.String encodingMethod
        end local 0 // com.sun.crypto.provider.PBES2Parameters this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0    1     0            this  Lcom/sun/crypto/provider/PBES2Parameters;
            0    1     1  encodingMethod  Ljava/lang/String;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
                Name  Flags
      encodingMethod  

  protected java.lang.String engineToString();
    descriptor: ()Ljava/lang/String;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // com.sun.crypto.provider.PBES2Parameters this
         0: .line 458
            aload 0 /* this */
            getfield com.sun.crypto.provider.PBES2Parameters.pbes2AlgorithmName:Ljava/lang/String;
            areturn
        end local 0 // com.sun.crypto.provider.PBES2Parameters this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/sun/crypto/provider/PBES2Parameters;
}
SourceFile: "PBES2Parameters.java"
NestMembers:
  com.sun.crypto.provider.PBES2Parameters$General  com.sun.crypto.provider.PBES2Parameters$HmacSHA1AndAES_128  com.sun.crypto.provider.PBES2Parameters$HmacSHA1AndAES_256  com.sun.crypto.provider.PBES2Parameters$HmacSHA224AndAES_128  com.sun.crypto.provider.PBES2Parameters$HmacSHA224AndAES_256  com.sun.crypto.provider.PBES2Parameters$HmacSHA256AndAES_128  com.sun.crypto.provider.PBES2Parameters$HmacSHA256AndAES_256  com.sun.crypto.provider.PBES2Parameters$HmacSHA384AndAES_128  com.sun.crypto.provider.PBES2Parameters$HmacSHA384AndAES_256  com.sun.crypto.provider.PBES2Parameters$HmacSHA512AndAES_128  com.sun.crypto.provider.PBES2Parameters$HmacSHA512AndAES_256
InnerClasses:
  public final General = com.sun.crypto.provider.PBES2Parameters$General of com.sun.crypto.provider.PBES2Parameters
  public final HmacSHA1AndAES_128 = com.sun.crypto.provider.PBES2Parameters$HmacSHA1AndAES_128 of com.sun.crypto.provider.PBES2Parameters
  public final HmacSHA1AndAES_256 = com.sun.crypto.provider.PBES2Parameters$HmacSHA1AndAES_256 of com.sun.crypto.provider.PBES2Parameters
  public final HmacSHA224AndAES_128 = com.sun.crypto.provider.PBES2Parameters$HmacSHA224AndAES_128 of com.sun.crypto.provider.PBES2Parameters
  public final HmacSHA224AndAES_256 = com.sun.crypto.provider.PBES2Parameters$HmacSHA224AndAES_256 of com.sun.crypto.provider.PBES2Parameters
  public final HmacSHA256AndAES_128 = com.sun.crypto.provider.PBES2Parameters$HmacSHA256AndAES_128 of com.sun.crypto.provider.PBES2Parameters
  public final HmacSHA256AndAES_256 = com.sun.crypto.provider.PBES2Parameters$HmacSHA256AndAES_256 of com.sun.crypto.provider.PBES2Parameters
  public final HmacSHA384AndAES_128 = com.sun.crypto.provider.PBES2Parameters$HmacSHA384AndAES_128 of com.sun.crypto.provider.PBES2Parameters
  public final HmacSHA384AndAES_256 = com.sun.crypto.provider.PBES2Parameters$HmacSHA384AndAES_256 of com.sun.crypto.provider.PBES2Parameters
  public final HmacSHA512AndAES_128 = com.sun.crypto.provider.PBES2Parameters$HmacSHA512AndAES_128 of com.sun.crypto.provider.PBES2Parameters
  public final HmacSHA512AndAES_256 = com.sun.crypto.provider.PBES2Parameters$HmacSHA512AndAES_256 of com.sun.crypto.provider.PBES2Parameters