public class java.security.spec.RSAMultiPrimePrivateCrtKeySpec extends java.security.spec.RSAPrivateKeySpec
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: java.security.spec.RSAMultiPrimePrivateCrtKeySpec
  super_class: java.security.spec.RSAPrivateKeySpec
{
  private final java.math.BigInteger publicExponent;
    descriptor: Ljava/math/BigInteger;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.math.BigInteger primeP;
    descriptor: Ljava/math/BigInteger;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.math.BigInteger primeQ;
    descriptor: Ljava/math/BigInteger;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.math.BigInteger primeExponentP;
    descriptor: Ljava/math/BigInteger;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.math.BigInteger primeExponentQ;
    descriptor: Ljava/math/BigInteger;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.math.BigInteger crtCoefficient;
    descriptor: Ljava/math/BigInteger;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.security.spec.RSAOtherPrimeInfo[] otherPrimeInfo;
    descriptor: [Ljava/security/spec/RSAOtherPrimeInfo;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  public void <init>(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.security.spec.RSAOtherPrimeInfo[]);
    descriptor: (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/spec/RSAOtherPrimeInfo;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=11, locals=10, args_size=10
        start local 0 // java.security.spec.RSAMultiPrimePrivateCrtKeySpec this
        start local 1 // java.math.BigInteger modulus
        start local 2 // java.math.BigInteger publicExponent
        start local 3 // java.math.BigInteger privateExponent
        start local 4 // java.math.BigInteger primeP
        start local 5 // java.math.BigInteger primeQ
        start local 6 // java.math.BigInteger primeExponentP
        start local 7 // java.math.BigInteger primeExponentQ
        start local 8 // java.math.BigInteger crtCoefficient
        start local 9 // java.security.spec.RSAOtherPrimeInfo[] otherPrimeInfo
         0: .line 94
            aload 0 /* this */
            aload 1 /* modulus */
            aload 2 /* publicExponent */
            aload 3 /* privateExponent */
            aload 4 /* primeP */
            aload 5 /* primeQ */
         1: .line 95
            aload 6 /* primeExponentP */
            aload 7 /* primeExponentQ */
            aload 8 /* crtCoefficient */
            aload 9 /* otherPrimeInfo */
         2: .line 96
            aconst_null
            invokespecial java.security.spec.RSAMultiPrimePrivateCrtKeySpec.<init>:(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/spec/RSAOtherPrimeInfo;Ljava/security/spec/AlgorithmParameterSpec;)V
         3: .line 97
            return
        end local 9 // java.security.spec.RSAOtherPrimeInfo[] otherPrimeInfo
        end local 8 // java.math.BigInteger crtCoefficient
        end local 7 // java.math.BigInteger primeExponentQ
        end local 6 // java.math.BigInteger primeExponentP
        end local 5 // java.math.BigInteger primeQ
        end local 4 // java.math.BigInteger primeP
        end local 3 // java.math.BigInteger privateExponent
        end local 2 // java.math.BigInteger publicExponent
        end local 1 // java.math.BigInteger modulus
        end local 0 // java.security.spec.RSAMultiPrimePrivateCrtKeySpec this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0    4     0             this  Ljava/security/spec/RSAMultiPrimePrivateCrtKeySpec;
            0    4     1          modulus  Ljava/math/BigInteger;
            0    4     2   publicExponent  Ljava/math/BigInteger;
            0    4     3  privateExponent  Ljava/math/BigInteger;
            0    4     4           primeP  Ljava/math/BigInteger;
            0    4     5           primeQ  Ljava/math/BigInteger;
            0    4     6   primeExponentP  Ljava/math/BigInteger;
            0    4     7   primeExponentQ  Ljava/math/BigInteger;
            0    4     8   crtCoefficient  Ljava/math/BigInteger;
            0    4     9   otherPrimeInfo  [Ljava/security/spec/RSAOtherPrimeInfo;
    MethodParameters:
                 Name  Flags
      modulus          
      publicExponent   
      privateExponent  
      primeP           
      primeQ           
      primeExponentP   
      primeExponentQ   
      crtCoefficient   
      otherPrimeInfo   

  public void <init>(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.security.spec.RSAOtherPrimeInfo[], java.security.spec.AlgorithmParameterSpec);
    descriptor: (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/spec/RSAOtherPrimeInfo;Ljava/security/spec/AlgorithmParameterSpec;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=11, args_size=11
        start local 0 // java.security.spec.RSAMultiPrimePrivateCrtKeySpec this
        start local 1 // java.math.BigInteger modulus
        start local 2 // java.math.BigInteger publicExponent
        start local 3 // java.math.BigInteger privateExponent
        start local 4 // java.math.BigInteger primeP
        start local 5 // java.math.BigInteger primeQ
        start local 6 // java.math.BigInteger primeExponentP
        start local 7 // java.math.BigInteger primeExponentQ
        start local 8 // java.math.BigInteger crtCoefficient
        start local 9 // java.security.spec.RSAOtherPrimeInfo[] otherPrimeInfo
        start local 10 // java.security.spec.AlgorithmParameterSpec keyParams
         0: .line 137
            aload 0 /* this */
            aload 1 /* modulus */
            aload 3 /* privateExponent */
            aload 10 /* keyParams */
            invokespecial java.security.spec.RSAPrivateKeySpec.<init>:(Ljava/math/BigInteger;Ljava/math/BigInteger;Ljava/security/spec/AlgorithmParameterSpec;)V
         1: .line 138
            aload 1 /* modulus */
         2: .line 139
            ldc "the modulus parameter must be non-null"
         3: .line 138
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
            pop
         4: .line 140
            aload 3 /* privateExponent */
         5: .line 141
            ldc "the privateExponent parameter must be non-null"
         6: .line 140
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
            pop
         7: .line 142
            aload 0 /* this */
            aload 2 /* publicExponent */
         8: .line 143
            ldc "the publicExponent parameter must be non-null"
         9: .line 142
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
            checkcast java.math.BigInteger
            putfield java.security.spec.RSAMultiPrimePrivateCrtKeySpec.publicExponent:Ljava/math/BigInteger;
        10: .line 144
            aload 0 /* this */
            aload 4 /* primeP */
        11: .line 145
            ldc "the primeP parameter must be non-null"
        12: .line 144
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
            checkcast java.math.BigInteger
            putfield java.security.spec.RSAMultiPrimePrivateCrtKeySpec.primeP:Ljava/math/BigInteger;
        13: .line 146
            aload 0 /* this */
            aload 5 /* primeQ */
        14: .line 147
            ldc "the primeQ parameter must be non-null"
        15: .line 146
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
            checkcast java.math.BigInteger
            putfield java.security.spec.RSAMultiPrimePrivateCrtKeySpec.primeQ:Ljava/math/BigInteger;
        16: .line 148
            aload 0 /* this */
            aload 6 /* primeExponentP */
        17: .line 149
            ldc "the primeExponentP parameter must be non-null"
        18: .line 148
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
            checkcast java.math.BigInteger
            putfield java.security.spec.RSAMultiPrimePrivateCrtKeySpec.primeExponentP:Ljava/math/BigInteger;
        19: .line 150
            aload 0 /* this */
            aload 7 /* primeExponentQ */
        20: .line 151
            ldc "the primeExponentQ parameter must be non-null"
        21: .line 150
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
            checkcast java.math.BigInteger
            putfield java.security.spec.RSAMultiPrimePrivateCrtKeySpec.primeExponentQ:Ljava/math/BigInteger;
        22: .line 152
            aload 0 /* this */
            aload 8 /* crtCoefficient */
        23: .line 153
            ldc "the crtCoefficient parameter must be non-null"
        24: .line 152
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
            checkcast java.math.BigInteger
            putfield java.security.spec.RSAMultiPrimePrivateCrtKeySpec.crtCoefficient:Ljava/math/BigInteger;
        25: .line 155
            aload 9 /* otherPrimeInfo */
            ifnonnull 28
        26: .line 156
            aload 0 /* this */
            aconst_null
            putfield java.security.spec.RSAMultiPrimePrivateCrtKeySpec.otherPrimeInfo:[Ljava/security/spec/RSAOtherPrimeInfo;
        27: .line 157
            goto 31
      StackMap locals: java.security.spec.RSAMultiPrimePrivateCrtKeySpec 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.security.spec.RSAOtherPrimeInfo[] java.security.spec.AlgorithmParameterSpec
      StackMap stack:
        28: aload 9 /* otherPrimeInfo */
            arraylength
            ifne 30
        29: .line 158
            new java.lang.IllegalArgumentException
            dup
            ldc "the otherPrimeInfo parameter must not be empty"
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
        30: .line 161
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 9 /* otherPrimeInfo */
            invokevirtual java.security.spec.RSAOtherPrimeInfo[].clone:()Ljava/lang/Object;
            checkcast java.security.spec.RSAOtherPrimeInfo[]
            putfield java.security.spec.RSAMultiPrimePrivateCrtKeySpec.otherPrimeInfo:[Ljava/security/spec/RSAOtherPrimeInfo;
        31: .line 163
      StackMap locals:
      StackMap stack:
            return
        end local 10 // java.security.spec.AlgorithmParameterSpec keyParams
        end local 9 // java.security.spec.RSAOtherPrimeInfo[] otherPrimeInfo
        end local 8 // java.math.BigInteger crtCoefficient
        end local 7 // java.math.BigInteger primeExponentQ
        end local 6 // java.math.BigInteger primeExponentP
        end local 5 // java.math.BigInteger primeQ
        end local 4 // java.math.BigInteger primeP
        end local 3 // java.math.BigInteger privateExponent
        end local 2 // java.math.BigInteger publicExponent
        end local 1 // java.math.BigInteger modulus
        end local 0 // java.security.spec.RSAMultiPrimePrivateCrtKeySpec this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0   32     0             this  Ljava/security/spec/RSAMultiPrimePrivateCrtKeySpec;
            0   32     1          modulus  Ljava/math/BigInteger;
            0   32     2   publicExponent  Ljava/math/BigInteger;
            0   32     3  privateExponent  Ljava/math/BigInteger;
            0   32     4           primeP  Ljava/math/BigInteger;
            0   32     5           primeQ  Ljava/math/BigInteger;
            0   32     6   primeExponentP  Ljava/math/BigInteger;
            0   32     7   primeExponentQ  Ljava/math/BigInteger;
            0   32     8   crtCoefficient  Ljava/math/BigInteger;
            0   32     9   otherPrimeInfo  [Ljava/security/spec/RSAOtherPrimeInfo;
            0   32    10        keyParams  Ljava/security/spec/AlgorithmParameterSpec;
    MethodParameters:
                 Name  Flags
      modulus          
      publicExponent   
      privateExponent  
      primeP           
      primeQ           
      primeExponentP   
      primeExponentQ   
      crtCoefficient   
      otherPrimeInfo   
      keyParams        

  public java.math.BigInteger getPublicExponent();
    descriptor: ()Ljava/math/BigInteger;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // java.security.spec.RSAMultiPrimePrivateCrtKeySpec this
         0: .line 171
            aload 0 /* this */
            getfield java.security.spec.RSAMultiPrimePrivateCrtKeySpec.publicExponent:Ljava/math/BigInteger;
            areturn
        end local 0 // java.security.spec.RSAMultiPrimePrivateCrtKeySpec this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljava/security/spec/RSAMultiPrimePrivateCrtKeySpec;

  public java.math.BigInteger getPrimeP();
    descriptor: ()Ljava/math/BigInteger;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // java.security.spec.RSAMultiPrimePrivateCrtKeySpec this
         0: .line 180
            aload 0 /* this */
            getfield java.security.spec.RSAMultiPrimePrivateCrtKeySpec.primeP:Ljava/math/BigInteger;
            areturn
        end local 0 // java.security.spec.RSAMultiPrimePrivateCrtKeySpec this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljava/security/spec/RSAMultiPrimePrivateCrtKeySpec;

  public java.math.BigInteger getPrimeQ();
    descriptor: ()Ljava/math/BigInteger;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // java.security.spec.RSAMultiPrimePrivateCrtKeySpec this
         0: .line 189
            aload 0 /* this */
            getfield java.security.spec.RSAMultiPrimePrivateCrtKeySpec.primeQ:Ljava/math/BigInteger;
            areturn
        end local 0 // java.security.spec.RSAMultiPrimePrivateCrtKeySpec this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljava/security/spec/RSAMultiPrimePrivateCrtKeySpec;

  public java.math.BigInteger getPrimeExponentP();
    descriptor: ()Ljava/math/BigInteger;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // java.security.spec.RSAMultiPrimePrivateCrtKeySpec this
         0: .line 198
            aload 0 /* this */
            getfield java.security.spec.RSAMultiPrimePrivateCrtKeySpec.primeExponentP:Ljava/math/BigInteger;
            areturn
        end local 0 // java.security.spec.RSAMultiPrimePrivateCrtKeySpec this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljava/security/spec/RSAMultiPrimePrivateCrtKeySpec;

  public java.math.BigInteger getPrimeExponentQ();
    descriptor: ()Ljava/math/BigInteger;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // java.security.spec.RSAMultiPrimePrivateCrtKeySpec this
         0: .line 207
            aload 0 /* this */
            getfield java.security.spec.RSAMultiPrimePrivateCrtKeySpec.primeExponentQ:Ljava/math/BigInteger;
            areturn
        end local 0 // java.security.spec.RSAMultiPrimePrivateCrtKeySpec this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljava/security/spec/RSAMultiPrimePrivateCrtKeySpec;

  public java.math.BigInteger getCrtCoefficient();
    descriptor: ()Ljava/math/BigInteger;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // java.security.spec.RSAMultiPrimePrivateCrtKeySpec this
         0: .line 216
            aload 0 /* this */
            getfield java.security.spec.RSAMultiPrimePrivateCrtKeySpec.crtCoefficient:Ljava/math/BigInteger;
            areturn
        end local 0 // java.security.spec.RSAMultiPrimePrivateCrtKeySpec this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljava/security/spec/RSAMultiPrimePrivateCrtKeySpec;

  public java.security.spec.RSAOtherPrimeInfo[] getOtherPrimeInfo();
    descriptor: ()[Ljava/security/spec/RSAOtherPrimeInfo;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // java.security.spec.RSAMultiPrimePrivateCrtKeySpec this
         0: .line 227
            aload 0 /* this */
            getfield java.security.spec.RSAMultiPrimePrivateCrtKeySpec.otherPrimeInfo:[Ljava/security/spec/RSAOtherPrimeInfo;
            ifnonnull 1
            aconst_null
            areturn
         1: .line 228
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield java.security.spec.RSAMultiPrimePrivateCrtKeySpec.otherPrimeInfo:[Ljava/security/spec/RSAOtherPrimeInfo;
            invokevirtual java.security.spec.RSAOtherPrimeInfo[].clone:()Ljava/lang/Object;
            checkcast java.security.spec.RSAOtherPrimeInfo[]
            areturn
        end local 0 // java.security.spec.RSAMultiPrimePrivateCrtKeySpec this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Ljava/security/spec/RSAMultiPrimePrivateCrtKeySpec;
}
SourceFile: "RSAMultiPrimePrivateCrtKeySpec.java"