public class sun.security.mscapi.CPublicKey$CRSAPublicKey extends sun.security.mscapi.CPublicKey implements java.security.interfaces.RSAPublicKey
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: sun.security.mscapi.CPublicKey$CRSAPublicKey
  super_class: sun.security.mscapi.CPublicKey
{
  private java.math.BigInteger modulus;
    descriptor: Ljava/math/BigInteger;
    flags: (0x0002) ACC_PRIVATE

  private java.math.BigInteger exponent;
    descriptor: Ljava/math/BigInteger;
    flags: (0x0002) ACC_PRIVATE

  private static final long serialVersionUID;
    descriptor: J
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 12

  void <init>(sun.security.mscapi.CKey$NativeHandles, int);
    descriptor: (Lsun/security/mscapi/CKey$NativeHandles;I)V
    flags: (0x0000) 
    Code:
      stack=4, locals=3, args_size=3
        start local 0 // sun.security.mscapi.CPublicKey$CRSAPublicKey this
        start local 1 // sun.security.mscapi.CKey$NativeHandles handles
        start local 2 // int keyLength
         0: .line 125
            aload 0 /* this */
            ldc "RSA"
            aload 1 /* handles */
            iload 2 /* keyLength */
            invokespecial sun.security.mscapi.CPublicKey.<init>:(Ljava/lang/String;Lsun/security/mscapi/CKey$NativeHandles;I)V
         1: .line 120
            aload 0 /* this */
            aconst_null
            putfield sun.security.mscapi.CPublicKey$CRSAPublicKey.modulus:Ljava/math/BigInteger;
         2: .line 121
            aload 0 /* this */
            aconst_null
            putfield sun.security.mscapi.CPublicKey$CRSAPublicKey.exponent:Ljava/math/BigInteger;
         3: .line 126
            return
        end local 2 // int keyLength
        end local 1 // sun.security.mscapi.CKey$NativeHandles handles
        end local 0 // sun.security.mscapi.CPublicKey$CRSAPublicKey this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    4     0       this  Lsun/security/mscapi/CPublicKey$CRSAPublicKey;
            0    4     1    handles  Lsun/security/mscapi/CKey$NativeHandles;
            0    4     2  keyLength  I
    MethodParameters:
           Name  Flags
      handles    
      keyLength  

  public java.lang.String toString();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=2, args_size=1
        start local 0 // sun.security.mscapi.CPublicKey$CRSAPublicKey this
         0: .line 129
            new java.lang.StringBuffer
            dup
            invokespecial java.lang.StringBuffer.<init>:()V
            astore 1 /* sb */
        start local 1 // java.lang.StringBuffer sb
         1: .line 130
            aload 1 /* sb */
            new java.lang.StringBuilder
            dup
            aload 0 /* this */
            getfield sun.security.mscapi.CPublicKey$CRSAPublicKey.algorithm:Ljava/lang/String;
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc "PublicKey [size="
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            aload 0 /* this */
            getfield sun.security.mscapi.CPublicKey$CRSAPublicKey.keyLength:I
            invokevirtual java.lang.StringBuffer.append:(I)Ljava/lang/StringBuffer;
         2: .line 131
            ldc " bits, type="
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            aload 0 /* this */
            getfield sun.security.mscapi.CPublicKey$CRSAPublicKey.handles:Lsun/security/mscapi/CKey$NativeHandles;
            getfield sun.security.mscapi.CKey$NativeHandles.hCryptKey:J
            invokestatic sun.security.mscapi.CPublicKey$CRSAPublicKey.getKeyType:(J)Ljava/lang/String;
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
         3: .line 132
            ldc ", container="
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            aload 0 /* this */
            getfield sun.security.mscapi.CPublicKey$CRSAPublicKey.handles:Lsun/security/mscapi/CKey$NativeHandles;
            getfield sun.security.mscapi.CKey$NativeHandles.hCryptProv:J
            invokestatic sun.security.mscapi.CPublicKey$CRSAPublicKey.getContainerName:(J)Ljava/lang/String;
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
         4: .line 133
            ldc "]\n  modulus: "
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            aload 0 /* this */
            invokevirtual sun.security.mscapi.CPublicKey$CRSAPublicKey.getModulus:()Ljava/math/BigInteger;
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/Object;)Ljava/lang/StringBuffer;
         5: .line 134
            ldc "\n  public exponent: "
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            aload 0 /* this */
            invokevirtual sun.security.mscapi.CPublicKey$CRSAPublicKey.getPublicExponent:()Ljava/math/BigInteger;
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/Object;)Ljava/lang/StringBuffer;
            pop
         6: .line 135
            aload 1 /* sb */
            invokevirtual java.lang.StringBuffer.toString:()Ljava/lang/String;
            areturn
        end local 1 // java.lang.StringBuffer sb
        end local 0 // sun.security.mscapi.CPublicKey$CRSAPublicKey this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    7     0  this  Lsun/security/mscapi/CPublicKey$CRSAPublicKey;
            1    7     1    sb  Ljava/lang/StringBuffer;

  public java.math.BigInteger getPublicExponent();
    descriptor: ()Ljava/math/BigInteger;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=2, args_size=1
        start local 0 // sun.security.mscapi.CPublicKey$CRSAPublicKey this
         0: .line 140
            aload 0 /* this */
            getfield sun.security.mscapi.CPublicKey$CRSAPublicKey.exponent:Ljava/math/BigInteger;
            ifnonnull 8
         1: .line 142
            aload 0 /* this */
         2: .line 143
            aload 0 /* this */
            getfield sun.security.mscapi.CPublicKey$CRSAPublicKey.handles:Lsun/security/mscapi/CKey$NativeHandles;
            getfield sun.security.mscapi.CKey$NativeHandles.hCryptProv:J
            aload 0 /* this */
            getfield sun.security.mscapi.CPublicKey$CRSAPublicKey.handles:Lsun/security/mscapi/CKey$NativeHandles;
            getfield sun.security.mscapi.CKey$NativeHandles.hCryptKey:J
         3: .line 142
            invokevirtual sun.security.mscapi.CPublicKey$CRSAPublicKey.getPublicKeyBlob:(JJ)[B
            astore 1 /* publicKeyBlob */
        start local 1 // byte[] publicKeyBlob
         4: .line 144
            aload 0 /* this */
            new java.math.BigInteger
            dup
            iconst_1
            aload 0 /* this */
            aload 1 /* publicKeyBlob */
            invokevirtual sun.security.mscapi.CPublicKey$CRSAPublicKey.getExponent:([B)[B
            invokespecial java.math.BigInteger.<init>:(I[B)V
            putfield sun.security.mscapi.CPublicKey$CRSAPublicKey.exponent:Ljava/math/BigInteger;
        end local 1 // byte[] publicKeyBlob
         5: .line 145
            goto 8
      StackMap locals:
      StackMap stack: java.security.KeyException
         6: astore 1 /* e */
        start local 1 // java.security.KeyException e
         7: .line 146
            new java.security.ProviderException
            dup
            aload 1 /* e */
            invokespecial java.security.ProviderException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 1 // java.security.KeyException e
         8: .line 149
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.mscapi.CPublicKey$CRSAPublicKey.exponent:Ljava/math/BigInteger;
            areturn
        end local 0 // sun.security.mscapi.CPublicKey$CRSAPublicKey this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0    9     0           this  Lsun/security/mscapi/CPublicKey$CRSAPublicKey;
            4    5     1  publicKeyBlob  [B
            7    8     1              e  Ljava/security/KeyException;
      Exception table:
        from    to  target  type
           1     5       6  Class java.security.KeyException

  public java.math.BigInteger getModulus();
    descriptor: ()Ljava/math/BigInteger;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=2, args_size=1
        start local 0 // sun.security.mscapi.CPublicKey$CRSAPublicKey this
         0: .line 154
            aload 0 /* this */
            getfield sun.security.mscapi.CPublicKey$CRSAPublicKey.modulus:Ljava/math/BigInteger;
            ifnonnull 8
         1: .line 156
            aload 0 /* this */
         2: .line 157
            aload 0 /* this */
            getfield sun.security.mscapi.CPublicKey$CRSAPublicKey.handles:Lsun/security/mscapi/CKey$NativeHandles;
            getfield sun.security.mscapi.CKey$NativeHandles.hCryptProv:J
            aload 0 /* this */
            getfield sun.security.mscapi.CPublicKey$CRSAPublicKey.handles:Lsun/security/mscapi/CKey$NativeHandles;
            getfield sun.security.mscapi.CKey$NativeHandles.hCryptKey:J
         3: .line 156
            invokevirtual sun.security.mscapi.CPublicKey$CRSAPublicKey.getPublicKeyBlob:(JJ)[B
            astore 1 /* publicKeyBlob */
        start local 1 // byte[] publicKeyBlob
         4: .line 158
            aload 0 /* this */
            new java.math.BigInteger
            dup
            iconst_1
            aload 0 /* this */
            aload 1 /* publicKeyBlob */
            invokevirtual sun.security.mscapi.CPublicKey$CRSAPublicKey.getModulus:([B)[B
            invokespecial java.math.BigInteger.<init>:(I[B)V
            putfield sun.security.mscapi.CPublicKey$CRSAPublicKey.modulus:Ljava/math/BigInteger;
        end local 1 // byte[] publicKeyBlob
         5: .line 159
            goto 8
      StackMap locals:
      StackMap stack: java.security.KeyException
         6: astore 1 /* e */
        start local 1 // java.security.KeyException e
         7: .line 160
            new java.security.ProviderException
            dup
            aload 1 /* e */
            invokespecial java.security.ProviderException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 1 // java.security.KeyException e
         8: .line 163
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.mscapi.CPublicKey$CRSAPublicKey.modulus:Ljava/math/BigInteger;
            areturn
        end local 0 // sun.security.mscapi.CPublicKey$CRSAPublicKey this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0    9     0           this  Lsun/security/mscapi/CPublicKey$CRSAPublicKey;
            4    5     1  publicKeyBlob  [B
            7    8     1              e  Ljava/security/KeyException;
      Exception table:
        from    to  target  type
           1     5       6  Class java.security.KeyException

  public byte[] getEncoded();
    descriptor: ()[B
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=1, args_size=1
        start local 0 // sun.security.mscapi.CPublicKey$CRSAPublicKey this
         0: .line 168
            aload 0 /* this */
            getfield sun.security.mscapi.CPublicKey$CRSAPublicKey.encoding:[B
            ifnonnull 8
         1: .line 170
            aload 0 /* this */
            getstatic sun.security.rsa.RSAUtil$KeyType.RSA:Lsun/security/rsa/RSAUtil$KeyType;
            aconst_null
         2: .line 171
            aload 0 /* this */
            invokevirtual sun.security.mscapi.CPublicKey$CRSAPublicKey.getModulus:()Ljava/math/BigInteger;
            aload 0 /* this */
            invokevirtual sun.security.mscapi.CPublicKey$CRSAPublicKey.getPublicExponent:()Ljava/math/BigInteger;
         3: .line 170
            invokestatic sun.security.rsa.RSAPublicKeyImpl.newKey:(Lsun/security/rsa/RSAUtil$KeyType;Ljava/security/spec/AlgorithmParameterSpec;Ljava/math/BigInteger;Ljava/math/BigInteger;)Ljava/security/interfaces/RSAPublicKey;
         4: .line 171
            invokeinterface java.security.interfaces.RSAPublicKey.getEncoded:()[B
         5: .line 170
            putfield sun.security.mscapi.CPublicKey$CRSAPublicKey.encoding:[B
         6: .line 172
            goto 8
      StackMap locals:
      StackMap stack: java.security.KeyException
         7: pop
         8: .line 176
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.mscapi.CPublicKey$CRSAPublicKey.encoding:[B
            areturn
        end local 0 // sun.security.mscapi.CPublicKey$CRSAPublicKey this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    9     0  this  Lsun/security/mscapi/CPublicKey$CRSAPublicKey;
      Exception table:
        from    to  target  type
           1     6       7  Class java.security.KeyException

  private native byte[] getExponent(byte[]);
    descriptor: ([B)[B
    flags: (0x0102) ACC_PRIVATE, ACC_NATIVE
    Exceptions:
      throws java.security.KeyException
    MethodParameters:
         Name  Flags
      keyBlob  

  private native byte[] getModulus(byte[]);
    descriptor: ([B)[B
    flags: (0x0102) ACC_PRIVATE, ACC_NATIVE
    Exceptions:
      throws java.security.KeyException
    MethodParameters:
         Name  Flags
      keyBlob  

  public long getHCryptKey();
    descriptor: ()J
    flags: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
    Code:
      stack=2, locals=1, args_size=1
         0: .line 1
            aload 0
            invokespecial sun.security.mscapi.CPublicKey.getHCryptKey:()J
            lreturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public int length();
    descriptor: ()I
    flags: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
    Code:
      stack=1, locals=1, args_size=1
         0: .line 1
            aload 0
            invokespecial sun.security.mscapi.CPublicKey.length:()I
            ireturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public java.lang.String getAlgorithm();
    descriptor: ()Ljava/lang/String;
    flags: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
    Code:
      stack=1, locals=1, args_size=1
         0: .line 1
            aload 0
            invokespecial sun.security.mscapi.CPublicKey.getAlgorithm:()Ljava/lang/String;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public long getHCryptProvider();
    descriptor: ()J
    flags: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
    Code:
      stack=2, locals=1, args_size=1
         0: .line 1
            aload 0
            invokespecial sun.security.mscapi.CPublicKey.getHCryptProvider:()J
            lreturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature
}
SourceFile: "CPublicKey.java"
NestHost: sun.security.mscapi.CPublicKey
InnerClasses:
  NativeHandles = sun.security.mscapi.CKey$NativeHandles of sun.security.mscapi.CKey
  public CRSAPublicKey = sun.security.mscapi.CPublicKey$CRSAPublicKey of sun.security.mscapi.CPublicKey
  public final KeyType = sun.security.rsa.RSAUtil$KeyType of sun.security.rsa.RSAUtil