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 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 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=1, locals=0, args_size=0
         0: .line 96
            getstatic sun.security.util.KnownOIDs.PBKDF2WithHmacSHA1:Lsun/security/util/KnownOIDs;
            invokestatic sun.security.util.ObjectIdentifier.of:(Lsun/security/util/KnownOIDs;)Lsun/security/util/ObjectIdentifier;
         1: .line 95
            putstatic com.sun.crypto.provider.PBES2Parameters.pkcs5PBKDF2_OID:Lsun/security/util/ObjectIdentifier;
         2: .line 98
            getstatic sun.security.util.KnownOIDs.PBES2:Lsun/security/util/KnownOIDs;
            invokestatic sun.security.util.ObjectIdentifier.of:(Lsun/security/util/KnownOIDs;)Lsun/security/util/ObjectIdentifier;
         3: .line 97
            putstatic com.sun.crypto.provider.PBES2Parameters.pkcs5PBES2_OID:Lsun/security/util/ObjectIdentifier;
         4: .line 100
            getstatic sun.security.util.KnownOIDs.AES_128$CBC$NoPadding:Lsun/security/util/KnownOIDs;
            invokestatic sun.security.util.ObjectIdentifier.of:(Lsun/security/util/KnownOIDs;)Lsun/security/util/ObjectIdentifier;
         5: .line 99
            putstatic com.sun.crypto.provider.PBES2Parameters.aes128CBC_OID:Lsun/security/util/ObjectIdentifier;
         6: .line 102
            getstatic sun.security.util.KnownOIDs.AES_192$CBC$NoPadding:Lsun/security/util/KnownOIDs;
            invokestatic sun.security.util.ObjectIdentifier.of:(Lsun/security/util/KnownOIDs;)Lsun/security/util/ObjectIdentifier;
         7: .line 101
            putstatic com.sun.crypto.provider.PBES2Parameters.aes192CBC_OID:Lsun/security/util/ObjectIdentifier;
         8: .line 104
            getstatic sun.security.util.KnownOIDs.AES_256$CBC$NoPadding:Lsun/security/util/KnownOIDs;
            invokestatic sun.security.util.ObjectIdentifier.of:(Lsun/security/util/KnownOIDs;)Lsun/security/util/ObjectIdentifier;
         9: .line 103
            putstatic com.sun.crypto.provider.PBES2Parameters.aes256CBC_OID:Lsun/security/util/ObjectIdentifier;
        10: .line 104
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  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 128
            aload 0 /* this */
            invokespecial java.security.AlgorithmParametersSpi.<init>:()V
         1: .line 107
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.PBES2Parameters.pbes2AlgorithmName:Ljava/lang/String;
         2: .line 110
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.PBES2Parameters.salt:[B
         3: .line 113
            aload 0 /* this */
            iconst_0
            putfield com.sun.crypto.provider.PBES2Parameters.iCount:I
         4: .line 116
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.PBES2Parameters.cipherParam:Ljava/security/spec/AlgorithmParameterSpec;
         5: .line 119
            aload 0 /* this */
         6: .line 120
            getstatic sun.security.util.KnownOIDs.HmacSHA1:Lsun/security/util/KnownOIDs;
            invokestatic sun.security.util.ObjectIdentifier.of:(Lsun/security/util/KnownOIDs;)Lsun/security/util/ObjectIdentifier;
            putfield com.sun.crypto.provider.PBES2Parameters.kdfAlgo_OID:Lsun/security/util/ObjectIdentifier;
         7: .line 123
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.PBES2Parameters.cipherAlgo_OID:Lsun/security/util/ObjectIdentifier;
         8: .line 126
            aload 0 /* this */
            iconst_m1
            putfield com.sun.crypto.provider.PBES2Parameters.keysize:I
         9: .line 130
            return
        end local 0 // com.sun.crypto.provider.PBES2Parameters this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   10     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 132
            aload 0 /* this */
            invokespecial java.security.AlgorithmParametersSpi.<init>:()V
         1: .line 107
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.PBES2Parameters.pbes2AlgorithmName:Ljava/lang/String;
         2: .line 110
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.PBES2Parameters.salt:[B
         3: .line 113
            aload 0 /* this */
            iconst_0
            putfield com.sun.crypto.provider.PBES2Parameters.iCount:I
         4: .line 116
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.PBES2Parameters.cipherParam:Ljava/security/spec/AlgorithmParameterSpec;
         5: .line 119
            aload 0 /* this */
         6: .line 120
            getstatic sun.security.util.KnownOIDs.HmacSHA1:Lsun/security/util/KnownOIDs;
            invokestatic sun.security.util.ObjectIdentifier.of:(Lsun/security/util/KnownOIDs;)Lsun/security/util/ObjectIdentifier;
            putfield com.sun.crypto.provider.PBES2Parameters.kdfAlgo_OID:Lsun/security/util/ObjectIdentifier;
         7: .line 123
            aload 0 /* this */
            aconst_null
            putfield com.sun.crypto.provider.PBES2Parameters.cipherAlgo_OID:Lsun/security/util/ObjectIdentifier;
         8: .line 126
            aload 0 /* this */
            iconst_m1
            putfield com.sun.crypto.provider.PBES2Parameters.keysize:I
         9: .line 134
            aconst_null
            astore 3 /* kdfAlgo */
        start local 3 // java.lang.String kdfAlgo
        10: .line 135
            aconst_null
            astore 4 /* cipherAlgo */
        start local 4 // java.lang.String cipherAlgo
        11: .line 138
            aload 0 /* this */
            aload 1 /* pbes2AlgorithmName */
            putfield com.sun.crypto.provider.PBES2Parameters.pbes2AlgorithmName:Ljava/lang/String;
        12: .line 139
            aload 1 /* pbes2AlgorithmName */
            ldc "PBEWith"
            invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
            ifeq 32
        13: .line 140
            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
        14: ifle 32
        15: .line 141
            aload 1 /* pbes2AlgorithmName */
            bipush 7
            iload 2 /* and */
            invokevirtual java.lang.String.substring:(II)Ljava/lang/String;
            astore 3 /* kdfAlgo */
        16: .line 142
            aload 1 /* pbes2AlgorithmName */
            iload 2 /* and */
            iconst_3
            iadd
            invokevirtual java.lang.String.substring:(I)Ljava/lang/String;
            astore 4 /* cipherAlgo */
        17: .line 146
            aload 4 /* cipherAlgo */
            bipush 95
            invokevirtual java.lang.String.indexOf:(I)I
            dup
            istore 5 /* underscore */
        start local 5 // int underscore
        18: ifle 35
        19: .line 148
            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
        20: ifle 27
        21: .line 149
            aload 0 /* this */
        22: .line 150
            aload 4 /* cipherAlgo */
            iload 5 /* underscore */
            iconst_1
            iadd
        23: .line 151
            iload 6 /* slash */
        24: .line 150
            invokevirtual java.lang.String.substring:(II)Ljava/lang/String;
            invokestatic java.lang.Integer.parseInt:(Ljava/lang/String;)I
        25: .line 149
            putfield com.sun.crypto.provider.PBES2Parameters.keysize:I
        26: .line 152
            goto 30
        27: .line 153
      StackMap locals: com.sun.crypto.provider.PBES2Parameters java.lang.String int java.lang.String java.lang.String int int
      StackMap stack:
            aload 0 /* this */
        28: .line 154
            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
        29: .line 153
            putfield com.sun.crypto.provider.PBES2Parameters.keysize:I
        30: .line 156
      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
        31: .line 158
            goto 35
        end local 2 // int and
        32: .line 159
      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
        33: .line 160
            aload 1 /* pbes2AlgorithmName */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        34: .line 159
            invokespecial java.security.NoSuchAlgorithmException.<init>:(Ljava/lang/String;)V
            athrow
        start local 2 // int and
        35: .line 163
      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: 36
            954017038: 37
            954018090: 38
            954019793: 39
           1752946092: 40
              default: 43
          }
      StackMap locals: java.lang.String
      StackMap stack:
        36: aload 5
            ldc "HmacSHA224"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 41
            goto 43
      StackMap locals:
      StackMap stack:
        37: aload 5
            ldc "HmacSHA256"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 41
            goto 43
      StackMap locals:
      StackMap stack:
        38: aload 5
            ldc "HmacSHA384"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 41
            goto 43
      StackMap locals:
      StackMap stack:
        39: aload 5
            ldc "HmacSHA512"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 41
            goto 43
      StackMap locals:
      StackMap stack:
        40: aload 5
            ldc "HmacSHA1"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 41
            goto 43
        41: .line 169
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 3 /* kdfAlgo */
            invokestatic sun.security.util.KnownOIDs.findMatch:(Ljava/lang/String;)Lsun/security/util/KnownOIDs;
            invokestatic sun.security.util.ObjectIdentifier.of:(Lsun/security/util/KnownOIDs;)Lsun/security/util/ObjectIdentifier;
            putfield com.sun.crypto.provider.PBES2Parameters.kdfAlgo_OID:Lsun/security/util/ObjectIdentifier;
        42: .line 170
            goto 46
        43: .line 172
      StackMap locals:
      StackMap stack:
            new java.security.NoSuchAlgorithmException
            dup
        44: .line 173
            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;
        45: .line 172
            invokespecial java.security.NoSuchAlgorithmException.<init>:(Ljava/lang/String;)V
            athrow
        46: .line 176
      StackMap locals:
      StackMap stack:
            aload 4 /* cipherAlgo */
            ldc "AES"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 59
        47: .line 177
            aload 0 /* this */
            aload 0 /* this */
            getfield com.sun.crypto.provider.PBES2Parameters.keysize:I
            putfield com.sun.crypto.provider.PBES2Parameters.keysize:I
        48: .line 178
            aload 0 /* this */
            getfield com.sun.crypto.provider.PBES2Parameters.keysize:I
            lookupswitch { // 2
                  128: 49
                  256: 51
              default: 53
          }
        49: .line 180
      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;
        50: .line 181
            goto 62
        51: .line 183
      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;
        52: .line 184
            goto 62
        53: .line 186
      StackMap locals:
      StackMap stack:
            new java.security.NoSuchAlgorithmException
            dup
        54: .line 187
            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;
        55: .line 188
            aload 4 /* cipherAlgo */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        56: .line 187
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        57: .line 186
            invokespecial java.security.NoSuchAlgorithmException.<init>:(Ljava/lang/String;)V
            athrow
        58: .line 190
      StackMap locals:
      StackMap stack:
            goto 62
        59: .line 191
      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
        60: .line 192
            aload 4 /* cipherAlgo */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        61: .line 191
            invokespecial java.security.NoSuchAlgorithmException.<init>:(Ljava/lang/String;)V
            athrow
        62: .line 194
      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   63     0                this  Lcom/sun/crypto/provider/PBES2Parameters;
            0   63     1  pbes2AlgorithmName  Ljava/lang/String;
           14   32     2                 and  I
           35   63     2                 and  I
           10   63     3             kdfAlgo  Ljava/lang/String;
           11   63     4          cipherAlgo  Ljava/lang/String;
           18   31     5          underscore  I
           20   31     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 199
            aload 1 /* paramSpec */
            instanceof javax.crypto.spec.PBEParameterSpec
            ifne 4
         1: .line 200
            new java.security.spec.InvalidParameterSpecException
            dup
         2: .line 201
            ldc "Inappropriate parameter specification"
         3: .line 200
            invokespecial java.security.spec.InvalidParameterSpecException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 203
      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 204
            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 205
            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 206
            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 212
            aconst_null
            astore 2 /* kdfAlgo */
        start local 2 // java.lang.String kdfAlgo
         1: .line 213
            aconst_null
            astore 3 /* cipherAlgo */
        start local 3 // java.lang.String cipherAlgo
         2: .line 215
            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 216
            aload 4 /* pBES2_params */
            getfield sun.security.util.DerValue.tag:B
            bipush 48
            if_icmpeq 5
         4: .line 217
            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 220
      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 228
            aload 5 /* kdf */
            invokevirtual sun.security.util.DerValue.getTag:()B
            bipush 6
            if_icmpne 9
         7: .line 229
            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 230
            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 233
      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 235
            aload 4 /* pBES2_params */
            getfield sun.security.util.DerValue.tag:B
            bipush 48
            if_icmpeq 12
        11: .line 236
            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 239
      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 241
            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 242
            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 241
            putfield com.sun.crypto.provider.PBES2Parameters.pbes2AlgorithmName:Ljava/lang/String;
        16: .line 243
            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=8, args_size=2
        start local 0 // com.sun.crypto.provider.PBES2Parameters this
        start local 1 // sun.security.util.DerValue keyDerivationFunc
         0: .line 248
            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 249
            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 252
      StackMap locals:
      StackMap stack:
            aload 1 /* keyDerivationFunc */
            getfield sun.security.util.DerValue.tag:B
            bipush 48
            if_icmpeq 4
         3: .line 253
            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 256
      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 257
            aload 2 /* pBKDF2_params */
            getfield sun.security.util.DerValue.tag:B
            bipush 48
            if_icmpeq 7
         6: .line 258
            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 261
      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 263
            aload 3 /* specified */
            getfield sun.security.util.DerValue.tag:B
            iconst_4
            if_icmpne 11
         9: .line 264
            aload 0 /* this */
            aload 3 /* specified */
            invokevirtual sun.security.util.DerValue.getOctetString:()[B
            putfield com.sun.crypto.provider.PBES2Parameters.salt:[B
        10: .line 265
            goto 12
        11: .line 267
      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 270
      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 272
            aconst_null
            astore 4 /* prf */
        start local 4 // sun.security.util.DerValue prf
        14: .line 274
            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 275
            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 276
            aload 5 /* keyLength */
            getfield sun.security.util.DerValue.tag:B
            iconst_2
            if_icmpne 19
        17: .line 277
            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 278
            goto 20
        19: .line 280
      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 284
      StackMap locals:
      StackMap stack:
            ldc "HmacSHA1"
            astore 5 /* kdfAlgo */
        start local 5 // java.lang.String kdfAlgo
        21: .line 285
            aload 4 /* prf */
            ifnonnull 24
        22: .line 286
            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 287
            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 290
      StackMap locals: java.lang.String
      StackMap stack:
            aload 4 /* prf */
            ifnull 38
        25: .line 291
            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 292
            aload 0 /* this */
            getfield com.sun.crypto.provider.PBES2Parameters.kdfAlgo_OID:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.toString:()Ljava/lang/String;
            invokestatic sun.security.util.KnownOIDs.findMatch:(Ljava/lang/String;)Lsun/security/util/KnownOIDs;
            astore 6 /* o */
        start local 6 // sun.security.util.KnownOIDs o
        27: .line 293
            aload 6 /* o */
            ifnull 32
            aload 6 /* o */
            invokevirtual sun.security.util.KnownOIDs.stdName:()Ljava/lang/String;
            ldc "HmacSHA1"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 33
        28: .line 294
            aload 6 /* o */
            invokevirtual sun.security.util.KnownOIDs.stdName:()Ljava/lang/String;
            ldc "HmacSHA224"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 33
        29: .line 295
            aload 6 /* o */
            invokevirtual sun.security.util.KnownOIDs.stdName:()Ljava/lang/String;
            ldc "HmacSHA256"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 33
        30: .line 296
            aload 6 /* o */
            invokevirtual sun.security.util.KnownOIDs.stdName:()Ljava/lang/String;
            ldc "HmacSHA384"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 33
        31: .line 297
            aload 6 /* o */
            invokevirtual sun.security.util.KnownOIDs.stdName:()Ljava/lang/String;
            ldc "HmacSHA512"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 33
        32: .line 298
      StackMap locals: sun.security.util.KnownOIDs
      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
        33: .line 302
      StackMap locals:
      StackMap stack:
            aload 6 /* o */
            invokevirtual sun.security.util.KnownOIDs.stdName:()Ljava/lang/String;
            astore 5 /* kdfAlgo */
        34: .line 304
            aload 4 /* prf */
            getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
            invokevirtual sun.security.util.DerInputStream.available:()I
            ifeq 38
        35: .line 306
            aload 4 /* 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
        36: .line 307
            aload 7 /* parameter */
            getfield sun.security.util.DerValue.tag:B
            iconst_5
            if_icmpeq 38
        37: .line 308
            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.KnownOIDs o
        38: .line 314
      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   39     0               this  Lcom/sun/crypto/provider/PBES2Parameters;
            0   39     1  keyDerivationFunc  Lsun/security/util/DerValue;
            5   39     2      pBKDF2_params  Lsun/security/util/DerValue;
            8   39     3          specified  Lsun/security/util/DerValue;
           14   39     4                prf  Lsun/security/util/DerValue;
           16   20     5          keyLength  Lsun/security/util/DerValue;
           21   39     5            kdfAlgo  Ljava/lang/String;
           27   38     6                  o  Lsun/security/util/KnownOIDs;
           36   38     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 319
            aconst_null
            astore 2 /* cipherAlgo */
        start local 2 // java.lang.String cipherAlgo
         1: .line 321
            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 322
            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 323
            ldc "AES_128"
            astore 2 /* cipherAlgo */
         4: .line 325
            aload 0 /* this */
         5: .line 326
            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 325
            putfield com.sun.crypto.provider.PBES2Parameters.cipherParam:Ljava/security/spec/AlgorithmParameterSpec;
         7: .line 327
            aload 0 /* this */
            sipush 128
            putfield com.sun.crypto.provider.PBES2Parameters.keysize:I
         8: .line 328
            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 329
            ldc "AES_256"
            astore 2 /* cipherAlgo */
        11: .line 331
            aload 0 /* this */
        12: .line 332
            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 331
            putfield com.sun.crypto.provider.PBES2Parameters.cipherParam:Ljava/security/spec/AlgorithmParameterSpec;
        14: .line 333
            aload 0 /* this */
            sipush 256
            putfield com.sun.crypto.provider.PBES2Parameters.keysize:I
        15: .line 334
            goto 17
        16: .line 335
      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 339
      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 345
            aload 0 /* this */
            aload 1 /* encoded */
            invokevirtual com.sun.crypto.provider.PBES2Parameters.engineInit:([B)V
         1: .line 346
            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 352
            ldc Ljavax/crypto/spec/PBEParameterSpec;
            aload 1 /* paramSpec */
            invokevirtual java.lang.Class.isAssignableFrom:(Ljava/lang/Class;)Z
            ifeq 4
         1: .line 353
            aload 1 /* paramSpec */
         2: .line 354
            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 353
            invokevirtual java.lang.Class.cast:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.security.spec.AlgorithmParameterSpec
            areturn
         4: .line 356
      StackMap locals:
      StackMap stack:
            new java.security.spec.InvalidParameterSpecException
            dup
         5: .line 357
            ldc "Inappropriate parameter specification"
         6: .line 356
            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 362
            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 364
            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 366
            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 367
            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 369
            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 370
            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 371
            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 373
            aload 0 /* this */
            getfield com.sun.crypto.provider.PBES2Parameters.keysize:I
            ifle 9
         8: .line 374
            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 377
      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 379
            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 381
            aload 5 /* prf */
            invokevirtual sun.security.util.DerOutputStream.putNull:()V
        12: .line 382
            aload 4 /* pBKDF2_params */
            bipush 48
            aload 5 /* prf */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        13: .line 384
            aload 3 /* keyDerivationFunc */
            bipush 48
            aload 4 /* pBKDF2_params */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        14: .line 385
            aload 2 /* pBES2_params */
            bipush 48
            aload 3 /* keyDerivationFunc */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        15: .line 387
            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 389
            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 391
            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 392
            aload 6 /* encryptionScheme */
        19: .line 393
            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 392
            invokevirtual sun.security.util.DerOutputStream.putOctetString:([B)V
        21: .line 394
            goto 23
        22: .line 395
      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 397
      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 399
            aload 1 /* out */
            bipush 48
            aload 2 /* pBES2_params */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
        25: .line 401
            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 407
            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 418
            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