public final class java.security.KeyStore$PrivateKeyEntry implements java.security.KeyStore$Entry
minor version: 0
major version: 59
flags: flags: (0x0031) ACC_PUBLIC, ACC_FINAL, ACC_SUPER
this_class: java.security.KeyStore$PrivateKeyEntry
super_class: java.lang.Object
{
private final java.security.PrivateKey privKey;
descriptor: Ljava/security/PrivateKey;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final java.security.cert.Certificate[] chain;
descriptor: [Ljava/security/cert/Certificate;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
public void <init>(java.security.PrivateKey, java.security.cert.Certificate[]);
descriptor: (Ljava/security/PrivateKey;[Ljava/security/cert/Certificate;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=5, locals=6, args_size=3
start local 0 start local 1 start local 2 0: aload 0
invokespecial java.lang.Object.<init>:()V
1: aload 1
ifnull 2
aload 2
ifnonnull 3
2: StackMap locals: java.security.KeyStore$PrivateKeyEntry java.security.PrivateKey java.security.cert.Certificate[]
StackMap stack:
new java.lang.NullPointerException
dup
ldc "invalid null input"
invokespecial java.lang.NullPointerException.<init>:(Ljava/lang/String;)V
athrow
3: StackMap locals:
StackMap stack:
aload 2
arraylength
ifne 7
4: new java.lang.IllegalArgumentException
dup
5: ldc "invalid zero-length input chain"
6: invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
athrow
7: StackMap locals:
StackMap stack:
aload 2
invokevirtual java.security.cert.Certificate[].clone:()Ljava/lang/Object;
checkcast java.security.cert.Certificate[]
astore 3
start local 3 8: aload 3
iconst_0
aaload
invokevirtual java.security.cert.Certificate.getType:()Ljava/lang/String;
astore 4
start local 4 9: iconst_1
istore 5
start local 5 10: goto 16
11: StackMap locals: java.security.cert.Certificate[] java.lang.String int
StackMap stack:
aload 4
aload 3
iload 5
aaload
invokevirtual java.security.cert.Certificate.getType:()Ljava/lang/String;
invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
ifne 15
12: new java.lang.IllegalArgumentException
dup
13: ldc "chain does not contain certificates of the same type"
14: invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
athrow
15: StackMap locals:
StackMap stack:
iinc 5 1
StackMap locals:
StackMap stack:
16: iload 5
aload 3
arraylength
if_icmplt 11
end local 5 17: aload 1
invokeinterface java.security.PrivateKey.getAlgorithm:()Ljava/lang/String;
18: aload 3
iconst_0
aaload
invokevirtual java.security.cert.Certificate.getPublicKey:()Ljava/security/PublicKey;
invokeinterface java.security.PublicKey.getAlgorithm:()Ljava/lang/String;
19: invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
20: ifne 24
21: new java.lang.IllegalArgumentException
dup
22: ldc "private key algorithm does not match algorithm of public key in end entity certificate (at index 0)"
23: invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
athrow
24: StackMap locals:
StackMap stack:
aload 0
aload 1
putfield java.security.KeyStore$PrivateKeyEntry.privKey:Ljava/security/PrivateKey;
25: aload 3
iconst_0
aaload
instanceof java.security.cert.X509Certificate
ifeq 32
26: aload 3
instanceof java.security.cert.X509Certificate[]
ifne 32
27: aload 0
aload 3
arraylength
anewarray java.security.cert.X509Certificate
putfield java.security.KeyStore$PrivateKeyEntry.chain:[Ljava/security/cert/Certificate;
28: aload 3
iconst_0
29: aload 0
getfield java.security.KeyStore$PrivateKeyEntry.chain:[Ljava/security/cert/Certificate;
iconst_0
aload 3
arraylength
30: invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
31: goto 33
32: StackMap locals:
StackMap stack:
aload 0
aload 3
putfield java.security.KeyStore$PrivateKeyEntry.chain:[Ljava/security/cert/Certificate;
33: 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 34 0 this Ljava/security/KeyStore$PrivateKeyEntry;
0 34 1 privateKey Ljava/security/PrivateKey;
0 34 2 chain [Ljava/security/cert/Certificate;
8 34 3 clonedChain [Ljava/security/cert/Certificate;
9 34 4 certType Ljava/lang/String;
10 17 5 i I
MethodParameters:
Name Flags
privateKey
chain
public java.security.PrivateKey getPrivateKey();
descriptor: ()Ljava/security/PrivateKey;
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield java.security.KeyStore$PrivateKeyEntry.privKey:Ljava/security/PrivateKey;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Ljava/security/KeyStore$PrivateKeyEntry;
public java.security.cert.Certificate[] getCertificateChain();
descriptor: ()[Ljava/security/cert/Certificate;
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield java.security.KeyStore$PrivateKeyEntry.chain:[Ljava/security/cert/Certificate;
invokevirtual java.security.cert.Certificate[].clone:()Ljava/lang/Object;
checkcast java.security.cert.Certificate[]
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Ljava/security/KeyStore$PrivateKeyEntry;
public java.security.cert.Certificate getCertificate();
descriptor: ()Ljava/security/cert/Certificate;
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=1, args_size=1
start local 0 0: aload 0
getfield java.security.KeyStore$PrivateKeyEntry.chain:[Ljava/security/cert/Certificate;
iconst_0
aaload
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Ljava/security/KeyStore$PrivateKeyEntry;
public java.lang.String toString();
descriptor: ()Ljava/lang/String;
flags: (0x0001) ACC_PUBLIC
Code:
stack=4, locals=6, args_size=1
start local 0 0: new java.lang.StringBuilder
dup
invokespecial java.lang.StringBuilder.<init>:()V
astore 1
start local 1 1: aload 1
new java.lang.StringBuilder
dup
ldc "Private key entry and certificate chain with "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
2: aload 0
getfield java.security.KeyStore$PrivateKeyEntry.chain:[Ljava/security/cert/Certificate;
arraylength
invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
ldc " elements:\r\n"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
3: invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
pop
4: aload 0
getfield java.security.KeyStore$PrivateKeyEntry.chain:[Ljava/security/cert/Certificate;
dup
astore 5
arraylength
istore 4
iconst_0
istore 3
goto 9
StackMap locals: java.security.KeyStore$PrivateKeyEntry java.lang.StringBuilder top int int java.security.cert.Certificate[]
StackMap stack:
5: aload 5
iload 3
aaload
astore 2
start local 2 6: aload 1
aload 2
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
pop
7: aload 1
ldc "\r\n"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
pop
end local 2 8: iinc 3 1
StackMap locals:
StackMap stack:
9: iload 3
iload 4
if_icmplt 5
10: aload 1
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 11 0 this Ljava/security/KeyStore$PrivateKeyEntry;
1 11 1 sb Ljava/lang/StringBuilder;
6 8 2 cert Ljava/security/cert/Certificate;
}
SourceFile: "KeyStore.java"
NestHost: java.security.KeyStore
InnerClasses:
public abstract Entry = java.security.KeyStore$Entry of java.security.KeyStore
public final PrivateKeyEntry = java.security.KeyStore$PrivateKeyEntry of java.security.KeyStore