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 97
            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 96
            putstatic com.sun.crypto.provider.PBES2Parameters.pkcs5PBKDF2:[I
         2: .line 99
            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 98
            putstatic com.sun.crypto.provider.PBES2Parameters.pkcs5PBES2:[I
         4: .line 101
            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 100
            putstatic com.sun.crypto.provider.PBES2Parameters.hmacWithSHA1:[I
         6: .line 103
            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 102
            putstatic com.sun.crypto.provider.PBES2Parameters.hmacWithSHA224:[I
         8: .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 9
            iastore
         9: .line 104
            putstatic com.sun.crypto.provider.PBES2Parameters.hmacWithSHA256:[I
        10: .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 10
            iastore
        11: .line 106
            putstatic com.sun.crypto.provider.PBES2Parameters.hmacWithSHA384:[I
        12: .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 11
            iastore
        13: .line 108
            putstatic com.sun.crypto.provider.PBES2Parameters.hmacWithSHA512:[I
        14: .line 111
            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 110
            putstatic com.sun.crypto.provider.PBES2Parameters.aes128CBC:[I
        16: .line 113
            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 112
            putstatic com.sun.crypto.provider.PBES2Parameters.aes192CBC:[I
        18: .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
            bipush 42
            iastore
        19: .line 114
            putstatic com.sun.crypto.provider.PBES2Parameters.aes256CBC:[I
        20: .line 130
            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 131
            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 132
            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 133
            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 134
            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 135
            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 136
            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 137
            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 138
            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 139
            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 140
            goto 32
      StackMap locals:
      StackMap stack: java.io.IOException
        31: pop
        32: .line 143
      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 166
            aload 0 /* this */
            invokespecial java.security.AlgorithmParametersSpi.<init>:()V
         1: .line 146
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.PBES2Parameters.pbes2AlgorithmName:Ljava/lang/String;
         2: .line 149
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.PBES2Parameters.salt:[B
         3: .line 152
            aload 0 /* this */
            iconst_0
            putfield com.sun.crypto.provider.PBES2Parameters.iCount:I
         4: .line 155
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.PBES2Parameters.cipherParam:Ljava/security/spec/AlgorithmParameterSpec;
         5: .line 158
            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 161
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.PBES2Parameters.cipherAlgo_OID:Lsun/security/util/ObjectIdentifier;
         7: .line 164
            aload 0 /* this */
            iconst_m1
            putfield com.sun.crypto.provider.PBES2Parameters.keysize:I
         8: .line 168
            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 170
            aload 0 /* this */
            invokespecial java.security.AlgorithmParametersSpi.<init>:()V
         1: .line 146
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.PBES2Parameters.pbes2AlgorithmName:Ljava/lang/String;
         2: .line 149
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.PBES2Parameters.salt:[B
         3: .line 152
            aload 0 /* this */
            iconst_0
            putfield com.sun.crypto.provider.PBES2Parameters.iCount:I
         4: .line 155
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.PBES2Parameters.cipherParam:Ljava/security/spec/AlgorithmParameterSpec;
         5: .line 158
            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 161
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.PBES2Parameters.cipherAlgo_OID:Lsun/security/util/ObjectIdentifier;
         7: .line 164
            aload 0 /* this */
            iconst_m1
            putfield com.sun.crypto.provider.PBES2Parameters.keysize:I
         8: .line 172
            aconst_null
            astore 3 /* kdfAlgo */
        start local 3 // java.lang.String kdfAlgo
         9: .line 173
            aconst_null
            astore 4 /* cipherAlgo */
        start local 4 // java.lang.String cipherAlgo
        10: .line 176
            aload 0 /* this */
            aload 1 /* pbes2AlgorithmName */
            putfield com.sun.crypto.provider.PBES2Parameters.pbes2AlgorithmName:Ljava/lang/String;
        11: .line 177
            aload 1 /* pbes2AlgorithmName */
            ldc "PBEWith"
            invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
            ifeq 31
        12: .line 178
            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 179
            aload 1 /* pbes2AlgorithmName */
            bipush 7
            iload 2 /* and */
            invokevirtual java.lang.String.substring:(II)Ljava/lang/String;
            astore 3 /* kdfAlgo */
        15: .line 180
            aload 1 /* pbes2AlgorithmName */
            iload 2 /* and */
            iconst_3
            iadd
            invokevirtual java.lang.String.substring:(I)Ljava/lang/String;
            astore 4 /* cipherAlgo */
        16: .line 184
            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 186
            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 187
            aload 0 /* this */
        21: .line 188
            aload 4 /* cipherAlgo */
            iload 5 /* underscore */
            iconst_1
            iadd
        22: .line 189
            iload 6 /* slash */
        23: .line 188
            invokevirtual java.lang.String.substring:(II)Ljava/lang/String;
            invokestatic java.lang.Integer.parseInt:(Ljava/lang/String;)I
        24: .line 187
            putfield com.sun.crypto.provider.PBES2Parameters.keysize:I
        25: .line 190
            goto 29
        26: .line 191
      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 192
            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 191
            putfield com.sun.crypto.provider.PBES2Parameters.keysize:I
        29: .line 194
      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 196
            goto 34
        end local 2 // int and
        31: .line 197
      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 198
            aload 1 /* pbes2AlgorithmName */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        33: .line 197
            invokespecial java.security.NoSuchAlgorithmException.<init>:(Ljava/lang/String;)V
            athrow
        start local 2 // int and
        34: .line 201
      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 203
      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 204
            goto 53
        42: .line 206
      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 207
            goto 53
        44: .line 209
      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 210
            goto 53
        46: .line 212
      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 213
            goto 53
        48: .line 215
      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 216
            goto 53
        50: .line 218
      StackMap locals:
      StackMap stack:
            new java.security.NoSuchAlgorithmException
            dup
        51: .line 219
            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 218
            invokespecial java.security.NoSuchAlgorithmException.<init>:(Ljava/lang/String;)V
            athrow
        53: .line 222
      StackMap locals:
      StackMap stack:
            aload 4 /* cipherAlgo */
            ldc "AES"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 66
        54: .line 223
            aload 0 /* this */
            aload 0 /* this */
            getfield com.sun.crypto.provider.PBES2Parameters.keysize:I
            putfield com.sun.crypto.provider.PBES2Parameters.keysize:I
        55: .line 224
            aload 0 /* this */
            getfield com.sun.crypto.provider.PBES2Parameters.keysize:I
            lookupswitch { // 2
                  128: 56
                  256: 58
              default: 60
          }
        56: .line 226
      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 227
            goto 69
        58: .line 229
      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 230
            goto 69
        60: .line 232
      StackMap locals:
      StackMap stack:
            new java.security.NoSuchAlgorithmException
            dup
        61: .line 233
            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 234
            aload 4 /* cipherAlgo */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        63: .line 233
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        64: .line 232
            invokespecial java.security.NoSuchAlgorithmException.<init>:(Ljava/lang/String;)V
            athrow
        65: .line 236
      StackMap locals:
      StackMap stack:
            goto 69
        66: .line 237
      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 238
            aload 4 /* cipherAlgo */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        68: .line 237
            invokespecial java.security.NoSuchAlgorithmException.<init>:(Ljava/lang/String;)V
            athrow
        69: .line 240
      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 245
            aload 1 /* paramSpec */
            instanceof javax.crypto.spec.PBEParameterSpec
            ifne 4
         1: .line 246
            new java.security.spec.InvalidParameterSpecException
            dup
         2: .line 247
            ldc "Inappropriate parameter specification"
         3: .line 246
            invokespecial java.security.spec.InvalidParameterSpecException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 249
      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 250
            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 251
            aload 0 /* this */
            aload 1 /* paramSpec */
            checkcast javax.crypto.spec.PBEParameterSpec
            invokevirtual javax.crypto.spec.PBEParameterSpec.getParameterSpec:()Ljava/security/spec/AlgorithmParameterSpec;
            putfield com.sun.crypto.provider.PBES2Parameters.cipherParam:Ljava/security/spec/AlgorithmParameterSpec;
         7: .line 252
            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    8     0       this  Lcom/sun/crypto/provider/PBES2Parameters;
            0    8     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 258
            aconst_null
            astore 2 /* kdfAlgo */
        start local 2 // java.lang.String kdfAlgo
         1: .line 259
            aconst_null
            astore 3 /* cipherAlgo */
        start local 3 // java.lang.String cipherAlgo
         2: .line 261
            new sun.security.util.DerValue
            dup
            aload 1 /* encoded */
            invokespecial sun.security.util.DerValue.<init>:([B)V
            astore 4 /* pBES2_params */
        start local 4 // sun.security.util.DerValue pBES2_params
         3: .line 262
            aload 4 /* pBES2_params */
            getfield sun.security.util.DerValue.tag:B
            bipush 48
            if_icmpeq 5
         4: .line 263
            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 266
      StackMap locals: java.lang.String java.lang.String sun.security.util.DerValue
      StackMap stack:
            aload 4 /* pBES2_params */
            getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
            invokevirtual sun.security.util.DerInputStream.getDerValue:()Lsun/security/util/DerValue;
            astore 5 /* kdf */
        start local 5 // sun.security.util.DerValue kdf
         6: .line 274
            aload 5 /* kdf */
            invokevirtual sun.security.util.DerValue.getTag:()B
            bipush 6
            if_icmpne 9
         7: .line 275
            aload 4 /* pBES2_params */
            getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
            invokevirtual sun.security.util.DerInputStream.getDerValue:()Lsun/security/util/DerValue;
            astore 4 /* pBES2_params */
         8: .line 276
            aload 4 /* pBES2_params */
            getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
            invokevirtual sun.security.util.DerInputStream.getDerValue:()Lsun/security/util/DerValue;
            astore 5 /* kdf */
         9: .line 279
      StackMap locals: sun.security.util.DerValue
      StackMap stack:
            aload 0 /* this */
            aload 5 /* kdf */
            invokevirtual com.sun.crypto.provider.PBES2Parameters.parseKDF:(Lsun/security/util/DerValue;)Ljava/lang/String;
            astore 2 /* kdfAlgo */
        10: .line 281
            aload 4 /* 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:
      StackMap stack:
            aload 0 /* this */
            aload 4 /* 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 */
        13: .line 287
            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;
        14: .line 288
            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;
        15: .line 287
            putfield com.sun.crypto.provider.PBES2Parameters.pbes2AlgorithmName:Ljava/lang/String;
        16: .line 289
            return
        end local 5 // sun.security.util.DerValue kdf
        end local 4 // sun.security.util.DerValue pBES2_params
        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   17     0          this  Lcom/sun/crypto/provider/PBES2Parameters;
            0   17     1       encoded  [B
            1   17     2       kdfAlgo  Ljava/lang/String;
            2   17     3    cipherAlgo  Ljava/lang/String;
            3   17     4  pBES2_params  Lsun/security/util/DerValue;
            6   17     5           kdf  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=7, args_size=2
        start local 0 // com.sun.crypto.provider.PBES2Parameters this
        start local 1 // sun.security.util.DerValue keyDerivationFunc
         0: .line 294
            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:(Ljava/lang/Object;)Z
            ifne 2
         1: .line 295
            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
         2: .line 298
      StackMap locals:
      StackMap stack:
            aload 1 /* keyDerivationFunc */
            getfield sun.security.util.DerValue.tag:B
            bipush 48
            if_icmpeq 4
         3: .line 299
            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
         4: .line 302
      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 2 /* pBKDF2_params */
        start local 2 // sun.security.util.DerValue pBKDF2_params
         5: .line 303
            aload 2 /* pBKDF2_params */
            getfield sun.security.util.DerValue.tag:B
            bipush 48
            if_icmpeq 7
         6: .line 304
            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
         7: .line 307
      StackMap locals: sun.security.util.DerValue
      StackMap stack:
            aload 2 /* pBKDF2_params */
            getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
            invokevirtual sun.security.util.DerInputStream.getDerValue:()Lsun/security/util/DerValue;
            astore 3 /* specified */
        start local 3 // sun.security.util.DerValue specified
         8: .line 309
            aload 3 /* specified */
            getfield sun.security.util.DerValue.tag:B
            iconst_4
            if_icmpne 11
         9: .line 310
            aload 0 /* this */
            aload 3 /* specified */
            invokevirtual sun.security.util.DerValue.getOctetString:()[B
            putfield com.sun.crypto.provider.PBES2Parameters.salt:[B
        10: .line 311
            goto 12
        11: .line 313
      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
        12: .line 316
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 2 /* 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
        13: .line 318
            aconst_null
            astore 4 /* prf */
        start local 4 // sun.security.util.DerValue prf
        14: .line 320
            aload 2 /* pBKDF2_params */
            getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
            invokevirtual sun.security.util.DerInputStream.available:()I
            ifle 20
        15: .line 321
            aload 2 /* 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
        16: .line 322
            aload 5 /* keyLength */
            getfield sun.security.util.DerValue.tag:B
            iconst_2
            if_icmpne 19
        17: .line 323
            aload 0 /* this */
            aload 5 /* keyLength */
            invokevirtual sun.security.util.DerValue.getInteger:()I
            bipush 8
            imul
            putfield com.sun.crypto.provider.PBES2Parameters.keysize:I
        18: .line 324
            goto 20
        19: .line 326
      StackMap locals: sun.security.util.DerValue sun.security.util.DerValue
      StackMap stack:
            aload 5 /* keyLength */
            astore 4 /* prf */
        end local 5 // sun.security.util.DerValue keyLength
        20: .line 330
      StackMap locals:
      StackMap stack:
            ldc "HmacSHA1"
            astore 5 /* kdfAlgo */
        start local 5 // java.lang.String kdfAlgo
        21: .line 331
            aload 4 /* prf */
            ifnonnull 24
        22: .line 332
            aload 2 /* pBKDF2_params */
            getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
            invokevirtual sun.security.util.DerInputStream.available:()I
            ifle 24
        23: .line 333
            aload 2 /* pBKDF2_params */
            getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
            invokevirtual sun.security.util.DerInputStream.getDerValue:()Lsun/security/util/DerValue;
            astore 4 /* prf */
        24: .line 336
      StackMap locals: java.lang.String
      StackMap stack:
            aload 4 /* prf */
            ifnull 46
        25: .line 337
            aload 0 /* this */
            aload 4 /* 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;
        26: .line 338
            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:(Ljava/lang/Object;)Z
            ifeq 29
        27: .line 339
            ldc "HmacSHA1"
            astore 5 /* kdfAlgo */
        28: .line 340
            goto 42
      StackMap locals:
      StackMap stack:
        29: 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:(Ljava/lang/Object;)Z
            ifeq 32
        30: .line 341
            ldc "HmacSHA224"
            astore 5 /* kdfAlgo */
        31: .line 342
            goto 42
      StackMap locals:
      StackMap stack:
        32: 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:(Ljava/lang/Object;)Z
            ifeq 35
        33: .line 343
            ldc "HmacSHA256"
            astore 5 /* kdfAlgo */
        34: .line 344
            goto 42
      StackMap locals:
      StackMap stack:
        35: 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:(Ljava/lang/Object;)Z
            ifeq 38
        36: .line 345
            ldc "HmacSHA384"
            astore 5 /* kdfAlgo */
        37: .line 346
            goto 42
      StackMap locals:
      StackMap stack:
        38: 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:(Ljava/lang/Object;)Z
            ifeq 41
        39: .line 347
            ldc "HmacSHA512"
            astore 5 /* kdfAlgo */
        40: .line 348
            goto 42
        41: .line 349
      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
        42: .line 353
      StackMap locals:
      StackMap stack:
            aload 4 /* prf */
            getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
            invokevirtual sun.security.util.DerInputStream.available:()I
            ifeq 46
        43: .line 355
            aload 4 /* prf */
            getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
            invokevirtual sun.security.util.DerInputStream.getDerValue:()Lsun/security/util/DerValue;
            astore 6 /* parameter */
        start local 6 // sun.security.util.DerValue parameter
        44: .line 356
            aload 6 /* parameter */
            getfield sun.security.util.DerValue.tag:B
            iconst_5
            if_icmpeq 46
        45: .line 357
            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 6 // sun.security.util.DerValue parameter
        46: .line 363
      StackMap locals:
      StackMap stack:
            aload 5 /* kdfAlgo */
            areturn
        end local 5 // java.lang.String kdfAlgo
        end local 4 // sun.security.util.DerValue prf
        end local 3 // sun.security.util.DerValue specified
        end local 2 // sun.security.util.DerValue pBKDF2_params
        end local 1 // sun.security.util.DerValue keyDerivationFunc
        end local 0 // com.sun.crypto.provider.PBES2Parameters this
      LocalVariableTable:
        Start  End  Slot               Name  Signature
            0   47     0               this  Lcom/sun/crypto/provider/PBES2Parameters;
            0   47     1  keyDerivationFunc  Lsun/security/util/DerValue;
            5   47     2      pBKDF2_params  Lsun/security/util/DerValue;
            8   47     3          specified  Lsun/security/util/DerValue;
           14   47     4                prf  Lsun/security/util/DerValue;
           16   20     5          keyLength  Lsun/security/util/DerValue;
           21   47     5            kdfAlgo  Ljava/lang/String;
           44   46     6          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 368
            aconst_null
            astore 2 /* cipherAlgo */
        start local 2 // java.lang.String cipherAlgo
         1: .line 370
            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 371
            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:(Ljava/lang/Object;)Z
            ifeq 9
         3: .line 372
            ldc "AES_128"
            astore 2 /* cipherAlgo */
         4: .line 374
            aload 0 /* this */
         5: .line 375
            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 374
            putfield com.sun.crypto.provider.PBES2Parameters.cipherParam:Ljava/security/spec/AlgorithmParameterSpec;
         7: .line 376
            aload 0 /* this */
            sipush 128
            putfield com.sun.crypto.provider.PBES2Parameters.keysize:I
         8: .line 377
            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:(Ljava/lang/Object;)Z
            ifeq 16
        10: .line 378
            ldc "AES_256"
            astore 2 /* cipherAlgo */
        11: .line 380
            aload 0 /* this */
        12: .line 381
            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 380
            putfield com.sun.crypto.provider.PBES2Parameters.cipherParam:Ljava/security/spec/AlgorithmParameterSpec;
        14: .line 382
            aload 0 /* this */
            sipush 256
            putfield com.sun.crypto.provider.PBES2Parameters.keysize:I
        15: .line 383
            goto 17
        16: .line 384
      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 388
      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 394
            aload 0 /* this */
            aload 1 /* encoded */
            invokevirtual com.sun.crypto.provider.PBES2Parameters.engineInit:([B)V
         1: .line 395
            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 401
            ldc Ljavax/crypto/spec/PBEParameterSpec;
            aload 1 /* paramSpec */
            invokevirtual java.lang.Class.isAssignableFrom:(Ljava/lang/Class;)Z
            ifeq 4
         1: .line 402
            aload 1 /* paramSpec */
         2: .line 403
            new javax.crypto.spec.PBEParameterSpec
            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 javax.crypto.spec.PBEParameterSpec.<init>:([BILjava/security/spec/AlgorithmParameterSpec;)V
         3: .line 402
            invokevirtual java.lang.Class.cast:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.security.spec.AlgorithmParameterSpec
            areturn
         4: .line 405
      StackMap locals:
      StackMap stack:
            new java.security.spec.InvalidParameterSpecException
            dup
         5: .line 406
            ldc "Inappropriate parameter specification"
         6: .line 405
            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=7, args_size=1
        start local 0 // com.sun.crypto.provider.PBES2Parameters this
         0: .line 411
            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 413
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 2 /* pBES2_params */
        start local 2 // sun.security.util.DerOutputStream pBES2_params
         2: .line 415
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 3 /* keyDerivationFunc */
        start local 3 // sun.security.util.DerOutputStream keyDerivationFunc
         3: .line 416
            aload 3 /* keyDerivationFunc */
            getstatic com.sun.crypto.provider.PBES2Parameters.pkcs5PBKDF2_OID:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.DerOutputStream.putOID:(Lsun/security/util/ObjectIdentifier;)V
         4: .line 418
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 4 /* pBKDF2_params */
        start local 4 // sun.security.util.DerOutputStream pBKDF2_params
         5: .line 419
            aload 4 /* pBKDF2_params */
            aload 0 /* this */
            getfield com.sun.crypto.provider.PBES2Parameters.salt:[B
            invokevirtual sun.security.util.DerOutputStream.putOctetString:([B)V
         6: .line 420
            aload 4 /* pBKDF2_params */
            aload 0 /* this */
            getfield com.sun.crypto.provider.PBES2Parameters.iCount:I
            invokevirtual sun.security.util.DerOutputStream.putInteger:(I)V
         7: .line 422
            aload 0 /* this */
            getfield com.sun.crypto.provider.PBES2Parameters.keysize:I
            ifle 9
         8: .line 423
            aload 4 /* pBKDF2_params */
            aload 0 /* this */
            getfield com.sun.crypto.provider.PBES2Parameters.keysize:I
            bipush 8
            idiv
            invokevirtual sun.security.util.DerOutputStream.putInteger:(I)V
         9: .line 426
      StackMap locals: com.sun.crypto.provider.PBES2Parameters sun.security.util.DerOutputStream sun.security.util.DerOutputStream sun.security.util.DerOutputStream sun.security.util.DerOutputStream
      StackMap stack:
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 5 /* prf */
        start local 5 // sun.security.util.DerOutputStream prf
        10: .line 428
            aload 5 /* 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
        11: .line 430
            aload 5 /* prf */
            invokevirtual sun.security.util.DerOutputStream.putNull:()V
        12: .line 431
            aload 4 /* pBKDF2_params */
            bipush 48
            aload 5 /* prf */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        13: .line 433
            aload 3 /* keyDerivationFunc */
            bipush 48
            aload 4 /* pBKDF2_params */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        14: .line 434
            aload 2 /* pBES2_params */
            bipush 48
            aload 3 /* keyDerivationFunc */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        15: .line 436
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 6 /* encryptionScheme */
        start local 6 // sun.security.util.DerOutputStream encryptionScheme
        16: .line 438
            aload 6 /* 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
        17: .line 440
            aload 0 /* this */
            getfield com.sun.crypto.provider.PBES2Parameters.cipherParam:Ljava/security/spec/AlgorithmParameterSpec;
            ifnull 22
            aload 0 /* this */
            getfield com.sun.crypto.provider.PBES2Parameters.cipherParam:Ljava/security/spec/AlgorithmParameterSpec;
            instanceof javax.crypto.spec.IvParameterSpec
            ifeq 22
        18: .line 441
            aload 6 /* encryptionScheme */
        19: .line 442
            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
        20: .line 441
            invokevirtual sun.security.util.DerOutputStream.putOctetString:([B)V
        21: .line 443
            goto 23
        22: .line 444
      StackMap locals: 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
        23: .line 446
      StackMap locals:
      StackMap stack:
            aload 2 /* pBES2_params */
            bipush 48
            aload 6 /* encryptionScheme */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        24: .line 448
            aload 1 /* out */
            bipush 48
            aload 2 /* pBES2_params */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        25: .line 450
            aload 1 /* out */
            invokevirtual sun.security.util.DerOutputStream.toByteArray:()[B
            areturn
        end local 6 // sun.security.util.DerOutputStream encryptionScheme
        end local 5 // sun.security.util.DerOutputStream prf
        end local 4 // sun.security.util.DerOutputStream pBKDF2_params
        end local 3 // sun.security.util.DerOutputStream keyDerivationFunc
        end local 2 // sun.security.util.DerOutputStream pBES2_params
        end local 1 // sun.security.util.DerOutputStream out
        end local 0 // com.sun.crypto.provider.PBES2Parameters this
      LocalVariableTable:
        Start  End  Slot               Name  Signature
            0   26     0               this  Lcom/sun/crypto/provider/PBES2Parameters;
            1   26     1                out  Lsun/security/util/DerOutputStream;
            2   26     2       pBES2_params  Lsun/security/util/DerOutputStream;
            3   26     3  keyDerivationFunc  Lsun/security/util/DerOutputStream;
            5   26     4      pBKDF2_params  Lsun/security/util/DerOutputStream;
           10   26     5                prf  Lsun/security/util/DerOutputStream;
           16   26     6   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 456
            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 467
            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