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: 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: putstatic com.sun.crypto.provider.PBES2Parameters.pkcs5PBKDF2:[I
2: 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: putstatic com.sun.crypto.provider.PBES2Parameters.pkcs5PBES2:[I
4: 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: putstatic com.sun.crypto.provider.PBES2Parameters.hmacWithSHA1:[I
6: 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: putstatic com.sun.crypto.provider.PBES2Parameters.hmacWithSHA224:[I
8: 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: putstatic com.sun.crypto.provider.PBES2Parameters.hmacWithSHA256:[I
10: 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: putstatic com.sun.crypto.provider.PBES2Parameters.hmacWithSHA384:[I
12: 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: putstatic com.sun.crypto.provider.PBES2Parameters.hmacWithSHA512:[I
14: 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: putstatic com.sun.crypto.provider.PBES2Parameters.aes128CBC:[I
16: 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: putstatic com.sun.crypto.provider.PBES2Parameters.aes192CBC:[I
18: 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: putstatic com.sun.crypto.provider.PBES2Parameters.aes256CBC:[I
20: 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: 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: 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: 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: 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: 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: 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: 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: 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: 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: goto 32
StackMap locals:
StackMap stack: java.io.IOException
31: pop
32: 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 0: aload 0
invokespecial java.security.AlgorithmParametersSpi.<init>:()V
1: aload 0
aconst_null
putfield com.sun.crypto.provider.PBES2Parameters.pbes2AlgorithmName:Ljava/lang/String;
2: aload 0
aconst_null
putfield com.sun.crypto.provider.PBES2Parameters.salt:[B
3: aload 0
iconst_0
putfield com.sun.crypto.provider.PBES2Parameters.iCount:I
4: aload 0
aconst_null
putfield com.sun.crypto.provider.PBES2Parameters.cipherParam:Ljava/security/spec/AlgorithmParameterSpec;
5: aload 0
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: aload 0
aconst_null
putfield com.sun.crypto.provider.PBES2Parameters.cipherAlgo_OID:Lsun/security/util/ObjectIdentifier;
7: aload 0
iconst_m1
putfield com.sun.crypto.provider.PBES2Parameters.keysize:I
8: return
end local 0 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 start local 1 0: aload 0
invokespecial java.security.AlgorithmParametersSpi.<init>:()V
1: aload 0
aconst_null
putfield com.sun.crypto.provider.PBES2Parameters.pbes2AlgorithmName:Ljava/lang/String;
2: aload 0
aconst_null
putfield com.sun.crypto.provider.PBES2Parameters.salt:[B
3: aload 0
iconst_0
putfield com.sun.crypto.provider.PBES2Parameters.iCount:I
4: aload 0
aconst_null
putfield com.sun.crypto.provider.PBES2Parameters.cipherParam:Ljava/security/spec/AlgorithmParameterSpec;
5: aload 0
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: aload 0
aconst_null
putfield com.sun.crypto.provider.PBES2Parameters.cipherAlgo_OID:Lsun/security/util/ObjectIdentifier;
7: aload 0
iconst_m1
putfield com.sun.crypto.provider.PBES2Parameters.keysize:I
8: aconst_null
astore 3
start local 3 9: aconst_null
astore 4
start local 4 10: aload 0
aload 1
putfield com.sun.crypto.provider.PBES2Parameters.pbes2AlgorithmName:Ljava/lang/String;
11: aload 1
ldc "PBEWith"
invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
ifeq 31
12: aload 1
ldc "And"
bipush 8
invokevirtual java.lang.String.indexOf:(Ljava/lang/String;I)I
dup
istore 2
start local 2 13: ifle 31
14: aload 1
bipush 7
iload 2
invokevirtual java.lang.String.substring:(II)Ljava/lang/String;
astore 3
15: aload 1
iload 2
iconst_3
iadd
invokevirtual java.lang.String.substring:(I)Ljava/lang/String;
astore 4
16: aload 4
bipush 95
invokevirtual java.lang.String.indexOf:(I)I
dup
istore 5
start local 5 17: ifle 34
18: aload 4
bipush 47
iload 5
iconst_1
iadd
invokevirtual java.lang.String.indexOf:(II)I
dup
istore 6
start local 6 19: ifle 26
20: aload 0
21: aload 4
iload 5
iconst_1
iadd
22: iload 6
23: invokevirtual java.lang.String.substring:(II)Ljava/lang/String;
invokestatic java.lang.Integer.parseInt:(Ljava/lang/String;)I
24: putfield com.sun.crypto.provider.PBES2Parameters.keysize:I
25: goto 29
26: StackMap locals: com.sun.crypto.provider.PBES2Parameters java.lang.String int java.lang.String java.lang.String int int
StackMap stack:
aload 0
27: aload 4
iload 5
iconst_1
iadd
invokevirtual java.lang.String.substring:(I)Ljava/lang/String;
invokestatic java.lang.Integer.parseInt:(Ljava/lang/String;)I
28: putfield com.sun.crypto.provider.PBES2Parameters.keysize:I
29: StackMap locals:
StackMap stack:
aload 4
iconst_0
iload 5
invokevirtual java.lang.String.substring:(II)Ljava/lang/String;
astore 4
end local 6 end local 5 30: goto 34
end local 2 31: 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: aload 1
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
33: invokespecial java.security.NoSuchAlgorithmException.<init>:(Ljava/lang/String;)V
athrow
start local 2 34: StackMap locals: com.sun.crypto.provider.PBES2Parameters java.lang.String int java.lang.String java.lang.String
StackMap stack:
aload 3
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: StackMap locals:
StackMap stack:
aload 0
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: goto 53
42: StackMap locals:
StackMap stack:
aload 0
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: goto 53
44: StackMap locals:
StackMap stack:
aload 0
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: goto 53
46: StackMap locals:
StackMap stack:
aload 0
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: goto 53
48: StackMap locals:
StackMap stack:
aload 0
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: goto 53
50: StackMap locals:
StackMap stack:
new java.security.NoSuchAlgorithmException
dup
51: new java.lang.StringBuilder
dup
ldc "No crypto implementation for "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 3
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
52: invokespecial java.security.NoSuchAlgorithmException.<init>:(Ljava/lang/String;)V
athrow
53: StackMap locals:
StackMap stack:
aload 4
ldc "AES"
invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
ifeq 66
54: aload 0
aload 0
getfield com.sun.crypto.provider.PBES2Parameters.keysize:I
putfield com.sun.crypto.provider.PBES2Parameters.keysize:I
55: aload 0
getfield com.sun.crypto.provider.PBES2Parameters.keysize:I
lookupswitch { // 2
128: 56
256: 58
default: 60
}
56: StackMap locals:
StackMap stack:
aload 0
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: goto 69
58: StackMap locals:
StackMap stack:
aload 0
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: goto 69
60: StackMap locals:
StackMap stack:
new java.security.NoSuchAlgorithmException
dup
61: new java.lang.StringBuilder
dup
ldc "No Cipher implementation for "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 0
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: aload 4
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
63: invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
64: invokespecial java.security.NoSuchAlgorithmException.<init>:(Ljava/lang/String;)V
athrow
65: StackMap locals:
StackMap stack:
goto 69
66: 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: aload 4
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
68: invokespecial java.security.NoSuchAlgorithmException.<init>:(Ljava/lang/String;)V
athrow
69: StackMap locals:
StackMap stack:
return
end local 4 end local 3 end local 2 end local 1 end local 0 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 start local 1 0: aload 1
instanceof javax.crypto.spec.PBEParameterSpec
ifne 4
1: new java.security.spec.InvalidParameterSpecException
dup
2: ldc "Inappropriate parameter specification"
3: invokespecial java.security.spec.InvalidParameterSpecException.<init>:(Ljava/lang/String;)V
athrow
4: StackMap locals:
StackMap stack:
aload 0
aload 1
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: aload 0
aload 1
checkcast javax.crypto.spec.PBEParameterSpec
invokevirtual javax.crypto.spec.PBEParameterSpec.getIterationCount:()I
putfield com.sun.crypto.provider.PBES2Parameters.iCount:I
6: aload 1
instanceof com.sun.crypto.spec.PBE2ParameterSpec
ifeq 8
7: aload 0
aload 1
checkcast com.sun.crypto.spec.PBE2ParameterSpec
invokevirtual com.sun.crypto.spec.PBE2ParameterSpec.getParameterSpec:()Ljava/security/spec/AlgorithmParameterSpec;
putfield com.sun.crypto.provider.PBES2Parameters.cipherParam:Ljava/security/spec/AlgorithmParameterSpec;
8: StackMap locals:
StackMap stack:
return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 9 0 this Lcom/sun/crypto/provider/PBES2Parameters;
0 9 1 paramSpec Ljava/security/spec/AlgorithmParameterSpec;
Exceptions:
throws java.security.spec.InvalidParameterSpecException
MethodParameters:
Name Flags
paramSpec
protected void engineInit(byte[]);
descriptor: ([B)V
flags: (0x0004) ACC_PROTECTED
Code:
stack=3, locals=6, args_size=2
start local 0 start local 1 0: aconst_null
astore 2
start local 2 1: aconst_null
astore 3
start local 3 2: new sun.security.util.DerValue
dup
aload 1
invokespecial sun.security.util.DerValue.<init>:([B)V
astore 4
start local 4 3: aload 4
getfield sun.security.util.DerValue.tag:B
bipush 48
if_icmpeq 5
4: 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: StackMap locals: java.lang.String java.lang.String sun.security.util.DerValue
StackMap stack:
getstatic com.sun.crypto.provider.PBES2Parameters.pkcs5PBES2_OID:Lsun/security/util/ObjectIdentifier;
aload 4
getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
invokevirtual sun.security.util.DerInputStream.getOID:()Lsun/security/util/ObjectIdentifier;
invokevirtual sun.security.util.ObjectIdentifier.equals:(Lsun/security/util/ObjectIdentifier;)Z
ifne 7
6: new java.io.IOException
dup
ldc "PBE parameter parsing error: expecting the object identifier for PBES2"
invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
athrow
7: StackMap locals:
StackMap stack:
aload 4
getfield sun.security.util.DerValue.tag:B
bipush 48
if_icmpeq 9
8: new java.io.IOException
dup
ldc "PBE parameter parsing error: not an ASN.1 SEQUENCE tag"
invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
athrow
9: StackMap locals:
StackMap stack:
aload 4
getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
invokevirtual sun.security.util.DerInputStream.getDerValue:()Lsun/security/util/DerValue;
astore 5
start local 5 10: aload 5
getfield sun.security.util.DerValue.tag:B
bipush 48
if_icmpeq 12
11: 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: StackMap locals: sun.security.util.DerValue
StackMap stack:
aload 0
aload 5
getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
invokevirtual sun.security.util.DerInputStream.getDerValue:()Lsun/security/util/DerValue;
invokevirtual com.sun.crypto.provider.PBES2Parameters.parseKDF:(Lsun/security/util/DerValue;)Ljava/lang/String;
astore 2
13: aload 5
getfield sun.security.util.DerValue.tag:B
bipush 48
if_icmpeq 15
14: new java.io.IOException
dup
ldc "PBE parameter parsing error: not an ASN.1 SEQUENCE tag"
invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
athrow
15: StackMap locals:
StackMap stack:
aload 0
aload 5
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
16: aload 0
new java.lang.StringBuilder
dup
invokespecial java.lang.StringBuilder.<init>:()V
ldc "PBEWith"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
17: aload 2
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
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
18: putfield com.sun.crypto.provider.PBES2Parameters.pbes2AlgorithmName:Ljava/lang/String;
19: return
end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 20 0 this Lcom/sun/crypto/provider/PBES2Parameters;
0 20 1 encoded [B
1 20 2 kdfAlgo Ljava/lang/String;
2 20 3 cipherAlgo Ljava/lang/String;
3 20 4 pBES2Algorithms Lsun/security/util/DerValue;
10 20 5 pBES2_params Lsun/security/util/DerValue;
Exceptions:
throws java.io.IOException
MethodParameters:
Name Flags
encoded
private java.lang.String parseKDF(sun.security.util.DerValue);
descriptor: (Lsun/security/util/DerValue;)Ljava/lang/String;
flags: (0x0002) ACC_PRIVATE
Code:
stack=3, locals=8, args_size=2
start local 0 start local 1 0: aconst_null
astore 2
start local 2 1: getstatic com.sun.crypto.provider.PBES2Parameters.pkcs5PBKDF2_OID:Lsun/security/util/ObjectIdentifier;
aload 1
getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
invokevirtual sun.security.util.DerInputStream.getOID:()Lsun/security/util/ObjectIdentifier;
invokevirtual sun.security.util.ObjectIdentifier.equals:(Lsun/security/util/ObjectIdentifier;)Z
ifne 3
2: new java.io.IOException
dup
ldc "PBE parameter parsing error: expecting the object identifier for PBKDF2"
invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
athrow
3: StackMap locals: java.lang.String
StackMap stack:
aload 1
getfield sun.security.util.DerValue.tag:B
bipush 48
if_icmpeq 5
4: 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: StackMap locals:
StackMap stack:
aload 1
getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
invokevirtual sun.security.util.DerInputStream.getDerValue:()Lsun/security/util/DerValue;
astore 3
start local 3 6: aload 3
getfield sun.security.util.DerValue.tag:B
bipush 48
if_icmpeq 8
7: new java.io.IOException
dup
ldc "PBE parameter parsing error: not an ASN.1 SEQUENCE tag"
invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
athrow
8: StackMap locals: sun.security.util.DerValue
StackMap stack:
aload 3
getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
invokevirtual sun.security.util.DerInputStream.getDerValue:()Lsun/security/util/DerValue;
astore 4
start local 4 9: aload 4
getfield sun.security.util.DerValue.tag:B
iconst_4
if_icmpne 12
10: aload 0
aload 4
invokevirtual sun.security.util.DerValue.getOctetString:()[B
putfield com.sun.crypto.provider.PBES2Parameters.salt:[B
11: goto 13
12: StackMap locals: sun.security.util.DerValue
StackMap stack:
new java.io.IOException
dup
ldc "PBE parameter parsing error: not an ASN.1 OCTET STRING tag"
invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
athrow
13: StackMap locals:
StackMap stack:
aload 0
aload 3
getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
invokevirtual sun.security.util.DerInputStream.getInteger:()I
putfield com.sun.crypto.provider.PBES2Parameters.iCount:I
14: aload 3
getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
invokevirtual sun.security.util.DerInputStream.getDerValue:()Lsun/security/util/DerValue;
astore 5
start local 5 15: aload 5
getfield sun.security.util.DerValue.tag:B
iconst_2
if_icmpne 17
16: aload 0
aload 5
invokevirtual sun.security.util.DerValue.getInteger:()I
bipush 8
imul
putfield com.sun.crypto.provider.PBES2Parameters.keysize:I
17: StackMap locals: sun.security.util.DerValue
StackMap stack:
aload 3
getfield sun.security.util.DerValue.tag:B
bipush 48
if_icmpne 40
18: aload 3
getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
invokevirtual sun.security.util.DerInputStream.getDerValue:()Lsun/security/util/DerValue;
astore 6
start local 6 19: aload 0
aload 6
getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
invokevirtual sun.security.util.DerInputStream.getOID:()Lsun/security/util/ObjectIdentifier;
putfield com.sun.crypto.provider.PBES2Parameters.kdfAlgo_OID:Lsun/security/util/ObjectIdentifier;
20: getstatic com.sun.crypto.provider.PBES2Parameters.hmacWithSHA1_OID:Lsun/security/util/ObjectIdentifier;
aload 0
getfield com.sun.crypto.provider.PBES2Parameters.kdfAlgo_OID:Lsun/security/util/ObjectIdentifier;
invokevirtual sun.security.util.ObjectIdentifier.equals:(Lsun/security/util/ObjectIdentifier;)Z
ifeq 23
21: ldc "HmacSHA1"
astore 2
22: goto 36
StackMap locals: sun.security.util.DerValue
StackMap stack:
23: getstatic com.sun.crypto.provider.PBES2Parameters.hmacWithSHA224_OID:Lsun/security/util/ObjectIdentifier;
aload 0
getfield com.sun.crypto.provider.PBES2Parameters.kdfAlgo_OID:Lsun/security/util/ObjectIdentifier;
invokevirtual sun.security.util.ObjectIdentifier.equals:(Lsun/security/util/ObjectIdentifier;)Z
ifeq 26
24: ldc "HmacSHA224"
astore 2
25: goto 36
StackMap locals:
StackMap stack:
26: getstatic com.sun.crypto.provider.PBES2Parameters.hmacWithSHA256_OID:Lsun/security/util/ObjectIdentifier;
aload 0
getfield com.sun.crypto.provider.PBES2Parameters.kdfAlgo_OID:Lsun/security/util/ObjectIdentifier;
invokevirtual sun.security.util.ObjectIdentifier.equals:(Lsun/security/util/ObjectIdentifier;)Z
ifeq 29
27: ldc "HmacSHA256"
astore 2
28: goto 36
StackMap locals:
StackMap stack:
29: getstatic com.sun.crypto.provider.PBES2Parameters.hmacWithSHA384_OID:Lsun/security/util/ObjectIdentifier;
aload 0
getfield com.sun.crypto.provider.PBES2Parameters.kdfAlgo_OID:Lsun/security/util/ObjectIdentifier;
invokevirtual sun.security.util.ObjectIdentifier.equals:(Lsun/security/util/ObjectIdentifier;)Z
ifeq 32
30: ldc "HmacSHA384"
astore 2
31: goto 36
StackMap locals:
StackMap stack:
32: getstatic com.sun.crypto.provider.PBES2Parameters.hmacWithSHA512_OID:Lsun/security/util/ObjectIdentifier;
aload 0
getfield com.sun.crypto.provider.PBES2Parameters.kdfAlgo_OID:Lsun/security/util/ObjectIdentifier;
invokevirtual sun.security.util.ObjectIdentifier.equals:(Lsun/security/util/ObjectIdentifier;)Z
ifeq 35
33: ldc "HmacSHA512"
astore 2
34: goto 36
35: StackMap locals:
StackMap stack:
new java.io.IOException
dup
ldc "PBE parameter parsing error: expecting the object identifier for a HmacSHA key derivation function"
invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
athrow
36: StackMap locals:
StackMap stack:
aload 6
getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
invokevirtual sun.security.util.DerInputStream.available:()I
ifeq 40
37: aload 6
getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
invokevirtual sun.security.util.DerInputStream.getDerValue:()Lsun/security/util/DerValue;
astore 7
start local 7 38: aload 7
getfield sun.security.util.DerValue.tag:B
iconst_5
if_icmpeq 40
39: 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 end local 6 40: StackMap locals:
StackMap stack:
aload 2
areturn
end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 41 0 this Lcom/sun/crypto/provider/PBES2Parameters;
0 41 1 keyDerivationFunc Lsun/security/util/DerValue;
1 41 2 kdfAlgo Ljava/lang/String;
6 41 3 pBKDF2_params Lsun/security/util/DerValue;
9 41 4 specified Lsun/security/util/DerValue;
15 41 5 keyLength Lsun/security/util/DerValue;
19 40 6 prf Lsun/security/util/DerValue;
38 40 7 parameter Lsun/security/util/DerValue;
Exceptions:
throws java.io.IOException
MethodParameters:
Name Flags
keyDerivationFunc
private java.lang.String parseES(sun.security.util.DerValue);
descriptor: (Lsun/security/util/DerValue;)Ljava/lang/String;
flags: (0x0002) ACC_PRIVATE
Code:
stack=4, locals=3, args_size=2
start local 0 start local 1 0: aconst_null
astore 2
start local 2 1: aload 0
aload 1
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: getstatic com.sun.crypto.provider.PBES2Parameters.aes128CBC_OID:Lsun/security/util/ObjectIdentifier;
aload 0
getfield com.sun.crypto.provider.PBES2Parameters.cipherAlgo_OID:Lsun/security/util/ObjectIdentifier;
invokevirtual sun.security.util.ObjectIdentifier.equals:(Lsun/security/util/ObjectIdentifier;)Z
ifeq 9
3: ldc "AES_128"
astore 2
4: aload 0
5: new javax.crypto.spec.IvParameterSpec
dup
aload 1
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: putfield com.sun.crypto.provider.PBES2Parameters.cipherParam:Ljava/security/spec/AlgorithmParameterSpec;
7: aload 0
sipush 128
putfield com.sun.crypto.provider.PBES2Parameters.keysize:I
8: goto 17
StackMap locals: java.lang.String
StackMap stack:
9: getstatic com.sun.crypto.provider.PBES2Parameters.aes256CBC_OID:Lsun/security/util/ObjectIdentifier;
aload 0
getfield com.sun.crypto.provider.PBES2Parameters.cipherAlgo_OID:Lsun/security/util/ObjectIdentifier;
invokevirtual sun.security.util.ObjectIdentifier.equals:(Lsun/security/util/ObjectIdentifier;)Z
ifeq 16
10: ldc "AES_256"
astore 2
11: aload 0
12: new javax.crypto.spec.IvParameterSpec
dup
aload 1
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: putfield com.sun.crypto.provider.PBES2Parameters.cipherParam:Ljava/security/spec/AlgorithmParameterSpec;
14: aload 0
sipush 256
putfield com.sun.crypto.provider.PBES2Parameters.keysize:I
15: goto 17
16: 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: StackMap locals:
StackMap stack:
aload 2
areturn
end local 2 end local 1 end local 0 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 start local 1 start local 2 0: aload 0
aload 1
invokevirtual com.sun.crypto.provider.PBES2Parameters.engineInit:([B)V
1: return
end local 2 end local 1 end local 0 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 start local 1 0: ldc Ljavax/crypto/spec/PBEParameterSpec;
aload 1
invokevirtual java.lang.Class.isAssignableFrom:(Ljava/lang/Class;)Z
ifeq 4
1: aload 1
2: new com.sun.crypto.spec.PBE2ParameterSpec
dup
aload 0
getfield com.sun.crypto.provider.PBES2Parameters.salt:[B
aload 0
getfield com.sun.crypto.provider.PBES2Parameters.iCount:I
aload 0
getfield com.sun.crypto.provider.PBES2Parameters.cipherParam:Ljava/security/spec/AlgorithmParameterSpec;
invokespecial com.sun.crypto.spec.PBE2ParameterSpec.<init>:([BILjava/security/spec/AlgorithmParameterSpec;)V
3: invokevirtual java.lang.Class.cast:(Ljava/lang/Object;)Ljava/lang/Object;
checkcast java.security.spec.AlgorithmParameterSpec
areturn
4: StackMap locals:
StackMap stack:
new java.security.spec.InvalidParameterSpecException
dup
5: ldc "Inappropriate parameter specification"
6: invokespecial java.security.spec.InvalidParameterSpecException.<init>:(Ljava/lang/String;)V
athrow
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 7 0 this Lcom/sun/crypto/provider/PBES2Parameters;
0 7 1 paramSpec Ljava/lang/Class<TT;>;
Exceptions:
throws java.security.spec.InvalidParameterSpecException
Signature: <T::Ljava/security/spec/AlgorithmParameterSpec;>(Ljava/lang/Class<TT;>;)TT;
MethodParameters:
Name Flags
paramSpec
protected byte[] engineGetEncoded();
descriptor: ()[B
flags: (0x0004) ACC_PROTECTED
Code:
stack=3, locals=8, args_size=1
start local 0 0: new sun.security.util.DerOutputStream
dup
invokespecial sun.security.util.DerOutputStream.<init>:()V
astore 1
start local 1 1: new sun.security.util.DerOutputStream
dup
invokespecial sun.security.util.DerOutputStream.<init>:()V
astore 2
start local 2 2: aload 2
getstatic com.sun.crypto.provider.PBES2Parameters.pkcs5PBES2_OID:Lsun/security/util/ObjectIdentifier;
invokevirtual sun.security.util.DerOutputStream.putOID:(Lsun/security/util/ObjectIdentifier;)V
3: new sun.security.util.DerOutputStream
dup
invokespecial sun.security.util.DerOutputStream.<init>:()V
astore 3
start local 3 4: new sun.security.util.DerOutputStream
dup
invokespecial sun.security.util.DerOutputStream.<init>:()V
astore 4
start local 4 5: aload 4
getstatic com.sun.crypto.provider.PBES2Parameters.pkcs5PBKDF2_OID:Lsun/security/util/ObjectIdentifier;
invokevirtual sun.security.util.DerOutputStream.putOID:(Lsun/security/util/ObjectIdentifier;)V
6: new sun.security.util.DerOutputStream
dup
invokespecial sun.security.util.DerOutputStream.<init>:()V
astore 5
start local 5 7: aload 5
aload 0
getfield com.sun.crypto.provider.PBES2Parameters.salt:[B
invokevirtual sun.security.util.DerOutputStream.putOctetString:([B)V
8: aload 5
aload 0
getfield com.sun.crypto.provider.PBES2Parameters.iCount:I
invokevirtual sun.security.util.DerOutputStream.putInteger:(I)V
9: aload 5
aload 0
getfield com.sun.crypto.provider.PBES2Parameters.keysize:I
bipush 8
idiv
invokevirtual sun.security.util.DerOutputStream.putInteger:(I)V
10: new sun.security.util.DerOutputStream
dup
invokespecial sun.security.util.DerOutputStream.<init>:()V
astore 6
start local 6 11: aload 6
aload 0
getfield com.sun.crypto.provider.PBES2Parameters.kdfAlgo_OID:Lsun/security/util/ObjectIdentifier;
invokevirtual sun.security.util.DerOutputStream.putOID:(Lsun/security/util/ObjectIdentifier;)V
12: aload 6
invokevirtual sun.security.util.DerOutputStream.putNull:()V
13: aload 5
bipush 48
aload 6
invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
14: aload 4
bipush 48
aload 5
invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
15: aload 3
bipush 48
aload 4
invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
16: new sun.security.util.DerOutputStream
dup
invokespecial sun.security.util.DerOutputStream.<init>:()V
astore 7
start local 7 17: aload 7
aload 0
getfield com.sun.crypto.provider.PBES2Parameters.cipherAlgo_OID:Lsun/security/util/ObjectIdentifier;
invokevirtual sun.security.util.DerOutputStream.putOID:(Lsun/security/util/ObjectIdentifier;)V
18: aload 0
getfield com.sun.crypto.provider.PBES2Parameters.cipherParam:Ljava/security/spec/AlgorithmParameterSpec;
ifnull 23
aload 0
getfield com.sun.crypto.provider.PBES2Parameters.cipherParam:Ljava/security/spec/AlgorithmParameterSpec;
instanceof javax.crypto.spec.IvParameterSpec
ifeq 23
19: aload 7
20: aload 0
getfield com.sun.crypto.provider.PBES2Parameters.cipherParam:Ljava/security/spec/AlgorithmParameterSpec;
checkcast javax.crypto.spec.IvParameterSpec
invokevirtual javax.crypto.spec.IvParameterSpec.getIV:()[B
21: invokevirtual sun.security.util.DerOutputStream.putOctetString:([B)V
22: goto 24
23: StackMap locals: com.sun.crypto.provider.PBES2Parameters sun.security.util.DerOutputStream sun.security.util.DerOutputStream sun.security.util.DerOutputStream sun.security.util.DerOutputStream sun.security.util.DerOutputStream sun.security.util.DerOutputStream sun.security.util.DerOutputStream
StackMap stack:
new java.io.IOException
dup
ldc "Wrong parameter type: IV expected"
invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
athrow
24: StackMap locals:
StackMap stack:
aload 3
bipush 48
aload 7
invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
25: aload 2
bipush 48
aload 3
invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
26: aload 1
bipush 48
aload 2
invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
27: aload 1
invokevirtual sun.security.util.DerOutputStream.toByteArray:()[B
areturn
end local 7 end local 6 end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 28 0 this Lcom/sun/crypto/provider/PBES2Parameters;
1 28 1 out Lsun/security/util/DerOutputStream;
2 28 2 pBES2Algorithms Lsun/security/util/DerOutputStream;
4 28 3 pBES2_params Lsun/security/util/DerOutputStream;
5 28 4 keyDerivationFunc Lsun/security/util/DerOutputStream;
7 28 5 pBKDF2_params Lsun/security/util/DerOutputStream;
11 28 6 prf Lsun/security/util/DerOutputStream;
17 28 7 encryptionScheme Lsun/security/util/DerOutputStream;
Exceptions:
throws java.io.IOException
protected byte[] engineGetEncoded(java.lang.String);
descriptor: (Ljava/lang/String;)[B
flags: (0x0004) ACC_PROTECTED
Code:
stack=1, locals=2, args_size=2
start local 0 start local 1 0: aload 0
invokevirtual com.sun.crypto.provider.PBES2Parameters.engineGetEncoded:()[B
areturn
end local 1 end local 0 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 0: aload 0
getfield com.sun.crypto.provider.PBES2Parameters.pbes2AlgorithmName:Ljava/lang/String;
areturn
end local 0 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