public final class com.sun.crypto.provider.AESKeyGenerator extends javax.crypto.KeyGeneratorSpi
minor version: 0
major version: 59
flags: flags: (0x0031) ACC_PUBLIC, ACC_FINAL, ACC_SUPER
this_class: com.sun.crypto.provider.AESKeyGenerator
super_class: javax.crypto.KeyGeneratorSpi
{
private java.security.SecureRandom random;
descriptor: Ljava/security/SecureRandom;
flags: (0x0002) ACC_PRIVATE
private int keySize;
descriptor: I
flags: (0x0002) ACC_PRIVATE
public void <init>();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=1, args_size=1
start local 0 0: aload 0
invokespecial javax.crypto.KeyGeneratorSpi.<init>:()V
1: aload 0
aconst_null
putfield com.sun.crypto.provider.AESKeyGenerator.random:Ljava/security/SecureRandom;
2: aload 0
bipush 16
putfield com.sun.crypto.provider.AESKeyGenerator.keySize:I
3: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lcom/sun/crypto/provider/AESKeyGenerator;
protected void engineInit(java.security.SecureRandom);
descriptor: (Ljava/security/SecureRandom;)V
flags: (0x0004) ACC_PROTECTED
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
aload 1
putfield com.sun.crypto.provider.AESKeyGenerator.random:Ljava/security/SecureRandom;
1: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lcom/sun/crypto/provider/AESKeyGenerator;
0 2 1 random Ljava/security/SecureRandom;
MethodParameters:
Name Flags
random
protected void engineInit(java.security.spec.AlgorithmParameterSpec, java.security.SecureRandom);
descriptor: (Ljava/security/spec/AlgorithmParameterSpec;Ljava/security/SecureRandom;)V
flags: (0x0004) ACC_PROTECTED
Code:
stack=3, locals=3, args_size=3
start local 0 start local 1 start local 2 0: new java.security.InvalidAlgorithmParameterException
dup
1: ldc "AES key generation does not take any parameters"
2: invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
athrow
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lcom/sun/crypto/provider/AESKeyGenerator;
0 3 1 params Ljava/security/spec/AlgorithmParameterSpec;
0 3 2 random Ljava/security/SecureRandom;
Exceptions:
throws java.security.InvalidAlgorithmParameterException
MethodParameters:
Name Flags
params
random
protected void engineInit(int, java.security.SecureRandom);
descriptor: (ILjava/security/SecureRandom;)V
flags: (0x0004) ACC_PROTECTED
Code:
stack=3, locals=3, args_size=3
start local 0 start local 1 start local 2 0: iload 1
bipush 8
irem
ifne 2
1: iload 1
bipush 8
idiv
invokestatic com.sun.crypto.provider.AESCrypt.isKeySizeValid:(I)Z
ifne 5
2: StackMap locals:
StackMap stack:
new java.security.InvalidParameterException
dup
3: ldc "Wrong keysize: must be equal to 128, 192 or 256"
4: invokespecial java.security.InvalidParameterException.<init>:(Ljava/lang/String;)V
athrow
5: StackMap locals:
StackMap stack:
aload 0
iload 1
bipush 8
idiv
putfield com.sun.crypto.provider.AESKeyGenerator.keySize:I
6: aload 0
aload 2
invokevirtual com.sun.crypto.provider.AESKeyGenerator.engineInit:(Ljava/security/SecureRandom;)V
7: return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 8 0 this Lcom/sun/crypto/provider/AESKeyGenerator;
0 8 1 keysize I
0 8 2 random Ljava/security/SecureRandom;
MethodParameters:
Name Flags
keysize
random
protected javax.crypto.SecretKey engineGenerateKey();
descriptor: ()Ljavax/crypto/SecretKey;
flags: (0x0004) ACC_PROTECTED
Code:
stack=4, locals=3, args_size=1
start local 0 0: aconst_null
astore 1
start local 1 1: aload 0
getfield com.sun.crypto.provider.AESKeyGenerator.random:Ljava/security/SecureRandom;
ifnonnull 3
2: aload 0
invokestatic com.sun.crypto.provider.SunJCE.getRandom:()Ljava/security/SecureRandom;
putfield com.sun.crypto.provider.AESKeyGenerator.random:Ljava/security/SecureRandom;
3: StackMap locals: javax.crypto.spec.SecretKeySpec
StackMap stack:
aload 0
getfield com.sun.crypto.provider.AESKeyGenerator.keySize:I
newarray 8
astore 2
start local 2 4: aload 0
getfield com.sun.crypto.provider.AESKeyGenerator.random:Ljava/security/SecureRandom;
aload 2
invokevirtual java.security.SecureRandom.nextBytes:([B)V
5: new javax.crypto.spec.SecretKeySpec
dup
aload 2
ldc "AES"
invokespecial javax.crypto.spec.SecretKeySpec.<init>:([BLjava/lang/String;)V
astore 1
6: aload 1
areturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 7 0 this Lcom/sun/crypto/provider/AESKeyGenerator;
1 7 1 aesKey Ljavax/crypto/spec/SecretKeySpec;
4 7 2 keyBytes [B
}
SourceFile: "AESKeyGenerator.java"