public final class sun.security.rsa.RSAPrivateCrtKeyImpl extends sun.security.pkcs.PKCS8Key implements java.security.interfaces.RSAPrivateCrtKey
minor version: 0
major version: 59
flags: flags: (0x0031) ACC_PUBLIC, ACC_FINAL, ACC_SUPER
this_class: sun.security.rsa.RSAPrivateCrtKeyImpl
super_class: sun.security.pkcs.PKCS8Key
{
private static final long serialVersionUID;
descriptor: J
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
ConstantValue: -1326088454257084918
private java.math.BigInteger n;
descriptor: Ljava/math/BigInteger;
flags: (0x0002) ACC_PRIVATE
private java.math.BigInteger e;
descriptor: Ljava/math/BigInteger;
flags: (0x0002) ACC_PRIVATE
private java.math.BigInteger d;
descriptor: Ljava/math/BigInteger;
flags: (0x0002) ACC_PRIVATE
private java.math.BigInteger p;
descriptor: Ljava/math/BigInteger;
flags: (0x0002) ACC_PRIVATE
private java.math.BigInteger q;
descriptor: Ljava/math/BigInteger;
flags: (0x0002) ACC_PRIVATE
private java.math.BigInteger pe;
descriptor: Ljava/math/BigInteger;
flags: (0x0002) ACC_PRIVATE
private java.math.BigInteger qe;
descriptor: Ljava/math/BigInteger;
flags: (0x0002) ACC_PRIVATE
private java.math.BigInteger coeff;
descriptor: Ljava/math/BigInteger;
flags: (0x0002) ACC_PRIVATE
private transient sun.security.rsa.RSAUtil$KeyType type;
descriptor: Lsun/security/rsa/RSAUtil$KeyType;
flags: (0x0082) ACC_PRIVATE, ACC_TRANSIENT
private transient java.security.spec.AlgorithmParameterSpec keyParams;
descriptor: Ljava/security/spec/AlgorithmParameterSpec;
flags: (0x0082) ACC_PRIVATE, ACC_TRANSIENT
public static java.security.interfaces.RSAPrivateKey newKey(byte[]);
descriptor: ([B)Ljava/security/interfaces/RSAPrivateKey;
flags: (0x0009) ACC_PUBLIC, ACC_STATIC
Code:
stack=6, locals=2, args_size=1
start local 0 0: aload 0
ifnull 1
aload 0
arraylength
ifne 2
1: StackMap locals:
StackMap stack:
new java.security.InvalidKeyException
dup
ldc "Missing key encoding"
invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;)V
athrow
2: StackMap locals:
StackMap stack:
new sun.security.rsa.RSAPrivateCrtKeyImpl
dup
aload 0
invokespecial sun.security.rsa.RSAPrivateCrtKeyImpl.<init>:([B)V
astore 1
start local 1 3: aload 1
invokevirtual sun.security.rsa.RSAPrivateCrtKeyImpl.getPublicExponent:()Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.signum:()I
ifeq 9
4: aload 1
invokevirtual sun.security.rsa.RSAPrivateCrtKeyImpl.getPrimeExponentP:()Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.signum:()I
ifeq 9
5: aload 1
invokevirtual sun.security.rsa.RSAPrivateCrtKeyImpl.getPrimeExponentQ:()Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.signum:()I
ifeq 9
6: aload 1
invokevirtual sun.security.rsa.RSAPrivateCrtKeyImpl.getPrimeP:()Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.signum:()I
ifeq 9
7: aload 1
invokevirtual sun.security.rsa.RSAPrivateCrtKeyImpl.getPrimeQ:()Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.signum:()I
ifeq 9
8: aload 1
invokevirtual sun.security.rsa.RSAPrivateCrtKeyImpl.getCrtCoefficient:()Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.signum:()I
ifne 14
9: StackMap locals: sun.security.rsa.RSAPrivateCrtKeyImpl
StackMap stack:
new sun.security.rsa.RSAPrivateKeyImpl
dup
10: aload 1
getfield sun.security.rsa.RSAPrivateCrtKeyImpl.type:Lsun/security/rsa/RSAUtil$KeyType;
aload 1
getfield sun.security.rsa.RSAPrivateCrtKeyImpl.keyParams:Ljava/security/spec/AlgorithmParameterSpec;
11: aload 1
invokevirtual sun.security.rsa.RSAPrivateCrtKeyImpl.getModulus:()Ljava/math/BigInteger;
12: aload 1
invokevirtual sun.security.rsa.RSAPrivateCrtKeyImpl.getPrivateExponent:()Ljava/math/BigInteger;
13: invokespecial sun.security.rsa.RSAPrivateKeyImpl.<init>:(Lsun/security/rsa/RSAUtil$KeyType;Ljava/security/spec/AlgorithmParameterSpec;Ljava/math/BigInteger;Ljava/math/BigInteger;)V
areturn
14: StackMap locals:
StackMap stack:
aload 1
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 15 0 encoded [B
3 15 1 key Lsun/security/rsa/RSAPrivateCrtKeyImpl;
Exceptions:
throws java.security.InvalidKeyException
MethodParameters:
Name Flags
encoded
public static java.security.interfaces.RSAPrivateKey newKey(sun.security.rsa.RSAUtil$KeyType, java.security.spec.AlgorithmParameterSpec, java.math.BigInteger, java.math.BigInteger, java.math.BigInteger, java.math.BigInteger, java.math.BigInteger, java.math.BigInteger, java.math.BigInteger, java.math.BigInteger);
descriptor: (Lsun/security/rsa/RSAUtil$KeyType;Ljava/security/spec/AlgorithmParameterSpec;Ljava/math/BigInteger;Ljava/math/BigInteger;Ljava/math/BigInteger;Ljava/math/BigInteger;Ljava/math/BigInteger;Ljava/math/BigInteger;Ljava/math/BigInteger;Ljava/math/BigInteger;)Ljava/security/interfaces/RSAPrivateKey;
flags: (0x0009) ACC_PUBLIC, ACC_STATIC
Code:
stack=12, locals=10, args_size=10
start local 0 start local 1 start local 2 start local 3 start local 4 start local 5 start local 6 start local 7 start local 8 start local 9 0: aload 3
invokevirtual java.math.BigInteger.signum:()I
ifeq 3
aload 5
invokevirtual java.math.BigInteger.signum:()I
ifeq 3
1: aload 6
invokevirtual java.math.BigInteger.signum:()I
ifeq 3
aload 7
invokevirtual java.math.BigInteger.signum:()I
ifeq 3
2: aload 8
invokevirtual java.math.BigInteger.signum:()I
ifeq 3
aload 9
invokevirtual java.math.BigInteger.signum:()I
ifne 4
3: StackMap locals:
StackMap stack:
new sun.security.rsa.RSAPrivateKeyImpl
dup
aload 0
aload 1
aload 2
aload 4
invokespecial sun.security.rsa.RSAPrivateKeyImpl.<init>:(Lsun/security/rsa/RSAUtil$KeyType;Ljava/security/spec/AlgorithmParameterSpec;Ljava/math/BigInteger;Ljava/math/BigInteger;)V
areturn
4: StackMap locals:
StackMap stack:
new sun.security.rsa.RSAPrivateCrtKeyImpl
dup
aload 0
aload 1
aload 2
aload 3
aload 4
5: aload 5
aload 6
aload 7
aload 8
aload 9
6: invokespecial sun.security.rsa.RSAPrivateCrtKeyImpl.<init>:(Lsun/security/rsa/RSAUtil$KeyType;Ljava/security/spec/AlgorithmParameterSpec;Ljava/math/BigInteger;Ljava/math/BigInteger;Ljava/math/BigInteger;Ljava/math/BigInteger;Ljava/math/BigInteger;Ljava/math/BigInteger;Ljava/math/BigInteger;Ljava/math/BigInteger;)V
areturn
end local 9 end local 8 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 7 0 type Lsun/security/rsa/RSAUtil$KeyType;
0 7 1 params Ljava/security/spec/AlgorithmParameterSpec;
0 7 2 n Ljava/math/BigInteger;
0 7 3 e Ljava/math/BigInteger;
0 7 4 d Ljava/math/BigInteger;
0 7 5 p Ljava/math/BigInteger;
0 7 6 q Ljava/math/BigInteger;
0 7 7 pe Ljava/math/BigInteger;
0 7 8 qe Ljava/math/BigInteger;
0 7 9 coeff Ljava/math/BigInteger;
Exceptions:
throws java.security.InvalidKeyException
MethodParameters:
Name Flags
type
params
n
e
d
p
q
pe
qe
coeff
void <init>(byte[]);
descriptor: ([B)V
flags: (0x0000)
Code:
stack=3, locals=3, args_size=2
start local 0 start local 1 0: aload 0
aload 1
invokespecial sun.security.pkcs.PKCS8Key.<init>:([B)V
1: aload 0
invokevirtual sun.security.rsa.RSAPrivateCrtKeyImpl.parseKeyBits:()V
2: aload 0
getfield sun.security.rsa.RSAPrivateCrtKeyImpl.n:Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.bitLength:()I
aload 0
getfield sun.security.rsa.RSAPrivateCrtKeyImpl.e:Ljava/math/BigInteger;
invokestatic sun.security.rsa.RSAKeyFactory.checkRSAProviderKeyLengths:(ILjava/math/BigInteger;)V
3: aload 0
getfield sun.security.rsa.RSAPrivateCrtKeyImpl.algid:Lsun/security/x509/AlgorithmId;
invokestatic sun.security.rsa.RSAUtil.getTypeAndParamSpec:(Lsun/security/x509/AlgorithmId;)[Ljava/lang/Object;
astore 2
start local 2 4: aload 0
aload 2
iconst_0
aaload
checkcast sun.security.rsa.RSAUtil$KeyType
putfield sun.security.rsa.RSAPrivateCrtKeyImpl.type:Lsun/security/rsa/RSAUtil$KeyType;
5: aload 0
aload 2
iconst_1
aaload
checkcast java.security.spec.AlgorithmParameterSpec
putfield sun.security.rsa.RSAPrivateCrtKeyImpl.keyParams:Ljava/security/spec/AlgorithmParameterSpec;
end local 2 6: goto 9
StackMap locals: sun.security.rsa.RSAPrivateCrtKeyImpl byte[]
StackMap stack: java.security.ProviderException
7: astore 2
start local 2 8: new java.security.InvalidKeyException
dup
aload 2
invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/Throwable;)V
athrow
end local 2 9: StackMap locals:
StackMap stack:
return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 10 0 this Lsun/security/rsa/RSAPrivateCrtKeyImpl;
0 10 1 encoded [B
4 6 2 o [Ljava/lang/Object;
8 9 2 e Ljava/security/ProviderException;
Exception table:
from to target type
3 6 7 Class java.security.ProviderException
Exceptions:
throws java.security.InvalidKeyException
MethodParameters:
Name Flags
encoded
void <init>(sun.security.rsa.RSAUtil$KeyType, java.security.spec.AlgorithmParameterSpec, java.math.BigInteger, java.math.BigInteger, java.math.BigInteger, java.math.BigInteger, java.math.BigInteger, java.math.BigInteger, java.math.BigInteger, java.math.BigInteger);
descriptor: (Lsun/security/rsa/RSAUtil$KeyType;Ljava/security/spec/AlgorithmParameterSpec;Ljava/math/BigInteger;Ljava/math/BigInteger;Ljava/math/BigInteger;Ljava/math/BigInteger;Ljava/math/BigInteger;Ljava/math/BigInteger;Ljava/math/BigInteger;Ljava/math/BigInteger;)V
flags: (0x0000)
Code:
stack=4, locals=13, args_size=11
start local 0 start local 1 start local 2 start local 3 start local 4 start local 5 start local 6 start local 7 start local 8 start local 9 start local 10 0: aload 0
invokespecial sun.security.pkcs.PKCS8Key.<init>:()V
1: aload 3
invokevirtual java.math.BigInteger.bitLength:()I
aload 4
invokestatic sun.security.rsa.RSAKeyFactory.checkRSAProviderKeyLengths:(ILjava/math/BigInteger;)V
2: aload 0
aload 3
putfield sun.security.rsa.RSAPrivateCrtKeyImpl.n:Ljava/math/BigInteger;
3: aload 0
aload 4
putfield sun.security.rsa.RSAPrivateCrtKeyImpl.e:Ljava/math/BigInteger;
4: aload 0
aload 5
putfield sun.security.rsa.RSAPrivateCrtKeyImpl.d:Ljava/math/BigInteger;
5: aload 0
aload 6
putfield sun.security.rsa.RSAPrivateCrtKeyImpl.p:Ljava/math/BigInteger;
6: aload 0
aload 7
putfield sun.security.rsa.RSAPrivateCrtKeyImpl.q:Ljava/math/BigInteger;
7: aload 0
aload 8
putfield sun.security.rsa.RSAPrivateCrtKeyImpl.pe:Ljava/math/BigInteger;
8: aload 0
aload 9
putfield sun.security.rsa.RSAPrivateCrtKeyImpl.qe:Ljava/math/BigInteger;
9: aload 0
aload 10
putfield sun.security.rsa.RSAPrivateCrtKeyImpl.coeff:Ljava/math/BigInteger;
10: aload 0
aload 1
aload 2
invokestatic sun.security.rsa.RSAUtil.createAlgorithmId:(Lsun/security/rsa/RSAUtil$KeyType;Ljava/security/spec/AlgorithmParameterSpec;)Lsun/security/x509/AlgorithmId;
putfield sun.security.rsa.RSAPrivateCrtKeyImpl.algid:Lsun/security/x509/AlgorithmId;
11: goto 14
StackMap locals: sun.security.rsa.RSAPrivateCrtKeyImpl sun.security.rsa.RSAUtil$KeyType java.security.spec.AlgorithmParameterSpec java.math.BigInteger java.math.BigInteger java.math.BigInteger java.math.BigInteger java.math.BigInteger java.math.BigInteger java.math.BigInteger java.math.BigInteger
StackMap stack: java.security.ProviderException
12: astore 11
start local 11 13: new java.security.InvalidKeyException
dup
aload 11
invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/Throwable;)V
athrow
end local 11 14: StackMap locals:
StackMap stack:
aload 0
aload 1
putfield sun.security.rsa.RSAPrivateCrtKeyImpl.type:Lsun/security/rsa/RSAUtil$KeyType;
15: aload 0
aload 2
putfield sun.security.rsa.RSAPrivateCrtKeyImpl.keyParams:Ljava/security/spec/AlgorithmParameterSpec;
16: new sun.security.util.DerOutputStream
dup
invokespecial sun.security.util.DerOutputStream.<init>:()V
astore 11
start local 11 17: aload 11
iconst_0
invokevirtual sun.security.util.DerOutputStream.putInteger:(I)V
18: aload 11
aload 3
invokevirtual sun.security.util.DerOutputStream.putInteger:(Ljava/math/BigInteger;)V
19: aload 11
aload 4
invokevirtual sun.security.util.DerOutputStream.putInteger:(Ljava/math/BigInteger;)V
20: aload 11
aload 5
invokevirtual sun.security.util.DerOutputStream.putInteger:(Ljava/math/BigInteger;)V
21: aload 11
aload 6
invokevirtual sun.security.util.DerOutputStream.putInteger:(Ljava/math/BigInteger;)V
22: aload 11
aload 7
invokevirtual sun.security.util.DerOutputStream.putInteger:(Ljava/math/BigInteger;)V
23: aload 11
aload 8
invokevirtual sun.security.util.DerOutputStream.putInteger:(Ljava/math/BigInteger;)V
24: aload 11
aload 9
invokevirtual sun.security.util.DerOutputStream.putInteger:(Ljava/math/BigInteger;)V
25: aload 11
aload 10
invokevirtual sun.security.util.DerOutputStream.putInteger:(Ljava/math/BigInteger;)V
26: new sun.security.util.DerValue
dup
bipush 48
aload 11
invokevirtual sun.security.util.DerOutputStream.toByteArray:()[B
invokespecial sun.security.util.DerValue.<init>:(B[B)V
27: astore 12
start local 12 28: aload 0
aload 12
invokevirtual sun.security.util.DerValue.toByteArray:()[B
putfield sun.security.rsa.RSAPrivateCrtKeyImpl.key:[B
end local 12 end local 11 29: goto 32
StackMap locals:
StackMap stack: java.io.IOException
30: astore 11
start local 11 31: new java.security.InvalidKeyException
dup
aload 11
invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/Throwable;)V
athrow
end local 11 32: StackMap locals:
StackMap stack:
return
end local 10 end local 9 end local 8 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 33 0 this Lsun/security/rsa/RSAPrivateCrtKeyImpl;
0 33 1 type Lsun/security/rsa/RSAUtil$KeyType;
0 33 2 keyParams Ljava/security/spec/AlgorithmParameterSpec;
0 33 3 n Ljava/math/BigInteger;
0 33 4 e Ljava/math/BigInteger;
0 33 5 d Ljava/math/BigInteger;
0 33 6 p Ljava/math/BigInteger;
0 33 7 q Ljava/math/BigInteger;
0 33 8 pe Ljava/math/BigInteger;
0 33 9 qe Ljava/math/BigInteger;
0 33 10 coeff Ljava/math/BigInteger;
13 14 11 exc Ljava/security/ProviderException;
17 29 11 out Lsun/security/util/DerOutputStream;
28 29 12 val Lsun/security/util/DerValue;
31 32 11 exc Ljava/io/IOException;
Exception table:
from to target type
10 11 12 Class java.security.ProviderException
16 29 30 Class java.io.IOException
Exceptions:
throws java.security.InvalidKeyException
MethodParameters:
Name Flags
type
keyParams
n
e
d
p
q
pe
qe
coeff
public java.lang.String getAlgorithm();
descriptor: ()Ljava/lang/String;
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield sun.security.rsa.RSAPrivateCrtKeyImpl.type:Lsun/security/rsa/RSAUtil$KeyType;
getfield sun.security.rsa.RSAUtil$KeyType.keyAlgo:Ljava/lang/String;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lsun/security/rsa/RSAPrivateCrtKeyImpl;
public java.math.BigInteger getModulus();
descriptor: ()Ljava/math/BigInteger;
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield sun.security.rsa.RSAPrivateCrtKeyImpl.n:Ljava/math/BigInteger;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lsun/security/rsa/RSAPrivateCrtKeyImpl;
public java.math.BigInteger getPublicExponent();
descriptor: ()Ljava/math/BigInteger;
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield sun.security.rsa.RSAPrivateCrtKeyImpl.e:Ljava/math/BigInteger;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lsun/security/rsa/RSAPrivateCrtKeyImpl;
public java.math.BigInteger getPrivateExponent();
descriptor: ()Ljava/math/BigInteger;
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield sun.security.rsa.RSAPrivateCrtKeyImpl.d:Ljava/math/BigInteger;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lsun/security/rsa/RSAPrivateCrtKeyImpl;
public java.math.BigInteger getPrimeP();
descriptor: ()Ljava/math/BigInteger;
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield sun.security.rsa.RSAPrivateCrtKeyImpl.p:Ljava/math/BigInteger;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lsun/security/rsa/RSAPrivateCrtKeyImpl;
public java.math.BigInteger getPrimeQ();
descriptor: ()Ljava/math/BigInteger;
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield sun.security.rsa.RSAPrivateCrtKeyImpl.q:Ljava/math/BigInteger;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lsun/security/rsa/RSAPrivateCrtKeyImpl;
public java.math.BigInteger getPrimeExponentP();
descriptor: ()Ljava/math/BigInteger;
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield sun.security.rsa.RSAPrivateCrtKeyImpl.pe:Ljava/math/BigInteger;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lsun/security/rsa/RSAPrivateCrtKeyImpl;
public java.math.BigInteger getPrimeExponentQ();
descriptor: ()Ljava/math/BigInteger;
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield sun.security.rsa.RSAPrivateCrtKeyImpl.qe:Ljava/math/BigInteger;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lsun/security/rsa/RSAPrivateCrtKeyImpl;
public java.math.BigInteger getCrtCoefficient();
descriptor: ()Ljava/math/BigInteger;
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield sun.security.rsa.RSAPrivateCrtKeyImpl.coeff:Ljava/math/BigInteger;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lsun/security/rsa/RSAPrivateCrtKeyImpl;
public java.security.spec.AlgorithmParameterSpec getParams();
descriptor: ()Ljava/security/spec/AlgorithmParameterSpec;
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield sun.security.rsa.RSAPrivateCrtKeyImpl.keyParams:Ljava/security/spec/AlgorithmParameterSpec;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lsun/security/rsa/RSAPrivateCrtKeyImpl;
public java.lang.String toString();
descriptor: ()Ljava/lang/String;
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=1, args_size=1
start local 0 0: new java.lang.StringBuilder
dup
ldc "SunRsaSign "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 0
getfield sun.security.rsa.RSAPrivateCrtKeyImpl.type:Lsun/security/rsa/RSAUtil$KeyType;
getfield sun.security.rsa.RSAUtil$KeyType.keyAlgo:Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
ldc " private CRT key, "
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
1: aload 0
getfield sun.security.rsa.RSAPrivateCrtKeyImpl.n:Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.bitLength:()I
invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
ldc " bits"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
ldc "\n params: "
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
aload 0
getfield sun.security.rsa.RSAPrivateCrtKeyImpl.keyParams:Ljava/security/spec/AlgorithmParameterSpec;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
2: ldc "\n modulus: "
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
aload 0
getfield sun.security.rsa.RSAPrivateCrtKeyImpl.n:Ljava/math/BigInteger;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
ldc "\n private exponent: "
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
aload 0
getfield sun.security.rsa.RSAPrivateCrtKeyImpl.d:Ljava/math/BigInteger;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
3: invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lsun/security/rsa/RSAPrivateCrtKeyImpl;
private void parseKeyBits();
descriptor: ()V
flags: (0x0002) ACC_PRIVATE
Code:
stack=4, locals=5, args_size=1
start local 0 0: new sun.security.util.DerInputStream
dup
aload 0
getfield sun.security.rsa.RSAPrivateCrtKeyImpl.key:[B
invokespecial sun.security.util.DerInputStream.<init>:([B)V
astore 1
start local 1 1: aload 1
invokevirtual sun.security.util.DerInputStream.getDerValue:()Lsun/security/util/DerValue;
astore 2
start local 2 2: aload 2
getfield sun.security.util.DerValue.tag:B
bipush 48
if_icmpeq 4
3: new java.io.IOException
dup
ldc "Not a SEQUENCE"
invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
athrow
4: StackMap locals: sun.security.util.DerInputStream sun.security.util.DerValue
StackMap stack:
aload 2
getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
astore 3
start local 3 5: aload 3
invokevirtual sun.security.util.DerInputStream.getInteger:()I
istore 4
start local 4 6: iload 4
ifeq 8
7: new java.io.IOException
dup
ldc "Version must be 0"
invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
athrow
8: StackMap locals: sun.security.util.DerInputStream int
StackMap stack:
aload 0
aload 3
invokevirtual sun.security.util.DerInputStream.getPositiveBigInteger:()Ljava/math/BigInteger;
putfield sun.security.rsa.RSAPrivateCrtKeyImpl.n:Ljava/math/BigInteger;
9: aload 0
aload 3
invokevirtual sun.security.util.DerInputStream.getPositiveBigInteger:()Ljava/math/BigInteger;
putfield sun.security.rsa.RSAPrivateCrtKeyImpl.e:Ljava/math/BigInteger;
10: aload 0
aload 3
invokevirtual sun.security.util.DerInputStream.getPositiveBigInteger:()Ljava/math/BigInteger;
putfield sun.security.rsa.RSAPrivateCrtKeyImpl.d:Ljava/math/BigInteger;
11: aload 0
aload 3
invokevirtual sun.security.util.DerInputStream.getPositiveBigInteger:()Ljava/math/BigInteger;
putfield sun.security.rsa.RSAPrivateCrtKeyImpl.p:Ljava/math/BigInteger;
12: aload 0
aload 3
invokevirtual sun.security.util.DerInputStream.getPositiveBigInteger:()Ljava/math/BigInteger;
putfield sun.security.rsa.RSAPrivateCrtKeyImpl.q:Ljava/math/BigInteger;
13: aload 0
aload 3
invokevirtual sun.security.util.DerInputStream.getPositiveBigInteger:()Ljava/math/BigInteger;
putfield sun.security.rsa.RSAPrivateCrtKeyImpl.pe:Ljava/math/BigInteger;
14: aload 0
aload 3
invokevirtual sun.security.util.DerInputStream.getPositiveBigInteger:()Ljava/math/BigInteger;
putfield sun.security.rsa.RSAPrivateCrtKeyImpl.qe:Ljava/math/BigInteger;
15: aload 0
aload 3
invokevirtual sun.security.util.DerInputStream.getPositiveBigInteger:()Ljava/math/BigInteger;
putfield sun.security.rsa.RSAPrivateCrtKeyImpl.coeff:Ljava/math/BigInteger;
16: aload 2
getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
invokevirtual sun.security.util.DerInputStream.available:()I
ifeq 20
17: new java.io.IOException
dup
ldc "Extra data available"
invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
athrow
end local 4 end local 3 end local 2 end local 1 18: StackMap locals: sun.security.rsa.RSAPrivateCrtKeyImpl
StackMap stack: java.io.IOException
astore 1
start local 1 19: new java.security.InvalidKeyException
dup
ldc "Invalid RSA private key"
aload 1
invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
athrow
end local 1 20: StackMap locals:
StackMap stack:
return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 21 0 this Lsun/security/rsa/RSAPrivateCrtKeyImpl;
1 18 1 in Lsun/security/util/DerInputStream;
2 18 2 derValue Lsun/security/util/DerValue;
5 18 3 data Lsun/security/util/DerInputStream;
6 18 4 version I
19 20 1 e Ljava/io/IOException;
Exception table:
from to target type
0 18 18 Class java.io.IOException
Exceptions:
throws java.security.InvalidKeyException
}
SourceFile: "RSAPrivateCrtKeyImpl.java"
InnerClasses:
public final KeyType = sun.security.rsa.RSAUtil$KeyType of sun.security.rsa.RSAUtil