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 java.security.spec.AlgorithmParameterSpec keyParams;
    descriptor: Ljava/security/spec/AlgorithmParameterSpec;
    flags: (0x0002) ACC_PRIVATE

  public static java.security.interfaces.RSAPrivateKey newKey(byte[]);
    descriptor: ([B)Ljava/security/interfaces/RSAPrivateKey;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=5, locals=2, args_size=1
        start local 0 // byte[] encoded
         0: .line 80
            new sun.security.rsa.RSAPrivateCrtKeyImpl
            dup
            aload 0 /* encoded */
            invokespecial sun.security.rsa.RSAPrivateCrtKeyImpl.<init>:([B)V
            astore 1 /* key */
        start local 1 // sun.security.rsa.RSAPrivateCrtKeyImpl key
         1: .line 83
            aload 1 /* key */
            invokevirtual sun.security.rsa.RSAPrivateCrtKeyImpl.getPublicExponent:()Ljava/math/BigInteger;
            invokevirtual java.math.BigInteger.signum:()I
            ifeq 7
         2: .line 84
            aload 1 /* key */
            invokevirtual sun.security.rsa.RSAPrivateCrtKeyImpl.getPrimeExponentP:()Ljava/math/BigInteger;
            invokevirtual java.math.BigInteger.signum:()I
            ifeq 7
         3: .line 85
            aload 1 /* key */
            invokevirtual sun.security.rsa.RSAPrivateCrtKeyImpl.getPrimeExponentQ:()Ljava/math/BigInteger;
            invokevirtual java.math.BigInteger.signum:()I
            ifeq 7
         4: .line 86
            aload 1 /* key */
            invokevirtual sun.security.rsa.RSAPrivateCrtKeyImpl.getPrimeP:()Ljava/math/BigInteger;
            invokevirtual java.math.BigInteger.signum:()I
            ifeq 7
         5: .line 87
            aload 1 /* key */
            invokevirtual sun.security.rsa.RSAPrivateCrtKeyImpl.getPrimeQ:()Ljava/math/BigInteger;
            invokevirtual java.math.BigInteger.signum:()I
            ifeq 7
         6: .line 88
            aload 1 /* key */
            invokevirtual sun.security.rsa.RSAPrivateCrtKeyImpl.getCrtCoefficient:()Ljava/math/BigInteger;
            invokevirtual java.math.BigInteger.signum:()I
            ifne 12
         7: .line 89
      StackMap locals: sun.security.rsa.RSAPrivateCrtKeyImpl
      StackMap stack:
            new sun.security.rsa.RSAPrivateKeyImpl
            dup
         8: .line 90
            aload 1 /* key */
            getfield sun.security.rsa.RSAPrivateCrtKeyImpl.algid:Lsun/security/x509/AlgorithmId;
         9: .line 91
            aload 1 /* key */
            invokevirtual sun.security.rsa.RSAPrivateCrtKeyImpl.getModulus:()Ljava/math/BigInteger;
        10: .line 92
            aload 1 /* key */
            invokevirtual sun.security.rsa.RSAPrivateCrtKeyImpl.getPrivateExponent:()Ljava/math/BigInteger;
        11: .line 89
            invokespecial sun.security.rsa.RSAPrivateKeyImpl.<init>:(Lsun/security/x509/AlgorithmId;Ljava/math/BigInteger;Ljava/math/BigInteger;)V
            areturn
        12: .line 95
      StackMap locals:
      StackMap stack:
            aload 1 /* key */
            areturn
        end local 1 // sun.security.rsa.RSAPrivateCrtKeyImpl key
        end local 0 // byte[] encoded
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0   13     0  encoded  [B
            1   13     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=11, locals=11, args_size=10
        start local 0 // sun.security.rsa.RSAUtil$KeyType type
        start local 1 // java.security.spec.AlgorithmParameterSpec params
        start local 2 // java.math.BigInteger n
        start local 3 // java.math.BigInteger e
        start local 4 // java.math.BigInteger d
        start local 5 // java.math.BigInteger p
        start local 6 // java.math.BigInteger q
        start local 7 // java.math.BigInteger pe
        start local 8 // java.math.BigInteger qe
        start local 9 // java.math.BigInteger coeff
         0: .line 110
            aload 0 /* type */
            aload 1 /* params */
            invokestatic sun.security.rsa.RSAUtil.createAlgorithmId:(Lsun/security/rsa/RSAUtil$KeyType;Ljava/security/spec/AlgorithmParameterSpec;)Lsun/security/x509/AlgorithmId;
            astore 10 /* rsaId */
        start local 10 // sun.security.x509.AlgorithmId rsaId
         1: .line 111
            aload 3 /* e */
            invokevirtual java.math.BigInteger.signum:()I
            ifeq 4
            aload 5 /* p */
            invokevirtual java.math.BigInteger.signum:()I
            ifeq 4
         2: .line 112
            aload 6 /* q */
            invokevirtual java.math.BigInteger.signum:()I
            ifeq 4
            aload 7 /* pe */
            invokevirtual java.math.BigInteger.signum:()I
            ifeq 4
         3: .line 113
            aload 8 /* qe */
            invokevirtual java.math.BigInteger.signum:()I
            ifeq 4
            aload 9 /* coeff */
            invokevirtual java.math.BigInteger.signum:()I
            ifne 5
         4: .line 115
      StackMap locals: sun.security.x509.AlgorithmId
      StackMap stack:
            new sun.security.rsa.RSAPrivateKeyImpl
            dup
            aload 10 /* rsaId */
            aload 2 /* n */
            aload 4 /* d */
            invokespecial sun.security.rsa.RSAPrivateKeyImpl.<init>:(Lsun/security/x509/AlgorithmId;Ljava/math/BigInteger;Ljava/math/BigInteger;)V
            areturn
         5: .line 117
      StackMap locals:
      StackMap stack:
            new sun.security.rsa.RSAPrivateCrtKeyImpl
            dup
            aload 10 /* rsaId */
            aload 2 /* n */
            aload 3 /* e */
            aload 4 /* d */
         6: .line 118
            aload 5 /* p */
            aload 6 /* q */
            aload 7 /* pe */
            aload 8 /* qe */
            aload 9 /* coeff */
         7: .line 117
            invokespecial sun.security.rsa.RSAPrivateCrtKeyImpl.<init>:(Lsun/security/x509/AlgorithmId;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 10 // sun.security.x509.AlgorithmId rsaId
        end local 9 // java.math.BigInteger coeff
        end local 8 // java.math.BigInteger qe
        end local 7 // java.math.BigInteger pe
        end local 6 // java.math.BigInteger q
        end local 5 // java.math.BigInteger p
        end local 4 // java.math.BigInteger d
        end local 3 // java.math.BigInteger e
        end local 2 // java.math.BigInteger n
        end local 1 // java.security.spec.AlgorithmParameterSpec params
        end local 0 // sun.security.rsa.RSAUtil$KeyType type
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    8     0    type  Lsun/security/rsa/RSAUtil$KeyType;
            0    8     1  params  Ljava/security/spec/AlgorithmParameterSpec;
            0    8     2       n  Ljava/math/BigInteger;
            0    8     3       e  Ljava/math/BigInteger;
            0    8     4       d  Ljava/math/BigInteger;
            0    8     5       p  Ljava/math/BigInteger;
            0    8     6       q  Ljava/math/BigInteger;
            0    8     7      pe  Ljava/math/BigInteger;
            0    8     8      qe  Ljava/math/BigInteger;
            0    8     9   coeff  Ljava/math/BigInteger;
            1    8    10   rsaId  Lsun/security/x509/AlgorithmId;
    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 // sun.security.rsa.RSAPrivateCrtKeyImpl this
        start local 1 // byte[] encoded
         0: .line 125
            aload 0 /* this */
            invokespecial sun.security.pkcs.PKCS8Key.<init>:()V
         1: .line 126
            aload 1 /* encoded */
            ifnull 2
            aload 1 /* encoded */
            arraylength
            ifne 3
         2: .line 127
      StackMap locals: sun.security.rsa.RSAPrivateCrtKeyImpl byte[]
      StackMap stack:
            new java.security.InvalidKeyException
            dup
            ldc "Missing key encoding"
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;)V
            athrow
         3: .line 130
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* encoded */
            invokevirtual sun.security.rsa.RSAPrivateCrtKeyImpl.decode:([B)V
         4: .line 131
            aload 0 /* this */
            getfield sun.security.rsa.RSAPrivateCrtKeyImpl.n:Ljava/math/BigInteger;
            invokevirtual java.math.BigInteger.bitLength:()I
            aload 0 /* this */
            getfield sun.security.rsa.RSAPrivateCrtKeyImpl.e:Ljava/math/BigInteger;
            invokestatic sun.security.rsa.RSAKeyFactory.checkRSAProviderKeyLengths:(ILjava/math/BigInteger;)V
         5: .line 134
            aload 0 /* this */
            aload 0 /* this */
            getfield sun.security.rsa.RSAPrivateCrtKeyImpl.algid:Lsun/security/x509/AlgorithmId;
            invokestatic sun.security.rsa.RSAUtil.getParamSpec:(Lsun/security/x509/AlgorithmId;)Ljava/security/spec/AlgorithmParameterSpec;
            putfield sun.security.rsa.RSAPrivateCrtKeyImpl.keyParams:Ljava/security/spec/AlgorithmParameterSpec;
         6: .line 135
            goto 9
      StackMap locals:
      StackMap stack: java.security.ProviderException
         7: astore 2 /* e */
        start local 2 // java.security.ProviderException e
         8: .line 136
            new java.security.InvalidKeyException
            dup
            aload 2 /* e */
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 2 // java.security.ProviderException e
         9: .line 138
      StackMap locals:
      StackMap stack:
            return
        end local 1 // byte[] encoded
        end local 0 // sun.security.rsa.RSAPrivateCrtKeyImpl this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0   10     0     this  Lsun/security/rsa/RSAPrivateCrtKeyImpl;
            0   10     1  encoded  [B
            8    9     2        e  Ljava/security/ProviderException;
      Exception table:
        from    to  target  type
           5     6       7  Class java.security.ProviderException
    Exceptions:
      throws java.security.InvalidKeyException
    MethodParameters:
         Name  Flags
      encoded  

  void <init>(sun.security.x509.AlgorithmId, 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/x509/AlgorithmId;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=12, args_size=10
        start local 0 // sun.security.rsa.RSAPrivateCrtKeyImpl this
        start local 1 // sun.security.x509.AlgorithmId rsaId
        start local 2 // java.math.BigInteger n
        start local 3 // java.math.BigInteger e
        start local 4 // java.math.BigInteger d
        start local 5 // java.math.BigInteger p
        start local 6 // java.math.BigInteger q
        start local 7 // java.math.BigInteger pe
        start local 8 // java.math.BigInteger qe
        start local 9 // java.math.BigInteger coeff
         0: .line 144
            aload 0 /* this */
            invokespecial sun.security.pkcs.PKCS8Key.<init>:()V
         1: .line 148
            aload 2 /* n */
            invokevirtual java.math.BigInteger.bitLength:()I
            aload 3 /* e */
            invokestatic sun.security.rsa.RSAKeyFactory.checkRSAProviderKeyLengths:(ILjava/math/BigInteger;)V
         2: .line 150
            aload 0 /* this */
            aload 2 /* n */
            putfield sun.security.rsa.RSAPrivateCrtKeyImpl.n:Ljava/math/BigInteger;
         3: .line 151
            aload 0 /* this */
            aload 3 /* e */
            putfield sun.security.rsa.RSAPrivateCrtKeyImpl.e:Ljava/math/BigInteger;
         4: .line 152
            aload 0 /* this */
            aload 4 /* d */
            putfield sun.security.rsa.RSAPrivateCrtKeyImpl.d:Ljava/math/BigInteger;
         5: .line 153
            aload 0 /* this */
            aload 5 /* p */
            putfield sun.security.rsa.RSAPrivateCrtKeyImpl.p:Ljava/math/BigInteger;
         6: .line 154
            aload 0 /* this */
            aload 6 /* q */
            putfield sun.security.rsa.RSAPrivateCrtKeyImpl.q:Ljava/math/BigInteger;
         7: .line 155
            aload 0 /* this */
            aload 7 /* pe */
            putfield sun.security.rsa.RSAPrivateCrtKeyImpl.pe:Ljava/math/BigInteger;
         8: .line 156
            aload 0 /* this */
            aload 8 /* qe */
            putfield sun.security.rsa.RSAPrivateCrtKeyImpl.qe:Ljava/math/BigInteger;
         9: .line 157
            aload 0 /* this */
            aload 9 /* coeff */
            putfield sun.security.rsa.RSAPrivateCrtKeyImpl.coeff:Ljava/math/BigInteger;
        10: .line 158
            aload 0 /* this */
            aload 1 /* rsaId */
            invokestatic sun.security.rsa.RSAUtil.getParamSpec:(Lsun/security/x509/AlgorithmId;)Ljava/security/spec/AlgorithmParameterSpec;
            putfield sun.security.rsa.RSAPrivateCrtKeyImpl.keyParams:Ljava/security/spec/AlgorithmParameterSpec;
        11: .line 161
            aload 0 /* this */
            aload 1 /* rsaId */
            putfield sun.security.rsa.RSAPrivateCrtKeyImpl.algid:Lsun/security/x509/AlgorithmId;
        12: .line 163
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 10 /* out */
        start local 10 // sun.security.util.DerOutputStream out
        13: .line 164
            aload 10 /* out */
            iconst_0
            invokevirtual sun.security.util.DerOutputStream.putInteger:(I)V
        14: .line 165
            aload 10 /* out */
            aload 2 /* n */
            invokevirtual sun.security.util.DerOutputStream.putInteger:(Ljava/math/BigInteger;)V
        15: .line 166
            aload 10 /* out */
            aload 3 /* e */
            invokevirtual sun.security.util.DerOutputStream.putInteger:(Ljava/math/BigInteger;)V
        16: .line 167
            aload 10 /* out */
            aload 4 /* d */
            invokevirtual sun.security.util.DerOutputStream.putInteger:(Ljava/math/BigInteger;)V
        17: .line 168
            aload 10 /* out */
            aload 5 /* p */
            invokevirtual sun.security.util.DerOutputStream.putInteger:(Ljava/math/BigInteger;)V
        18: .line 169
            aload 10 /* out */
            aload 6 /* q */
            invokevirtual sun.security.util.DerOutputStream.putInteger:(Ljava/math/BigInteger;)V
        19: .line 170
            aload 10 /* out */
            aload 7 /* pe */
            invokevirtual sun.security.util.DerOutputStream.putInteger:(Ljava/math/BigInteger;)V
        20: .line 171
            aload 10 /* out */
            aload 8 /* qe */
            invokevirtual sun.security.util.DerOutputStream.putInteger:(Ljava/math/BigInteger;)V
        21: .line 172
            aload 10 /* out */
            aload 9 /* coeff */
            invokevirtual sun.security.util.DerOutputStream.putInteger:(Ljava/math/BigInteger;)V
        22: .line 174
            new sun.security.util.DerValue
            dup
            bipush 48
            aload 10 /* out */
            invokevirtual sun.security.util.DerOutputStream.toByteArray:()[B
            invokespecial sun.security.util.DerValue.<init>:(B[B)V
        23: .line 173
            astore 11 /* val */
        start local 11 // sun.security.util.DerValue val
        24: .line 175
            aload 0 /* this */
            aload 11 /* val */
            invokevirtual sun.security.util.DerValue.toByteArray:()[B
            putfield sun.security.rsa.RSAPrivateCrtKeyImpl.key:[B
        end local 11 // sun.security.util.DerValue val
        end local 10 // sun.security.util.DerOutputStream out
        25: .line 176
            goto 28
      StackMap locals: sun.security.rsa.RSAPrivateCrtKeyImpl sun.security.x509.AlgorithmId 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.io.IOException
        26: astore 10 /* exc */
        start local 10 // java.io.IOException exc
        27: .line 178
            new java.security.InvalidKeyException
            dup
            aload 10 /* exc */
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 10 // java.io.IOException exc
        28: .line 180
      StackMap locals:
      StackMap stack:
            return
        end local 9 // java.math.BigInteger coeff
        end local 8 // java.math.BigInteger qe
        end local 7 // java.math.BigInteger pe
        end local 6 // java.math.BigInteger q
        end local 5 // java.math.BigInteger p
        end local 4 // java.math.BigInteger d
        end local 3 // java.math.BigInteger e
        end local 2 // java.math.BigInteger n
        end local 1 // sun.security.x509.AlgorithmId rsaId
        end local 0 // sun.security.rsa.RSAPrivateCrtKeyImpl this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0   29     0   this  Lsun/security/rsa/RSAPrivateCrtKeyImpl;
            0   29     1  rsaId  Lsun/security/x509/AlgorithmId;
            0   29     2      n  Ljava/math/BigInteger;
            0   29     3      e  Ljava/math/BigInteger;
            0   29     4      d  Ljava/math/BigInteger;
            0   29     5      p  Ljava/math/BigInteger;
            0   29     6      q  Ljava/math/BigInteger;
            0   29     7     pe  Ljava/math/BigInteger;
            0   29     8     qe  Ljava/math/BigInteger;
            0   29     9  coeff  Ljava/math/BigInteger;
           13   25    10    out  Lsun/security/util/DerOutputStream;
           24   25    11    val  Lsun/security/util/DerValue;
           27   28    10    exc  Ljava/io/IOException;
      Exception table:
        from    to  target  type
          12    25      26  Class java.io.IOException
    Exceptions:
      throws java.security.InvalidKeyException
    MethodParameters:
       Name  Flags
      rsaId  
      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 // sun.security.rsa.RSAPrivateCrtKeyImpl this
         0: .line 185
            aload 0 /* this */
            getfield sun.security.rsa.RSAPrivateCrtKeyImpl.algid:Lsun/security/x509/AlgorithmId;
            invokevirtual sun.security.x509.AlgorithmId.getName:()Ljava/lang/String;
            areturn
        end local 0 // sun.security.rsa.RSAPrivateCrtKeyImpl this
      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 // sun.security.rsa.RSAPrivateCrtKeyImpl this
         0: .line 191
            aload 0 /* this */
            getfield sun.security.rsa.RSAPrivateCrtKeyImpl.n:Ljava/math/BigInteger;
            areturn
        end local 0 // sun.security.rsa.RSAPrivateCrtKeyImpl this
      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 // sun.security.rsa.RSAPrivateCrtKeyImpl this
         0: .line 197
            aload 0 /* this */
            getfield sun.security.rsa.RSAPrivateCrtKeyImpl.e:Ljava/math/BigInteger;
            areturn
        end local 0 // sun.security.rsa.RSAPrivateCrtKeyImpl this
      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 // sun.security.rsa.RSAPrivateCrtKeyImpl this
         0: .line 203
            aload 0 /* this */
            getfield sun.security.rsa.RSAPrivateCrtKeyImpl.d:Ljava/math/BigInteger;
            areturn
        end local 0 // sun.security.rsa.RSAPrivateCrtKeyImpl this
      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 // sun.security.rsa.RSAPrivateCrtKeyImpl this
         0: .line 209
            aload 0 /* this */
            getfield sun.security.rsa.RSAPrivateCrtKeyImpl.p:Ljava/math/BigInteger;
            areturn
        end local 0 // sun.security.rsa.RSAPrivateCrtKeyImpl this
      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 // sun.security.rsa.RSAPrivateCrtKeyImpl this
         0: .line 215
            aload 0 /* this */
            getfield sun.security.rsa.RSAPrivateCrtKeyImpl.q:Ljava/math/BigInteger;
            areturn
        end local 0 // sun.security.rsa.RSAPrivateCrtKeyImpl this
      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 // sun.security.rsa.RSAPrivateCrtKeyImpl this
         0: .line 221
            aload 0 /* this */
            getfield sun.security.rsa.RSAPrivateCrtKeyImpl.pe:Ljava/math/BigInteger;
            areturn
        end local 0 // sun.security.rsa.RSAPrivateCrtKeyImpl this
      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 // sun.security.rsa.RSAPrivateCrtKeyImpl this
         0: .line 227
            aload 0 /* this */
            getfield sun.security.rsa.RSAPrivateCrtKeyImpl.qe:Ljava/math/BigInteger;
            areturn
        end local 0 // sun.security.rsa.RSAPrivateCrtKeyImpl this
      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 // sun.security.rsa.RSAPrivateCrtKeyImpl this
         0: .line 233
            aload 0 /* this */
            getfield sun.security.rsa.RSAPrivateCrtKeyImpl.coeff:Ljava/math/BigInteger;
            areturn
        end local 0 // sun.security.rsa.RSAPrivateCrtKeyImpl this
      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 // sun.security.rsa.RSAPrivateCrtKeyImpl this
         0: .line 239
            aload 0 /* this */
            getfield sun.security.rsa.RSAPrivateCrtKeyImpl.keyParams:Ljava/security/spec/AlgorithmParameterSpec;
            areturn
        end local 0 // sun.security.rsa.RSAPrivateCrtKeyImpl this
      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 // sun.security.rsa.RSAPrivateCrtKeyImpl this
         0: .line 245
            new java.lang.StringBuilder
            dup
            ldc "SunRsaSign "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            invokevirtual sun.security.rsa.RSAPrivateCrtKeyImpl.getAlgorithm:()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;
            aload 0 /* this */
            getfield sun.security.rsa.RSAPrivateCrtKeyImpl.n:Ljava/math/BigInteger;
            invokevirtual java.math.BigInteger.bitLength:()I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
         1: .line 246
            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 /* this */
            getfield sun.security.rsa.RSAPrivateCrtKeyImpl.keyParams:Ljava/security/spec/AlgorithmParameterSpec;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            ldc "\n  modulus: "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 0 /* this */
            getfield sun.security.rsa.RSAPrivateCrtKeyImpl.n:Ljava/math/BigInteger;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
         2: .line 247
            ldc "\n  private exponent: "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 0 /* this */
            getfield sun.security.rsa.RSAPrivateCrtKeyImpl.d:Ljava/math/BigInteger;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
         3: .line 245
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            areturn
        end local 0 // sun.security.rsa.RSAPrivateCrtKeyImpl this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lsun/security/rsa/RSAPrivateCrtKeyImpl;

  protected void parseKeyBits();
    descriptor: ()V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=4, locals=5, args_size=1
        start local 0 // sun.security.rsa.RSAPrivateCrtKeyImpl this
         0: .line 255
            new sun.security.util.DerInputStream
            dup
            aload 0 /* this */
            getfield sun.security.rsa.RSAPrivateCrtKeyImpl.key:[B
            invokespecial sun.security.util.DerInputStream.<init>:([B)V
            astore 1 /* in */
        start local 1 // sun.security.util.DerInputStream in
         1: .line 256
            aload 1 /* in */
            invokevirtual sun.security.util.DerInputStream.getDerValue:()Lsun/security/util/DerValue;
            astore 2 /* derValue */
        start local 2 // sun.security.util.DerValue derValue
         2: .line 257
            aload 2 /* derValue */
            getfield sun.security.util.DerValue.tag:B
            bipush 48
            if_icmpeq 4
         3: .line 258
            new java.io.IOException
            dup
            ldc "Not a SEQUENCE"
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 260
      StackMap locals: sun.security.util.DerInputStream sun.security.util.DerValue
      StackMap stack:
            aload 2 /* derValue */
            getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
            astore 3 /* data */
        start local 3 // sun.security.util.DerInputStream data
         5: .line 261
            aload 3 /* data */
            invokevirtual sun.security.util.DerInputStream.getInteger:()I
            istore 4 /* version */
        start local 4 // int version
         6: .line 262
            iload 4 /* version */
            ifeq 8
         7: .line 263
            new java.io.IOException
            dup
            ldc "Version must be 0"
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
         8: .line 273
      StackMap locals: sun.security.util.DerInputStream int
      StackMap stack:
            aload 0 /* this */
            aload 3 /* data */
            invokevirtual sun.security.util.DerInputStream.getPositiveBigInteger:()Ljava/math/BigInteger;
            putfield sun.security.rsa.RSAPrivateCrtKeyImpl.n:Ljava/math/BigInteger;
         9: .line 274
            aload 0 /* this */
            aload 3 /* data */
            invokevirtual sun.security.util.DerInputStream.getPositiveBigInteger:()Ljava/math/BigInteger;
            putfield sun.security.rsa.RSAPrivateCrtKeyImpl.e:Ljava/math/BigInteger;
        10: .line 275
            aload 0 /* this */
            aload 3 /* data */
            invokevirtual sun.security.util.DerInputStream.getPositiveBigInteger:()Ljava/math/BigInteger;
            putfield sun.security.rsa.RSAPrivateCrtKeyImpl.d:Ljava/math/BigInteger;
        11: .line 276
            aload 0 /* this */
            aload 3 /* data */
            invokevirtual sun.security.util.DerInputStream.getPositiveBigInteger:()Ljava/math/BigInteger;
            putfield sun.security.rsa.RSAPrivateCrtKeyImpl.p:Ljava/math/BigInteger;
        12: .line 277
            aload 0 /* this */
            aload 3 /* data */
            invokevirtual sun.security.util.DerInputStream.getPositiveBigInteger:()Ljava/math/BigInteger;
            putfield sun.security.rsa.RSAPrivateCrtKeyImpl.q:Ljava/math/BigInteger;
        13: .line 278
            aload 0 /* this */
            aload 3 /* data */
            invokevirtual sun.security.util.DerInputStream.getPositiveBigInteger:()Ljava/math/BigInteger;
            putfield sun.security.rsa.RSAPrivateCrtKeyImpl.pe:Ljava/math/BigInteger;
        14: .line 279
            aload 0 /* this */
            aload 3 /* data */
            invokevirtual sun.security.util.DerInputStream.getPositiveBigInteger:()Ljava/math/BigInteger;
            putfield sun.security.rsa.RSAPrivateCrtKeyImpl.qe:Ljava/math/BigInteger;
        15: .line 280
            aload 0 /* this */
            aload 3 /* data */
            invokevirtual sun.security.util.DerInputStream.getPositiveBigInteger:()Ljava/math/BigInteger;
            putfield sun.security.rsa.RSAPrivateCrtKeyImpl.coeff:Ljava/math/BigInteger;
        16: .line 281
            aload 2 /* derValue */
            getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
            invokevirtual sun.security.util.DerInputStream.available:()I
            ifeq 20
        17: .line 282
            new java.io.IOException
            dup
            ldc "Extra data available"
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        end local 4 // int version
        end local 3 // sun.security.util.DerInputStream data
        end local 2 // sun.security.util.DerValue derValue
        end local 1 // sun.security.util.DerInputStream in
        18: .line 284
      StackMap locals: sun.security.rsa.RSAPrivateCrtKeyImpl
      StackMap stack: java.io.IOException
            astore 1 /* e */
        start local 1 // java.io.IOException e
        19: .line 285
            new java.security.InvalidKeyException
            dup
            ldc "Invalid RSA private key"
            aload 1 /* e */
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 1 // java.io.IOException e
        20: .line 287
      StackMap locals:
      StackMap stack:
            return
        end local 0 // sun.security.rsa.RSAPrivateCrtKeyImpl this
      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