class sun.security.mscapi.RSAPublicKey extends sun.security.mscapi.Key implements java.security.interfaces.RSAPublicKey
  minor version: 0
  major version: 59
  flags: flags: (0x0020) ACC_SUPER
  this_class: sun.security.mscapi.RSAPublicKey
  super_class: sun.security.mscapi.Key
{
  private static final long serialVersionUID;
    descriptor: J
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: -2289561342425825391

  private byte[] publicKeyBlob;
    descriptor: [B
    flags: (0x0002) ACC_PRIVATE

  private byte[] encoding;
    descriptor: [B
    flags: (0x0002) ACC_PRIVATE

  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

  void <init>(long, long, int);
    descriptor: (JJI)V
    flags: (0x0000) 
    Code:
      stack=7, locals=6, args_size=4
        start local 0 // sun.security.mscapi.RSAPublicKey this
        start local 1 // long hCryptProv
        start local 3 // long hCryptKey
        start local 5 // int keyLength
         0: .line 54
            aload 0 /* this */
            new sun.security.mscapi.Key$NativeHandles
            dup
            lload 1 /* hCryptProv */
            lload 3 /* hCryptKey */
            invokespecial sun.security.mscapi.Key$NativeHandles.<init>:(JJ)V
            iload 5 /* keyLength */
            invokespecial sun.security.mscapi.Key.<init>:(Lsun/security/mscapi/Key$NativeHandles;I)V
         1: .line 44
            aload 0 /* this */
            aconst_null
            putfield sun.security.mscapi.RSAPublicKey.publicKeyBlob:[B
         2: .line 45
            aload 0 /* this */
            aconst_null
            putfield sun.security.mscapi.RSAPublicKey.encoding:[B
         3: .line 46
            aload 0 /* this */
            aconst_null
            putfield sun.security.mscapi.RSAPublicKey.modulus:Ljava/math/BigInteger;
         4: .line 47
            aload 0 /* this */
            aconst_null
            putfield sun.security.mscapi.RSAPublicKey.exponent:Ljava/math/BigInteger;
         5: .line 55
            return
        end local 5 // int keyLength
        end local 3 // long hCryptKey
        end local 1 // long hCryptProv
        end local 0 // sun.security.mscapi.RSAPublicKey this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    6     0        this  Lsun/security/mscapi/RSAPublicKey;
            0    6     1  hCryptProv  J
            0    6     3   hCryptKey  J
            0    6     5   keyLength  I
    MethodParameters:
            Name  Flags
      hCryptProv  
      hCryptKey   
      keyLength   

  void <init>(sun.security.mscapi.Key$NativeHandles, int);
    descriptor: (Lsun/security/mscapi/Key$NativeHandles;I)V
    flags: (0x0000) 
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // sun.security.mscapi.RSAPublicKey this
        start local 1 // sun.security.mscapi.Key$NativeHandles handles
        start local 2 // int keyLength
         0: .line 62
            aload 0 /* this */
            aload 1 /* handles */
            iload 2 /* keyLength */
            invokespecial sun.security.mscapi.Key.<init>:(Lsun/security/mscapi/Key$NativeHandles;I)V
         1: .line 44
            aload 0 /* this */
            aconst_null
            putfield sun.security.mscapi.RSAPublicKey.publicKeyBlob:[B
         2: .line 45
            aload 0 /* this */
            aconst_null
            putfield sun.security.mscapi.RSAPublicKey.encoding:[B
         3: .line 46
            aload 0 /* this */
            aconst_null
            putfield sun.security.mscapi.RSAPublicKey.modulus:Ljava/math/BigInteger;
         4: .line 47
            aload 0 /* this */
            aconst_null
            putfield sun.security.mscapi.RSAPublicKey.exponent:Ljava/math/BigInteger;
         5: .line 63
            return
        end local 2 // int keyLength
        end local 1 // sun.security.mscapi.Key$NativeHandles handles
        end local 0 // sun.security.mscapi.RSAPublicKey this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    6     0       this  Lsun/security/mscapi/RSAPublicKey;
            0    6     1    handles  Lsun/security/mscapi/Key$NativeHandles;
            0    6     2  keyLength  I
    MethodParameters:
           Name  Flags
      handles    
      keyLength  

  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.mscapi.RSAPublicKey this
         0: .line 77
            ldc "RSA"
            areturn
        end local 0 // sun.security.mscapi.RSAPublicKey this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/mscapi/RSAPublicKey;

  public java.lang.String toString();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=1
        start local 0 // sun.security.mscapi.RSAPublicKey this
         0: .line 85
            new java.lang.StringBuffer
            dup
            invokespecial java.lang.StringBuffer.<init>:()V
            astore 1 /* sb */
        start local 1 // java.lang.StringBuffer sb
         1: .line 87
            aload 1 /* sb */
            ldc "RSAPublicKey [size="
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            aload 0 /* this */
            getfield sun.security.mscapi.RSAPublicKey.keyLength:I
            invokevirtual java.lang.StringBuffer.append:(I)Ljava/lang/StringBuffer;
         2: .line 88
            ldc " bits, type="
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            aload 0 /* this */
            getfield sun.security.mscapi.RSAPublicKey.handles:Lsun/security/mscapi/Key$NativeHandles;
            getfield sun.security.mscapi.Key$NativeHandles.hCryptKey:J
            invokestatic sun.security.mscapi.RSAPublicKey.getKeyType:(J)Ljava/lang/String;
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
         3: .line 89
            ldc ", container="
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            aload 0 /* this */
            getfield sun.security.mscapi.RSAPublicKey.handles:Lsun/security/mscapi/Key$NativeHandles;
            getfield sun.security.mscapi.Key$NativeHandles.hCryptProv:J
            invokestatic sun.security.mscapi.RSAPublicKey.getContainerName:(J)Ljava/lang/String;
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
         4: .line 90
            ldc "]\n  modulus: "
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            aload 0 /* this */
            invokevirtual sun.security.mscapi.RSAPublicKey.getModulus:()Ljava/math/BigInteger;
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/Object;)Ljava/lang/StringBuffer;
         5: .line 91
            ldc "\n  public exponent: "
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            aload 0 /* this */
            invokevirtual sun.security.mscapi.RSAPublicKey.getPublicExponent:()Ljava/math/BigInteger;
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/Object;)Ljava/lang/StringBuffer;
            pop
         6: .line 93
            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.RSAPublicKey this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    7     0  this  Lsun/security/mscapi/RSAPublicKey;
            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.RSAPublicKey this
         0: .line 101
            aload 0 /* this */
            getfield sun.security.mscapi.RSAPublicKey.exponent:Ljava/math/BigInteger;
            ifnonnull 6
         1: .line 104
            aload 0 /* this */
            aload 0 /* this */
            aload 0 /* this */
            getfield sun.security.mscapi.RSAPublicKey.handles:Lsun/security/mscapi/Key$NativeHandles;
            getfield sun.security.mscapi.Key$NativeHandles.hCryptKey:J
            invokevirtual sun.security.mscapi.RSAPublicKey.getPublicKeyBlob:(J)[B
            putfield sun.security.mscapi.RSAPublicKey.publicKeyBlob:[B
         2: .line 105
            aload 0 /* this */
            new java.math.BigInteger
            dup
            iconst_1
            aload 0 /* this */
            aload 0 /* this */
            getfield sun.security.mscapi.RSAPublicKey.publicKeyBlob:[B
            invokevirtual sun.security.mscapi.RSAPublicKey.getExponent:([B)[B
            invokespecial java.math.BigInteger.<init>:(I[B)V
            putfield sun.security.mscapi.RSAPublicKey.exponent:Ljava/math/BigInteger;
         3: .line 107
            goto 6
      StackMap locals:
      StackMap stack: java.security.KeyException
         4: astore 1 /* e */
        start local 1 // java.security.KeyException e
         5: .line 108
            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
         6: .line 112
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.mscapi.RSAPublicKey.exponent:Ljava/math/BigInteger;
            areturn
        end local 0 // sun.security.mscapi.RSAPublicKey this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    7     0  this  Lsun/security/mscapi/RSAPublicKey;
            5    6     1     e  Ljava/security/KeyException;
      Exception table:
        from    to  target  type
           1     3       4  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.RSAPublicKey this
         0: .line 120
            aload 0 /* this */
            getfield sun.security.mscapi.RSAPublicKey.modulus:Ljava/math/BigInteger;
            ifnonnull 6
         1: .line 123
            aload 0 /* this */
            aload 0 /* this */
            aload 0 /* this */
            getfield sun.security.mscapi.RSAPublicKey.handles:Lsun/security/mscapi/Key$NativeHandles;
            getfield sun.security.mscapi.Key$NativeHandles.hCryptKey:J
            invokevirtual sun.security.mscapi.RSAPublicKey.getPublicKeyBlob:(J)[B
            putfield sun.security.mscapi.RSAPublicKey.publicKeyBlob:[B
         2: .line 124
            aload 0 /* this */
            new java.math.BigInteger
            dup
            iconst_1
            aload 0 /* this */
            aload 0 /* this */
            getfield sun.security.mscapi.RSAPublicKey.publicKeyBlob:[B
            invokevirtual sun.security.mscapi.RSAPublicKey.getModulus:([B)[B
            invokespecial java.math.BigInteger.<init>:(I[B)V
            putfield sun.security.mscapi.RSAPublicKey.modulus:Ljava/math/BigInteger;
         3: .line 126
            goto 6
      StackMap locals:
      StackMap stack: java.security.KeyException
         4: astore 1 /* e */
        start local 1 // java.security.KeyException e
         5: .line 127
            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
         6: .line 131
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.mscapi.RSAPublicKey.modulus:Ljava/math/BigInteger;
            areturn
        end local 0 // sun.security.mscapi.RSAPublicKey this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    7     0  this  Lsun/security/mscapi/RSAPublicKey;
            5    6     1     e  Ljava/security/KeyException;
      Exception table:
        from    to  target  type
           1     3       4  Class java.security.KeyException

  public java.lang.String getFormat();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.mscapi.RSAPublicKey this
         0: .line 153
            ldc "X.509"
            areturn
        end local 0 // sun.security.mscapi.RSAPublicKey this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/mscapi/RSAPublicKey;

  public byte[] getEncoded();
    descriptor: ()[B
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=1, args_size=1
        start local 0 // sun.security.mscapi.RSAPublicKey this
         0: .line 165
            aload 0 /* this */
            getfield sun.security.mscapi.RSAPublicKey.encoding:[B
            ifnonnull 6
         1: .line 168
            aload 0 /* this */
            new sun.security.rsa.RSAPublicKeyImpl
            dup
            aload 0 /* this */
            invokevirtual sun.security.mscapi.RSAPublicKey.getModulus:()Ljava/math/BigInteger;
         2: .line 169
            aload 0 /* this */
            invokevirtual sun.security.mscapi.RSAPublicKey.getPublicExponent:()Ljava/math/BigInteger;
            invokespecial sun.security.rsa.RSAPublicKeyImpl.<init>:(Ljava/math/BigInteger;Ljava/math/BigInteger;)V
            invokevirtual sun.security.rsa.RSAPublicKeyImpl.getEncoded:()[B
         3: .line 168
            putfield sun.security.mscapi.RSAPublicKey.encoding:[B
         4: .line 171
            goto 6
      StackMap locals:
      StackMap stack: java.security.KeyException
         5: pop
         6: .line 175
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.mscapi.RSAPublicKey.encoding:[B
            areturn
        end local 0 // sun.security.mscapi.RSAPublicKey this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    7     0  this  Lsun/security/mscapi/RSAPublicKey;
      Exception table:
        from    to  target  type
           1     4       5  Class java.security.KeyException

  protected java.lang.Object writeReplace();
    descriptor: ()Ljava/lang/Object;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=6, locals=1, args_size=1
        start local 0 // sun.security.mscapi.RSAPublicKey this
         0: .line 179
            new java.security.KeyRep
            dup
            getstatic java.security.KeyRep$Type.PUBLIC:Ljava/security/KeyRep$Type;
         1: .line 180
            aload 0 /* this */
            invokevirtual sun.security.mscapi.RSAPublicKey.getAlgorithm:()Ljava/lang/String;
         2: .line 181
            aload 0 /* this */
            invokevirtual sun.security.mscapi.RSAPublicKey.getFormat:()Ljava/lang/String;
         3: .line 182
            aload 0 /* this */
            invokevirtual sun.security.mscapi.RSAPublicKey.getEncoded:()[B
         4: .line 179
            invokespecial java.security.KeyRep.<init>:(Ljava/security/KeyRep$Type;Ljava/lang/String;Ljava/lang/String;[B)V
            areturn
        end local 0 // sun.security.mscapi.RSAPublicKey this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lsun/security/mscapi/RSAPublicKey;
    Exceptions:
      throws java.io.ObjectStreamException

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

  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  
}
SourceFile: "RSAPublicKey.java"
InnerClasses:
  public final Type = java.security.KeyRep$Type of java.security.KeyRep
  NativeHandles = sun.security.mscapi.Key$NativeHandles of sun.security.mscapi.Key