public final class sun.security.rsa.RSACore
minor version: 0
major version: 59
flags: flags: (0x0031) ACC_PUBLIC, ACC_FINAL, ACC_SUPER
this_class: sun.security.rsa.RSACore
super_class: java.lang.Object
{
private static final boolean ENABLE_BLINDING;
descriptor: Z
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
ConstantValue: 1
private static final java.util.Map<java.math.BigInteger, sun.security.rsa.RSACore$BlindingParameters> blindingCache;
descriptor: Ljava/util/Map;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
Signature: Ljava/util/Map<Ljava/math/BigInteger;Lsun/security/rsa/RSACore$BlindingParameters;>;
static final boolean $assertionsDisabled;
descriptor: Z
flags: (0x1018) ACC_STATIC, ACC_FINAL, ACC_SYNTHETIC
static void <clinit>();
descriptor: ()V
flags: (0x0008) ACC_STATIC
Code:
stack=2, locals=0, args_size=0
0: ldc Lsun/security/rsa/RSACore;
invokevirtual java.lang.Class.desiredAssertionStatus:()Z
ifne 1
iconst_1
goto 2
StackMap locals:
StackMap stack:
1: iconst_0
StackMap locals:
StackMap stack: int
2: putstatic sun.security.rsa.RSACore.$assertionsDisabled:Z
3: new java.util.WeakHashMap
dup
invokespecial java.util.WeakHashMap.<init>:()V
putstatic sun.security.rsa.RSACore.blindingCache:Ljava/util/Map;
return
LocalVariableTable:
Start End Slot Name Signature
private void <init>();
descriptor: ()V
flags: (0x0002) ACC_PRIVATE
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
invokespecial java.lang.Object.<init>:()V
1: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lsun/security/rsa/RSACore;
public static int getByteLength(java.math.BigInteger);
descriptor: (Ljava/math/BigInteger;)I
flags: (0x0009) ACC_PUBLIC, ACC_STATIC
Code:
stack=2, locals=2, args_size=1
start local 0 0: aload 0
invokevirtual java.math.BigInteger.bitLength:()I
istore 1
start local 1 1: iload 1
bipush 7
iadd
iconst_3
ishr
ireturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 b Ljava/math/BigInteger;
1 2 1 n I
MethodParameters:
Name Flags
b
public static int getByteLength(java.security.interfaces.RSAKey);
descriptor: (Ljava/security/interfaces/RSAKey;)I
flags: (0x0009) ACC_PUBLIC, ACC_STATIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
invokeinterface java.security.interfaces.RSAKey.getModulus:()Ljava/math/BigInteger;
invokestatic sun.security.rsa.RSACore.getByteLength:(Ljava/math/BigInteger;)I
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 key Ljava/security/interfaces/RSAKey;
MethodParameters:
Name Flags
key
public static byte[] convert(byte[], int, int);
descriptor: ([BII)[B
flags: (0x0009) ACC_PUBLIC, ACC_STATIC
Code:
stack=5, locals=4, args_size=3
start local 0 start local 1 start local 2 0: iload 1
ifne 2
iload 2
aload 0
arraylength
if_icmpne 2
1: aload 0
areturn
2: StackMap locals:
StackMap stack:
iload 2
newarray 8
astore 3
start local 3 3: aload 0
iload 1
aload 3
iconst_0
iload 2
invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
4: aload 3
areturn
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 5 0 b [B
0 5 1 ofs I
0 5 2 len I
3 5 3 t [B
MethodParameters:
Name Flags
b
ofs
len
public static byte[] rsa(byte[], java.security.interfaces.RSAPublicKey);
descriptor: ([BLjava/security/interfaces/RSAPublicKey;)[B
flags: (0x0009) ACC_PUBLIC, ACC_STATIC
Code:
stack=3, locals=2, args_size=2
start local 0 start local 1 0: aload 0
aload 1
invokeinterface java.security.interfaces.RSAPublicKey.getModulus:()Ljava/math/BigInteger;
aload 1
invokeinterface java.security.interfaces.RSAPublicKey.getPublicExponent:()Ljava/math/BigInteger;
invokestatic sun.security.rsa.RSACore.crypt:([BLjava/math/BigInteger;Ljava/math/BigInteger;)[B
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 msg [B
0 1 1 key Ljava/security/interfaces/RSAPublicKey;
Exceptions:
throws javax.crypto.BadPaddingException
MethodParameters:
Name Flags
msg
key
public static byte[] rsa(byte[], java.security.interfaces.RSAPrivateKey);
descriptor: ([BLjava/security/interfaces/RSAPrivateKey;)[B
flags: (0x0009) ACC_PUBLIC, ACC_STATIC
Code:
stack=3, locals=2, args_size=2
start local 0 start local 1 0: aload 0
aload 1
iconst_1
invokestatic sun.security.rsa.RSACore.rsa:([BLjava/security/interfaces/RSAPrivateKey;Z)[B
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 msg [B
0 1 1 key Ljava/security/interfaces/RSAPrivateKey;
Exceptions:
throws javax.crypto.BadPaddingException
RuntimeVisibleAnnotations:
java.lang.Deprecated()
MethodParameters:
Name Flags
msg
key
public static byte[] rsa(byte[], java.security.interfaces.RSAPrivateKey, boolean);
descriptor: ([BLjava/security/interfaces/RSAPrivateKey;Z)[B
flags: (0x0009) ACC_PUBLIC, ACC_STATIC
Code:
stack=3, locals=3, args_size=3
start local 0 start local 1 start local 2 0: aload 1
instanceof java.security.interfaces.RSAPrivateCrtKey
ifeq 2
1: aload 0
aload 1
checkcast java.security.interfaces.RSAPrivateCrtKey
iload 2
invokestatic sun.security.rsa.RSACore.crtCrypt:([BLjava/security/interfaces/RSAPrivateCrtKey;Z)[B
areturn
2: StackMap locals:
StackMap stack:
aload 0
aload 1
invokeinterface java.security.interfaces.RSAPrivateKey.getModulus:()Ljava/math/BigInteger;
aload 1
invokeinterface java.security.interfaces.RSAPrivateKey.getPrivateExponent:()Ljava/math/BigInteger;
invokestatic sun.security.rsa.RSACore.priCrypt:([BLjava/math/BigInteger;Ljava/math/BigInteger;)[B
areturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 msg [B
0 3 1 key Ljava/security/interfaces/RSAPrivateKey;
0 3 2 verify Z
Exceptions:
throws javax.crypto.BadPaddingException
MethodParameters:
Name Flags
msg
key
verify
private static byte[] crypt(byte[], java.math.BigInteger, java.math.BigInteger);
descriptor: ([BLjava/math/BigInteger;Ljava/math/BigInteger;)[B
flags: (0x000a) ACC_PRIVATE, ACC_STATIC
Code:
stack=3, locals=5, args_size=3
start local 0 start local 1 start local 2 0: aload 0
aload 1
invokestatic sun.security.rsa.RSACore.parseMsg:([BLjava/math/BigInteger;)Ljava/math/BigInteger;
astore 3
start local 3 1: aload 3
aload 2
aload 1
invokevirtual java.math.BigInteger.modPow:(Ljava/math/BigInteger;Ljava/math/BigInteger;)Ljava/math/BigInteger;
astore 4
start local 4 2: aload 4
aload 1
invokestatic sun.security.rsa.RSACore.getByteLength:(Ljava/math/BigInteger;)I
invokestatic sun.security.rsa.RSACore.toByteArray:(Ljava/math/BigInteger;I)[B
areturn
end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 msg [B
0 3 1 n Ljava/math/BigInteger;
0 3 2 exp Ljava/math/BigInteger;
1 3 3 m Ljava/math/BigInteger;
2 3 4 c Ljava/math/BigInteger;
Exceptions:
throws javax.crypto.BadPaddingException
MethodParameters:
Name Flags
msg
n
exp
private static byte[] priCrypt(byte[], java.math.BigInteger, java.math.BigInteger);
descriptor: ([BLjava/math/BigInteger;Ljava/math/BigInteger;)[B
flags: (0x000a) ACC_PRIVATE, ACC_STATIC
Code:
stack=3, locals=6, args_size=3
start local 0 start local 1 start local 2 0: aload 0
aload 1
invokestatic sun.security.rsa.RSACore.parseMsg:([BLjava/math/BigInteger;)Ljava/math/BigInteger;
astore 3
start local 3 1: aconst_null
astore 4
start local 4 2: aconst_null
aload 2
aload 1
invokestatic sun.security.rsa.RSACore.getBlindingRandomPair:(Ljava/math/BigInteger;Ljava/math/BigInteger;Ljava/math/BigInteger;)Lsun/security/rsa/RSACore$BlindingRandomPair;
astore 4
3: aload 3
aload 4
getfield sun.security.rsa.RSACore$BlindingRandomPair.u:Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.multiply:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
aload 1
invokevirtual java.math.BigInteger.mod:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
astore 3
4: aload 3
aload 2
aload 1
invokevirtual java.math.BigInteger.modPow:(Ljava/math/BigInteger;Ljava/math/BigInteger;)Ljava/math/BigInteger;
astore 5
start local 5 5: aload 5
aload 4
getfield sun.security.rsa.RSACore$BlindingRandomPair.v:Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.multiply:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
aload 1
invokevirtual java.math.BigInteger.mod:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
astore 5
6: aload 5
aload 1
invokestatic sun.security.rsa.RSACore.getByteLength:(Ljava/math/BigInteger;)I
invokestatic sun.security.rsa.RSACore.toByteArray:(Ljava/math/BigInteger;I)[B
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 7 0 msg [B
0 7 1 n Ljava/math/BigInteger;
0 7 2 exp Ljava/math/BigInteger;
1 7 3 c Ljava/math/BigInteger;
2 7 4 brp Lsun/security/rsa/RSACore$BlindingRandomPair;
5 7 5 m Ljava/math/BigInteger;
Exceptions:
throws javax.crypto.BadPaddingException
MethodParameters:
Name Flags
msg
n
exp
private static byte[] crtCrypt(byte[], java.security.interfaces.RSAPrivateCrtKey, boolean);
descriptor: ([BLjava/security/interfaces/RSAPrivateCrtKey;Z)[B
flags: (0x000a) ACC_PRIVATE, ACC_STATIC
Code:
stack=4, locals=19, args_size=3
start local 0 start local 1 start local 2 0: aload 1
invokeinterface java.security.interfaces.RSAPrivateCrtKey.getModulus:()Ljava/math/BigInteger;
astore 3
start local 3 1: aload 0
aload 3
invokestatic sun.security.rsa.RSACore.parseMsg:([BLjava/math/BigInteger;)Ljava/math/BigInteger;
astore 4
start local 4 2: aload 4
astore 5
start local 5 3: aload 1
invokeinterface java.security.interfaces.RSAPrivateCrtKey.getPrimeP:()Ljava/math/BigInteger;
astore 6
start local 6 4: aload 1
invokeinterface java.security.interfaces.RSAPrivateCrtKey.getPrimeQ:()Ljava/math/BigInteger;
astore 7
start local 7 5: aload 1
invokeinterface java.security.interfaces.RSAPrivateCrtKey.getPrimeExponentP:()Ljava/math/BigInteger;
astore 8
start local 8 6: aload 1
invokeinterface java.security.interfaces.RSAPrivateCrtKey.getPrimeExponentQ:()Ljava/math/BigInteger;
astore 9
start local 9 7: aload 1
invokeinterface java.security.interfaces.RSAPrivateCrtKey.getCrtCoefficient:()Ljava/math/BigInteger;
astore 10
start local 10 8: aload 1
invokeinterface java.security.interfaces.RSAPrivateCrtKey.getPublicExponent:()Ljava/math/BigInteger;
astore 11
start local 11 9: aload 1
invokeinterface java.security.interfaces.RSAPrivateCrtKey.getPrivateExponent:()Ljava/math/BigInteger;
astore 12
start local 12 10: aload 11
aload 12
aload 3
invokestatic sun.security.rsa.RSACore.getBlindingRandomPair:(Ljava/math/BigInteger;Ljava/math/BigInteger;Ljava/math/BigInteger;)Lsun/security/rsa/RSACore$BlindingRandomPair;
astore 13
start local 13 11: aload 5
aload 13
getfield sun.security.rsa.RSACore$BlindingRandomPair.u:Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.multiply:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
aload 3
invokevirtual java.math.BigInteger.mod:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
astore 5
12: aload 5
aload 8
aload 6
invokevirtual java.math.BigInteger.modPow:(Ljava/math/BigInteger;Ljava/math/BigInteger;)Ljava/math/BigInteger;
astore 14
start local 14 13: aload 5
aload 9
aload 7
invokevirtual java.math.BigInteger.modPow:(Ljava/math/BigInteger;Ljava/math/BigInteger;)Ljava/math/BigInteger;
astore 15
start local 15 14: aload 14
aload 15
invokevirtual java.math.BigInteger.subtract:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
astore 16
start local 16 15: aload 16
invokevirtual java.math.BigInteger.signum:()I
ifge 17
16: aload 16
aload 6
invokevirtual java.math.BigInteger.add:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
astore 16
17: StackMap locals: byte[] java.security.interfaces.RSAPrivateCrtKey int java.math.BigInteger java.math.BigInteger java.math.BigInteger java.math.BigInteger java.math.BigInteger java.math.BigInteger java.math.BigInteger java.math.BigInteger java.math.BigInteger java.math.BigInteger sun.security.rsa.RSACore$BlindingRandomPair java.math.BigInteger java.math.BigInteger java.math.BigInteger
StackMap stack:
aload 16
aload 10
invokevirtual java.math.BigInteger.multiply:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
aload 6
invokevirtual java.math.BigInteger.mod:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
astore 17
start local 17 18: aload 17
aload 7
invokevirtual java.math.BigInteger.multiply:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
aload 15
invokevirtual java.math.BigInteger.add:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
astore 18
start local 18 19: aload 18
aload 13
getfield sun.security.rsa.RSACore$BlindingRandomPair.v:Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.multiply:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
aload 3
invokevirtual java.math.BigInteger.mod:(Ljava/math/BigInteger;)Ljava/math/BigInteger;
astore 18
20: iload 2
ifeq 22
aload 4
aload 18
aload 11
aload 3
invokevirtual java.math.BigInteger.modPow:(Ljava/math/BigInteger;Ljava/math/BigInteger;)Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.equals:(Ljava/lang/Object;)Z
ifne 22
21: new javax.crypto.BadPaddingException
dup
ldc "RSA private key operation failed"
invokespecial javax.crypto.BadPaddingException.<init>:(Ljava/lang/String;)V
athrow
22: StackMap locals: java.math.BigInteger java.math.BigInteger
StackMap stack:
aload 18
aload 3
invokestatic sun.security.rsa.RSACore.getByteLength:(Ljava/math/BigInteger;)I
invokestatic sun.security.rsa.RSACore.toByteArray:(Ljava/math/BigInteger;I)[B
areturn
end local 18 end local 17 end local 16 end local 15 end local 14 end local 13 end local 12 end local 11 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 23 0 msg [B
0 23 1 key Ljava/security/interfaces/RSAPrivateCrtKey;
0 23 2 verify Z
1 23 3 n Ljava/math/BigInteger;
2 23 4 c0 Ljava/math/BigInteger;
3 23 5 c Ljava/math/BigInteger;
4 23 6 p Ljava/math/BigInteger;
5 23 7 q Ljava/math/BigInteger;
6 23 8 dP Ljava/math/BigInteger;
7 23 9 dQ Ljava/math/BigInteger;
8 23 10 qInv Ljava/math/BigInteger;
9 23 11 e Ljava/math/BigInteger;
10 23 12 d Ljava/math/BigInteger;
11 23 13 brp Lsun/security/rsa/RSACore$BlindingRandomPair;
13 23 14 m1 Ljava/math/BigInteger;
14 23 15 m2 Ljava/math/BigInteger;
15 23 16 mtmp Ljava/math/BigInteger;
18 23 17 h Ljava/math/BigInteger;
19 23 18 m Ljava/math/BigInteger;
Exceptions:
throws javax.crypto.BadPaddingException
MethodParameters:
Name Flags
msg
key
verify
private static java.math.BigInteger parseMsg(byte[], java.math.BigInteger);
descriptor: ([BLjava/math/BigInteger;)Ljava/math/BigInteger;
flags: (0x000a) ACC_PRIVATE, ACC_STATIC
Code:
stack=4, locals=3, args_size=2
start local 0 start local 1 0: new java.math.BigInteger
dup
iconst_1
aload 0
invokespecial java.math.BigInteger.<init>:(I[B)V
astore 2
start local 2 1: aload 2
aload 1
invokevirtual java.math.BigInteger.compareTo:(Ljava/math/BigInteger;)I
iflt 3
2: new javax.crypto.BadPaddingException
dup
ldc "Message is larger than modulus"
invokespecial javax.crypto.BadPaddingException.<init>:(Ljava/lang/String;)V
athrow
3: StackMap locals: java.math.BigInteger
StackMap stack:
aload 2
areturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 msg [B
0 4 1 n Ljava/math/BigInteger;
1 4 2 m Ljava/math/BigInteger;
Exceptions:
throws javax.crypto.BadPaddingException
MethodParameters:
Name Flags
msg
n
private static byte[] toByteArray(java.math.BigInteger, int);
descriptor: (Ljava/math/BigInteger;I)[B
flags: (0x000a) ACC_PRIVATE, ACC_STATIC
Code:
stack=5, locals=5, args_size=2
start local 0 start local 1 0: aload 0
invokevirtual java.math.BigInteger.toByteArray:()[B
astore 2
start local 2 1: aload 2
arraylength
istore 3
start local 3 2: iload 3
iload 1
if_icmpne 4
3: aload 2
areturn
4: StackMap locals: byte[] int
StackMap stack:
iload 3
iload 1
iconst_1
iadd
if_icmpne 8
aload 2
iconst_0
baload
ifne 8
5: iload 1
newarray 8
astore 4
start local 4 6: aload 2
iconst_1
aload 4
iconst_0
iload 1
invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
7: aload 4
areturn
end local 4 8: StackMap locals:
StackMap stack:
getstatic sun.security.rsa.RSACore.$assertionsDisabled:Z
ifne 9
iload 3
iload 1
if_icmplt 9
new java.lang.AssertionError
dup
invokespecial java.lang.AssertionError.<init>:()V
athrow
9: StackMap locals:
StackMap stack:
iload 1
newarray 8
astore 4
start local 4 10: aload 2
iconst_0
aload 4
iload 1
iload 3
isub
iload 3
invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
11: aload 4
areturn
end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 12 0 bi Ljava/math/BigInteger;
0 12 1 len I
1 12 2 b [B
2 12 3 n I
6 8 4 t [B
10 12 4 t [B
MethodParameters:
Name Flags
bi
len
private static sun.security.rsa.RSACore$BlindingRandomPair getBlindingRandomPair(java.math.BigInteger, java.math.BigInteger, java.math.BigInteger);
descriptor: (Ljava/math/BigInteger;Ljava/math/BigInteger;Ljava/math/BigInteger;)Lsun/security/rsa/RSACore$BlindingRandomPair;
flags: (0x000a) ACC_PRIVATE, ACC_STATIC
Code:
stack=5, locals=6, args_size=3
start local 0 start local 1 start local 2 0: aconst_null
astore 3
start local 3 1: getstatic sun.security.rsa.RSACore.blindingCache:Ljava/util/Map;
dup
astore 4
monitorenter
2: getstatic sun.security.rsa.RSACore.blindingCache:Ljava/util/Map;
aload 2
invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
checkcast sun.security.rsa.RSACore$BlindingParameters
astore 3
3: aload 4
monitorexit
4: goto 7
StackMap locals: java.math.BigInteger java.math.BigInteger java.math.BigInteger sun.security.rsa.RSACore$BlindingParameters java.util.Map
StackMap stack: java.lang.Throwable
5: aload 4
monitorexit
6: athrow
7: StackMap locals:
StackMap stack:
aload 3
ifnonnull 16
8: new sun.security.rsa.RSACore$BlindingParameters
dup
aload 0
aload 1
aload 2
invokespecial sun.security.rsa.RSACore$BlindingParameters.<init>:(Ljava/math/BigInteger;Ljava/math/BigInteger;Ljava/math/BigInteger;)V
astore 3
9: getstatic sun.security.rsa.RSACore.blindingCache:Ljava/util/Map;
dup
astore 4
monitorenter
10: getstatic sun.security.rsa.RSACore.blindingCache:Ljava/util/Map;
aload 2
invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
ifnonnull 12
11: getstatic sun.security.rsa.RSACore.blindingCache:Ljava/util/Map;
aload 2
aload 3
invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
pop
12: StackMap locals: java.util.Map
StackMap stack:
aload 4
monitorexit
13: goto 16
StackMap locals:
StackMap stack: java.lang.Throwable
14: aload 4
monitorexit
15: athrow
16: StackMap locals:
StackMap stack:
aload 3
aload 0
aload 1
aload 2
invokevirtual sun.security.rsa.RSACore$BlindingParameters.getBlindingRandomPair:(Ljava/math/BigInteger;Ljava/math/BigInteger;Ljava/math/BigInteger;)Lsun/security/rsa/RSACore$BlindingRandomPair;
astore 4
start local 4 17: aload 4
ifnonnull 27
18: new sun.security.rsa.RSACore$BlindingParameters
dup
aload 0
aload 1
aload 2
invokespecial sun.security.rsa.RSACore$BlindingParameters.<init>:(Ljava/math/BigInteger;Ljava/math/BigInteger;Ljava/math/BigInteger;)V
astore 3
19: getstatic sun.security.rsa.RSACore.blindingCache:Ljava/util/Map;
dup
astore 5
monitorenter
20: getstatic sun.security.rsa.RSACore.blindingCache:Ljava/util/Map;
aload 2
invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
ifnull 22
21: getstatic sun.security.rsa.RSACore.blindingCache:Ljava/util/Map;
aload 2
aload 3
invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
pop
22: StackMap locals: sun.security.rsa.RSACore$BlindingRandomPair java.util.Map
StackMap stack:
aload 5
monitorexit
23: goto 26
StackMap locals:
StackMap stack: java.lang.Throwable
24: aload 5
monitorexit
25: athrow
26: StackMap locals:
StackMap stack:
aload 3
aload 0
aload 1
aload 2
invokevirtual sun.security.rsa.RSACore$BlindingParameters.getBlindingRandomPair:(Ljava/math/BigInteger;Ljava/math/BigInteger;Ljava/math/BigInteger;)Lsun/security/rsa/RSACore$BlindingRandomPair;
astore 4
27: StackMap locals:
StackMap stack:
aload 4
areturn
end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 28 0 e Ljava/math/BigInteger;
0 28 1 d Ljava/math/BigInteger;
0 28 2 n Ljava/math/BigInteger;
1 28 3 bps Lsun/security/rsa/RSACore$BlindingParameters;
17 28 4 brp Lsun/security/rsa/RSACore$BlindingRandomPair;
Exception table:
from to target type
2 4 5 any
5 6 5 any
10 13 14 any
14 15 14 any
20 23 24 any
24 25 24 any
MethodParameters:
Name Flags
e
d
n
}
SourceFile: "RSACore.java"
NestMembers:
sun.security.rsa.RSACore$BlindingParameters sun.security.rsa.RSACore$BlindingRandomPair
InnerClasses:
private final BlindingParameters = sun.security.rsa.RSACore$BlindingParameters of sun.security.rsa.RSACore
private final BlindingRandomPair = sun.security.rsa.RSACore$BlindingRandomPair of sun.security.rsa.RSACore