public final class sun.security.mscapi.CRSACipher extends javax.crypto.CipherSpi
  minor version: 0
  major version: 59
  flags: flags: (0x0031) ACC_PUBLIC, ACC_FINAL, ACC_SUPER
  this_class: sun.security.mscapi.CRSACipher
  super_class: javax.crypto.CipherSpi
{
  private static final byte[] B0;
    descriptor: [B
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final int MODE_ENCRYPT;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 1

  private static final int MODE_DECRYPT;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 2

  private static final int MODE_SIGN;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 3

  private static final int MODE_VERIFY;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 4

  private static final java.lang.String PAD_PKCS1;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "PKCS1Padding"

  private static final int PAD_PKCS1_LENGTH;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 11

  private int mode;
    descriptor: I
    flags: (0x0002) ACC_PRIVATE

  private java.lang.String paddingType;
    descriptor: Ljava/lang/String;
    flags: (0x0002) ACC_PRIVATE

  private int paddingLength;
    descriptor: I
    flags: (0x0002) ACC_PRIVATE

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

  private int bufOfs;
    descriptor: I
    flags: (0x0002) ACC_PRIVATE

  private int outputSize;
    descriptor: I
    flags: (0x0002) ACC_PRIVATE

  private sun.security.mscapi.CKey publicKey;
    descriptor: Lsun/security/mscapi/CKey;
    flags: (0x0002) ACC_PRIVATE

  private sun.security.mscapi.CKey privateKey;
    descriptor: Lsun/security/mscapi/CKey;
    flags: (0x0002) ACC_PRIVATE

  private java.security.spec.AlgorithmParameterSpec spec;
    descriptor: Ljava/security/spec/AlgorithmParameterSpec;
    flags: (0x0002) ACC_PRIVATE

  private java.security.SecureRandom random;
    descriptor: Ljava/security/SecureRandom;
    flags: (0x0002) ACC_PRIVATE

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 65
            iconst_0
            newarray 8
            putstatic sun.security.mscapi.CRSACipher.B0:[B
         1: .line 78
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // sun.security.mscapi.CRSACipher this
         0: .line 107
            aload 0 /* this */
            invokespecial javax.crypto.CipherSpi.<init>:()V
         1: .line 85
            aload 0 /* this */
            iconst_0
            putfield sun.security.mscapi.CRSACipher.paddingLength:I
         2: .line 102
            aload 0 /* this */
            aconst_null
            putfield sun.security.mscapi.CRSACipher.spec:Ljava/security/spec/AlgorithmParameterSpec;
         3: .line 108
            aload 0 /* this */
            ldc "PKCS1Padding"
            putfield sun.security.mscapi.CRSACipher.paddingType:Ljava/lang/String;
         4: .line 109
            return
        end local 0 // sun.security.mscapi.CRSACipher this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lsun/security/mscapi/CRSACipher;

  protected void engineSetMode(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=5, locals=2, args_size=2
        start local 0 // sun.security.mscapi.CRSACipher this
        start local 1 // java.lang.String mode
         0: .line 114
            aload 1 /* mode */
            ldc "ECB"
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifne 2
         1: .line 115
            new java.security.NoSuchAlgorithmException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Unsupported mode "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* mode */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.security.NoSuchAlgorithmException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 117
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.lang.String mode
        end local 0 // sun.security.mscapi.CRSACipher this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lsun/security/mscapi/CRSACipher;
            0    3     1  mode  Ljava/lang/String;
    Exceptions:
      throws java.security.NoSuchAlgorithmException
    MethodParameters:
      Name  Flags
      mode  

  protected void engineSetPadding(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=5, locals=2, args_size=2
        start local 0 // sun.security.mscapi.CRSACipher this
        start local 1 // java.lang.String paddingName
         0: .line 123
            aload 1 /* paddingName */
            ldc "PKCS1Padding"
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifeq 3
         1: .line 124
            aload 0 /* this */
            ldc "PKCS1Padding"
            putfield sun.security.mscapi.CRSACipher.paddingType:Ljava/lang/String;
         2: .line 125
            goto 6
         3: .line 126
      StackMap locals:
      StackMap stack:
            new javax.crypto.NoSuchPaddingException
            dup
         4: .line 127
            new java.lang.StringBuilder
            dup
            ldc "Padding "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* paddingName */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc " not supported"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         5: .line 126
            invokespecial javax.crypto.NoSuchPaddingException.<init>:(Ljava/lang/String;)V
            athrow
         6: .line 129
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.lang.String paddingName
        end local 0 // sun.security.mscapi.CRSACipher this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    7     0         this  Lsun/security/mscapi/CRSACipher;
            0    7     1  paddingName  Ljava/lang/String;
    Exceptions:
      throws javax.crypto.NoSuchPaddingException
    MethodParameters:
             Name  Flags
      paddingName  

  protected int engineGetBlockSize();
    descriptor: ()I
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.mscapi.CRSACipher this
         0: .line 134
            iconst_0
            ireturn
        end local 0 // sun.security.mscapi.CRSACipher this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/mscapi/CRSACipher;

  protected int engineGetOutputSize(int);
    descriptor: (I)I
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=1, locals=2, args_size=2
        start local 0 // sun.security.mscapi.CRSACipher this
        start local 1 // int inputLen
         0: .line 140
            aload 0 /* this */
            getfield sun.security.mscapi.CRSACipher.outputSize:I
            ireturn
        end local 1 // int inputLen
        end local 0 // sun.security.mscapi.CRSACipher this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    1     0      this  Lsun/security/mscapi/CRSACipher;
            0    1     1  inputLen  I
    MethodParameters:
          Name  Flags
      inputLen  

  protected byte[] engineGetIV();
    descriptor: ()[B
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.mscapi.CRSACipher this
         0: .line 146
            aconst_null
            areturn
        end local 0 // sun.security.mscapi.CRSACipher this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/mscapi/CRSACipher;

  protected java.security.AlgorithmParameters engineGetParameters();
    descriptor: ()Ljava/security/AlgorithmParameters;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.mscapi.CRSACipher this
         0: .line 152
            aconst_null
            areturn
        end local 0 // sun.security.mscapi.CRSACipher this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/mscapi/CRSACipher;

  protected void engineInit(int, java.security.Key, java.security.SecureRandom);
    descriptor: (ILjava/security/Key;Ljava/security/SecureRandom;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=3, locals=4, args_size=4
        start local 0 // sun.security.mscapi.CRSACipher this
        start local 1 // int opmode
        start local 2 // java.security.Key key
        start local 3 // java.security.SecureRandom random
         0: .line 158
            aload 0 /* this */
            iload 1 /* opmode */
            aload 2 /* key */
            invokevirtual sun.security.mscapi.CRSACipher.init:(ILjava/security/Key;)V
         1: .line 159
            return
        end local 3 // java.security.SecureRandom random
        end local 2 // java.security.Key key
        end local 1 // int opmode
        end local 0 // sun.security.mscapi.CRSACipher this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    2     0    this  Lsun/security/mscapi/CRSACipher;
            0    2     1  opmode  I
            0    2     2     key  Ljava/security/Key;
            0    2     3  random  Ljava/security/SecureRandom;
    Exceptions:
      throws java.security.InvalidKeyException
    MethodParameters:
        Name  Flags
      opmode  
      key     
      random  

  protected void engineInit(int, java.security.Key, java.security.spec.AlgorithmParameterSpec, java.security.SecureRandom);
    descriptor: (ILjava/security/Key;Ljava/security/spec/AlgorithmParameterSpec;Ljava/security/SecureRandom;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=3, locals=5, args_size=5
        start local 0 // sun.security.mscapi.CRSACipher this
        start local 1 // int opmode
        start local 2 // java.security.Key key
        start local 3 // java.security.spec.AlgorithmParameterSpec params
        start local 4 // java.security.SecureRandom random
         0: .line 167
            aload 3 /* params */
            ifnull 7
         1: .line 168
            aload 3 /* params */
            instanceof sun.security.internal.spec.TlsRsaPremasterSecretParameterSpec
            ifne 5
         2: .line 169
            new java.security.InvalidAlgorithmParameterException
            dup
         3: .line 170
            ldc "Parameters not supported"
         4: .line 169
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            athrow
         5: .line 172
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 3 /* params */
            putfield sun.security.mscapi.CRSACipher.spec:Ljava/security/spec/AlgorithmParameterSpec;
         6: .line 173
            aload 0 /* this */
            aload 4 /* random */
            putfield sun.security.mscapi.CRSACipher.random:Ljava/security/SecureRandom;
         7: .line 175
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iload 1 /* opmode */
            aload 2 /* key */
            invokevirtual sun.security.mscapi.CRSACipher.init:(ILjava/security/Key;)V
         8: .line 176
            return
        end local 4 // java.security.SecureRandom random
        end local 3 // java.security.spec.AlgorithmParameterSpec params
        end local 2 // java.security.Key key
        end local 1 // int opmode
        end local 0 // sun.security.mscapi.CRSACipher this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    9     0    this  Lsun/security/mscapi/CRSACipher;
            0    9     1  opmode  I
            0    9     2     key  Ljava/security/Key;
            0    9     3  params  Ljava/security/spec/AlgorithmParameterSpec;
            0    9     4  random  Ljava/security/SecureRandom;
    Exceptions:
      throws java.security.InvalidKeyException, java.security.InvalidAlgorithmParameterException
    MethodParameters:
        Name  Flags
      opmode  
      key     
      params  
      random  

  protected void engineInit(int, java.security.Key, java.security.AlgorithmParameters, java.security.SecureRandom);
    descriptor: (ILjava/security/Key;Ljava/security/AlgorithmParameters;Ljava/security/SecureRandom;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=3, locals=5, args_size=5
        start local 0 // sun.security.mscapi.CRSACipher this
        start local 1 // int opmode
        start local 2 // java.security.Key key
        start local 3 // java.security.AlgorithmParameters params
        start local 4 // java.security.SecureRandom random
         0: .line 183
            aload 3 /* params */
            ifnull 4
         1: .line 184
            new java.security.InvalidAlgorithmParameterException
            dup
         2: .line 185
            ldc "Parameters not supported"
         3: .line 184
            invokespecial java.security.InvalidAlgorithmParameterException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 187
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iload 1 /* opmode */
            aload 2 /* key */
            invokevirtual sun.security.mscapi.CRSACipher.init:(ILjava/security/Key;)V
         5: .line 188
            return
        end local 4 // java.security.SecureRandom random
        end local 3 // java.security.AlgorithmParameters params
        end local 2 // java.security.Key key
        end local 1 // int opmode
        end local 0 // sun.security.mscapi.CRSACipher this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    6     0    this  Lsun/security/mscapi/CRSACipher;
            0    6     1  opmode  I
            0    6     2     key  Ljava/security/Key;
            0    6     3  params  Ljava/security/AlgorithmParameters;
            0    6     4  random  Ljava/security/SecureRandom;
    Exceptions:
      throws java.security.InvalidKeyException, java.security.InvalidAlgorithmParameterException
    MethodParameters:
        Name  Flags
      opmode  
      key     
      params  
      random  

  private void init(int, java.security.Key);
    descriptor: (ILjava/security/Key;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=12, args_size=3
        start local 0 // sun.security.mscapi.CRSACipher this
        start local 1 // int opmode
        start local 2 // java.security.Key key
         0: .line 195
            iload 1 /* opmode */
            tableswitch { // 1 - 4
                    1: 1
                    2: 4
                    3: 1
                    4: 4
              default: 7
          }
         1: .line 198
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            bipush 11
            putfield sun.security.mscapi.CRSACipher.paddingLength:I
         2: .line 199
            iconst_1
            istore 3 /* encrypt */
        start local 3 // boolean encrypt
         3: .line 200
            goto 8
        end local 3 // boolean encrypt
         4: .line 203
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_0
            putfield sun.security.mscapi.CRSACipher.paddingLength:I
         5: .line 204
            iconst_0
            istore 3 /* encrypt */
        start local 3 // boolean encrypt
         6: .line 205
            goto 8
        end local 3 // boolean encrypt
         7: .line 207
      StackMap locals:
      StackMap stack:
            new java.security.InvalidKeyException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Unknown mode: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            iload 1 /* opmode */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;)V
            athrow
        start local 3 // boolean encrypt
         8: .line 210
      StackMap locals: int
      StackMap stack:
            aload 2 /* key */
            instanceof sun.security.mscapi.CKey
            ifne 30
         9: .line 211
            aload 2 /* key */
            instanceof java.security.interfaces.RSAPublicKey
            ifeq 29
        10: .line 213
            aload 2 /* key */
            checkcast java.security.interfaces.RSAPublicKey
        11: .line 212
            astore 4 /* rsaKey */
        start local 4 // java.security.interfaces.RSAPublicKey rsaKey
        12: .line 217
            aload 4 /* rsaKey */
            invokeinterface java.security.interfaces.RSAPublicKey.getModulus:()Ljava/math/BigInteger;
            astore 5 /* modulus */
        start local 5 // java.math.BigInteger modulus
        13: .line 218
            aload 4 /* rsaKey */
            invokeinterface java.security.interfaces.RSAPublicKey.getPublicExponent:()Ljava/math/BigInteger;
            astore 6 /* exponent */
        start local 6 // java.math.BigInteger exponent
        14: .line 222
            aload 5 /* modulus */
            invokevirtual java.math.BigInteger.bitLength:()I
            bipush 7
            iadd
            bipush -8
            iand
        15: .line 223
            aload 6 /* exponent */
            iconst_m1
            sipush 16384
        16: .line 222
            invokestatic sun.security.rsa.RSAKeyFactory.checkKeyLengths:(ILjava/math/BigInteger;II)V
        17: .line 225
            aload 5 /* modulus */
            invokevirtual java.math.BigInteger.toByteArray:()[B
            astore 7 /* modulusBytes */
        start local 7 // byte[] modulusBytes
        18: .line 226
            aload 6 /* exponent */
            invokevirtual java.math.BigInteger.toByteArray:()[B
            astore 8 /* exponentBytes */
        start local 8 // byte[] exponentBytes
        19: .line 229
            aload 7 /* modulusBytes */
            iconst_0
            baload
            ifne 21
        20: .line 230
            aload 7 /* modulusBytes */
            arraylength
            iconst_1
            isub
            bipush 8
            imul
            goto 22
        21: .line 231
      StackMap locals: sun.security.mscapi.CRSACipher int java.security.Key int java.security.interfaces.RSAPublicKey java.math.BigInteger java.math.BigInteger byte[] byte[]
      StackMap stack:
            aload 7 /* modulusBytes */
            arraylength
            bipush 8
            imul
        22: .line 229
      StackMap locals:
      StackMap stack: int
            istore 9 /* keyBitLength */
        start local 9 // int keyBitLength
        23: .line 234
            iload 9 /* keyBitLength */
            aload 7 /* modulusBytes */
            aload 8 /* exponentBytes */
        24: .line 233
            invokestatic sun.security.mscapi.CSignature$RSA.generatePublicKeyBlob:(I[B[B)[B
            astore 10 /* keyBlob */
        start local 10 // byte[] keyBlob
        25: .line 237
            ldc "RSA"
            aload 10 /* keyBlob */
            iload 9 /* keyBitLength */
            invokestatic sun.security.mscapi.CSignature.importPublicKey:(Ljava/lang/String;[BI)Lsun/security/mscapi/CPublicKey;
            astore 2 /* key */
        26: .line 239
            goto 30
      StackMap locals: sun.security.mscapi.CRSACipher int java.security.Key int java.security.interfaces.RSAPublicKey java.math.BigInteger java.math.BigInteger byte[] byte[] int byte[]
      StackMap stack: java.security.KeyStoreException
        27: astore 11 /* e */
        start local 11 // java.security.KeyStoreException e
        28: .line 240
            new java.security.InvalidKeyException
            dup
            aload 11 /* e */
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 11 // java.security.KeyStoreException e
        end local 10 // byte[] keyBlob
        end local 9 // int keyBitLength
        end local 8 // byte[] exponentBytes
        end local 7 // byte[] modulusBytes
        end local 6 // java.math.BigInteger exponent
        end local 5 // java.math.BigInteger modulus
        end local 4 // java.security.interfaces.RSAPublicKey rsaKey
        29: .line 244
      StackMap locals: sun.security.mscapi.CRSACipher int java.security.Key int
      StackMap stack:
            new java.security.InvalidKeyException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Unsupported key type: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 2 /* key */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;)V
            athrow
        30: .line 248
      StackMap locals:
      StackMap stack:
            aload 2 /* key */
            instanceof java.security.PublicKey
            ifeq 38
        31: .line 249
            aload 0 /* this */
            iload 3 /* encrypt */
            ifeq 32
            iconst_1
            goto 33
      StackMap locals:
      StackMap stack: sun.security.mscapi.CRSACipher
        32: iconst_4
      StackMap locals: sun.security.mscapi.CRSACipher int java.security.Key int
      StackMap stack: sun.security.mscapi.CRSACipher int
        33: putfield sun.security.mscapi.CRSACipher.mode:I
        34: .line 250
            aload 0 /* this */
            aload 2 /* key */
            checkcast sun.security.mscapi.CKey
            putfield sun.security.mscapi.CRSACipher.publicKey:Lsun/security/mscapi/CKey;
        35: .line 251
            aload 0 /* this */
            aconst_null
            putfield sun.security.mscapi.CRSACipher.privateKey:Lsun/security/mscapi/CKey;
        36: .line 252
            aload 0 /* this */
            aload 0 /* this */
            getfield sun.security.mscapi.CRSACipher.publicKey:Lsun/security/mscapi/CKey;
            invokevirtual sun.security.mscapi.CKey.length:()I
            bipush 8
            idiv
            putfield sun.security.mscapi.CRSACipher.outputSize:I
        37: .line 253
            goto 47
      StackMap locals:
      StackMap stack:
        38: aload 2 /* key */
            instanceof java.security.PrivateKey
            ifeq 46
        39: .line 254
            aload 0 /* this */
            iload 3 /* encrypt */
            ifeq 40
            iconst_3
            goto 41
      StackMap locals:
      StackMap stack: sun.security.mscapi.CRSACipher
        40: iconst_2
      StackMap locals: sun.security.mscapi.CRSACipher int java.security.Key int
      StackMap stack: sun.security.mscapi.CRSACipher int
        41: putfield sun.security.mscapi.CRSACipher.mode:I
        42: .line 255
            aload 0 /* this */
            aload 2 /* key */
            checkcast sun.security.mscapi.CKey
            putfield sun.security.mscapi.CRSACipher.privateKey:Lsun/security/mscapi/CKey;
        43: .line 256
            aload 0 /* this */
            aconst_null
            putfield sun.security.mscapi.CRSACipher.publicKey:Lsun/security/mscapi/CKey;
        44: .line 257
            aload 0 /* this */
            aload 0 /* this */
            getfield sun.security.mscapi.CRSACipher.privateKey:Lsun/security/mscapi/CKey;
            invokevirtual sun.security.mscapi.CKey.length:()I
            bipush 8
            idiv
            putfield sun.security.mscapi.CRSACipher.outputSize:I
        45: .line 258
            goto 47
        46: .line 259
      StackMap locals:
      StackMap stack:
            new java.security.InvalidKeyException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Unknown key type: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 2 /* key */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;)V
            athrow
        47: .line 262
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_0
            putfield sun.security.mscapi.CRSACipher.bufOfs:I
        48: .line 263
            aload 0 /* this */
            aload 0 /* this */
            getfield sun.security.mscapi.CRSACipher.outputSize:I
            newarray 8
            putfield sun.security.mscapi.CRSACipher.buffer:[B
        49: .line 264
            return
        end local 3 // boolean encrypt
        end local 2 // java.security.Key key
        end local 1 // int opmode
        end local 0 // sun.security.mscapi.CRSACipher this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   50     0           this  Lsun/security/mscapi/CRSACipher;
            0   50     1         opmode  I
            0   50     2            key  Ljava/security/Key;
            3    4     3        encrypt  Z
            6    7     3        encrypt  Z
            8   50     3        encrypt  Z
           12   29     4         rsaKey  Ljava/security/interfaces/RSAPublicKey;
           13   29     5        modulus  Ljava/math/BigInteger;
           14   29     6       exponent  Ljava/math/BigInteger;
           18   29     7   modulusBytes  [B
           19   29     8  exponentBytes  [B
           23   29     9   keyBitLength  I
           25   29    10        keyBlob  [B
           28   29    11              e  Ljava/security/KeyStoreException;
      Exception table:
        from    to  target  type
          25    26      27  Class java.security.KeyStoreException
    Exceptions:
      throws java.security.InvalidKeyException
    MethodParameters:
        Name  Flags
      opmode  
      key     

  private void update(byte[], int, int);
    descriptor: ([BII)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=4, args_size=4
        start local 0 // sun.security.mscapi.CRSACipher this
        start local 1 // byte[] in
        start local 2 // int inOfs
        start local 3 // int inLen
         0: .line 268
            iload 3 /* inLen */
            ifeq 1
            aload 1 /* in */
            ifnonnull 2
         1: .line 269
      StackMap locals:
      StackMap stack:
            return
         2: .line 271
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.mscapi.CRSACipher.bufOfs:I
            iload 3 /* inLen */
            iadd
            aload 0 /* this */
            getfield sun.security.mscapi.CRSACipher.buffer:[B
            arraylength
            aload 0 /* this */
            getfield sun.security.mscapi.CRSACipher.paddingLength:I
            isub
            if_icmple 5
         3: .line 272
            aload 0 /* this */
            aload 0 /* this */
            getfield sun.security.mscapi.CRSACipher.buffer:[B
            arraylength
            iconst_1
            iadd
            putfield sun.security.mscapi.CRSACipher.bufOfs:I
         4: .line 273
            return
         5: .line 275
      StackMap locals:
      StackMap stack:
            aload 1 /* in */
            iload 2 /* inOfs */
            aload 0 /* this */
            getfield sun.security.mscapi.CRSACipher.buffer:[B
            aload 0 /* this */
            getfield sun.security.mscapi.CRSACipher.bufOfs:I
            iload 3 /* inLen */
            invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
         6: .line 276
            aload 0 /* this */
            dup
            getfield sun.security.mscapi.CRSACipher.bufOfs:I
            iload 3 /* inLen */
            iadd
            putfield sun.security.mscapi.CRSACipher.bufOfs:I
         7: .line 277
            return
        end local 3 // int inLen
        end local 2 // int inOfs
        end local 1 // byte[] in
        end local 0 // sun.security.mscapi.CRSACipher this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    8     0   this  Lsun/security/mscapi/CRSACipher;
            0    8     1     in  [B
            0    8     2  inOfs  I
            0    8     3  inLen  I
    MethodParameters:
       Name  Flags
      in     
      inOfs  
      inLen  

  private byte[] doFinal();
    descriptor: ()[B
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=4, args_size=1
        start local 0 // sun.security.mscapi.CRSACipher this
         0: .line 282
            aload 0 /* this */
            getfield sun.security.mscapi.CRSACipher.bufOfs:I
            aload 0 /* this */
            getfield sun.security.mscapi.CRSACipher.buffer:[B
            arraylength
            if_icmple 4
         1: .line 283
            new javax.crypto.IllegalBlockSizeException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Data must not be longer than "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         2: .line 284
            aload 0 /* this */
            getfield sun.security.mscapi.CRSACipher.buffer:[B
            arraylength
            aload 0 /* this */
            getfield sun.security.mscapi.CRSACipher.paddingLength:I
            isub
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc " bytes"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         3: .line 283
            invokespecial javax.crypto.IllegalBlockSizeException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 288
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.mscapi.CRSACipher.buffer:[B
            astore 1 /* data */
        start local 1 // byte[] data
         5: .line 289
            aload 0 /* this */
            getfield sun.security.mscapi.CRSACipher.mode:I
            tableswitch { // 1 - 4
                    1: 16
                    2: 21
                    3: 6
                    4: 11
              default: 26
          }
         6: .line 291
      StackMap locals: byte[]
      StackMap stack:
            aload 1 /* data */
            aload 0 /* this */
            getfield sun.security.mscapi.CRSACipher.bufOfs:I
         7: .line 292
            aload 0 /* this */
            getfield sun.security.mscapi.CRSACipher.privateKey:Lsun/security/mscapi/CKey;
            invokevirtual sun.security.mscapi.CKey.getHCryptKey:()J
            iconst_1
         8: .line 291
            invokestatic sun.security.mscapi.CRSACipher.encryptDecrypt:([BIJZ)[B
            astore 3
         9: .line 314
            aload 0 /* this */
            iconst_0
            putfield sun.security.mscapi.CRSACipher.bufOfs:I
        10: .line 291
            aload 3
            areturn
        11: .line 295
      StackMap locals:
      StackMap stack:
            aload 1 /* data */
            aload 0 /* this */
            getfield sun.security.mscapi.CRSACipher.bufOfs:I
        12: .line 296
            aload 0 /* this */
            getfield sun.security.mscapi.CRSACipher.publicKey:Lsun/security/mscapi/CKey;
            invokevirtual sun.security.mscapi.CKey.getHCryptKey:()J
            iconst_0
        13: .line 295
            invokestatic sun.security.mscapi.CRSACipher.encryptDecrypt:([BIJZ)[B
            astore 3
        14: .line 314
            aload 0 /* this */
            iconst_0
            putfield sun.security.mscapi.CRSACipher.bufOfs:I
        15: .line 295
            aload 3
            areturn
        16: .line 299
      StackMap locals:
      StackMap stack:
            aload 1 /* data */
            aload 0 /* this */
            getfield sun.security.mscapi.CRSACipher.bufOfs:I
        17: .line 300
            aload 0 /* this */
            getfield sun.security.mscapi.CRSACipher.publicKey:Lsun/security/mscapi/CKey;
            invokevirtual sun.security.mscapi.CKey.getHCryptKey:()J
            iconst_1
        18: .line 299
            invokestatic sun.security.mscapi.CRSACipher.encryptDecrypt:([BIJZ)[B
            astore 3
        19: .line 314
            aload 0 /* this */
            iconst_0
            putfield sun.security.mscapi.CRSACipher.bufOfs:I
        20: .line 299
            aload 3
            areturn
        21: .line 303
      StackMap locals:
      StackMap stack:
            aload 1 /* data */
            aload 0 /* this */
            getfield sun.security.mscapi.CRSACipher.bufOfs:I
        22: .line 304
            aload 0 /* this */
            getfield sun.security.mscapi.CRSACipher.privateKey:Lsun/security/mscapi/CKey;
            invokevirtual sun.security.mscapi.CKey.getHCryptKey:()J
            iconst_0
        23: .line 303
            invokestatic sun.security.mscapi.CRSACipher.encryptDecrypt:([BIJZ)[B
            astore 3
        24: .line 314
            aload 0 /* this */
            iconst_0
            putfield sun.security.mscapi.CRSACipher.bufOfs:I
        25: .line 303
            aload 3
            areturn
        26: .line 307
      StackMap locals:
      StackMap stack:
            new java.lang.AssertionError
            dup
            ldc "Internal error"
            invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
            athrow
        end local 1 // byte[] data
        27: .line 310
      StackMap locals: sun.security.mscapi.CRSACipher
      StackMap stack: java.security.KeyException
            astore 1 /* e */
        start local 1 // java.security.KeyException e
        28: .line 311
            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
        29: .line 313
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 2
        30: .line 314
            aload 0 /* this */
            iconst_0
            putfield sun.security.mscapi.CRSACipher.bufOfs:I
        31: .line 315
            aload 2
            athrow
        end local 0 // sun.security.mscapi.CRSACipher this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   32     0  this  Lsun/security/mscapi/CRSACipher;
            5   27     1  data  [B
           28   29     1     e  Ljava/security/KeyException;
      Exception table:
        from    to  target  type
           4     9      27  Class java.security.KeyException
          11    14      27  Class java.security.KeyException
          16    19      27  Class java.security.KeyException
          21    24      27  Class java.security.KeyException
          26    27      27  Class java.security.KeyException
           4     9      29  any
          11    14      29  any
          16    19      29  any
          21    24      29  any
          26    29      29  any
    Exceptions:
      throws javax.crypto.BadPaddingException, javax.crypto.IllegalBlockSizeException

  protected byte[] engineUpdate(byte[], int, int);
    descriptor: ([BII)[B
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=4, locals=4, args_size=4
        start local 0 // sun.security.mscapi.CRSACipher this
        start local 1 // byte[] in
        start local 2 // int inOfs
        start local 3 // int inLen
         0: .line 320
            aload 0 /* this */
            aload 1 /* in */
            iload 2 /* inOfs */
            iload 3 /* inLen */
            invokevirtual sun.security.mscapi.CRSACipher.update:([BII)V
         1: .line 321
            getstatic sun.security.mscapi.CRSACipher.B0:[B
            areturn
        end local 3 // int inLen
        end local 2 // int inOfs
        end local 1 // byte[] in
        end local 0 // sun.security.mscapi.CRSACipher this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    2     0   this  Lsun/security/mscapi/CRSACipher;
            0    2     1     in  [B
            0    2     2  inOfs  I
            0    2     3  inLen  I
    MethodParameters:
       Name  Flags
      in     
      inOfs  
      inLen  

  protected int engineUpdate(byte[], int, int, byte[], int);
    descriptor: ([BII[BI)I
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=4, locals=6, args_size=6
        start local 0 // sun.security.mscapi.CRSACipher this
        start local 1 // byte[] in
        start local 2 // int inOfs
        start local 3 // int inLen
        start local 4 // byte[] out
        start local 5 // int outOfs
         0: .line 327
            aload 0 /* this */
            aload 1 /* in */
            iload 2 /* inOfs */
            iload 3 /* inLen */
            invokevirtual sun.security.mscapi.CRSACipher.update:([BII)V
         1: .line 328
            iconst_0
            ireturn
        end local 5 // int outOfs
        end local 4 // byte[] out
        end local 3 // int inLen
        end local 2 // int inOfs
        end local 1 // byte[] in
        end local 0 // sun.security.mscapi.CRSACipher this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    2     0    this  Lsun/security/mscapi/CRSACipher;
            0    2     1      in  [B
            0    2     2   inOfs  I
            0    2     3   inLen  I
            0    2     4     out  [B
            0    2     5  outOfs  I
    MethodParameters:
        Name  Flags
      in      
      inOfs   
      inLen   
      out     
      outOfs  

  protected byte[] engineDoFinal(byte[], int, int);
    descriptor: ([BII)[B
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=4, locals=4, args_size=4
        start local 0 // sun.security.mscapi.CRSACipher this
        start local 1 // byte[] in
        start local 2 // int inOfs
        start local 3 // int inLen
         0: .line 334
            aload 0 /* this */
            aload 1 /* in */
            iload 2 /* inOfs */
            iload 3 /* inLen */
            invokevirtual sun.security.mscapi.CRSACipher.update:([BII)V
         1: .line 335
            aload 0 /* this */
            invokevirtual sun.security.mscapi.CRSACipher.doFinal:()[B
            areturn
        end local 3 // int inLen
        end local 2 // int inOfs
        end local 1 // byte[] in
        end local 0 // sun.security.mscapi.CRSACipher this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    2     0   this  Lsun/security/mscapi/CRSACipher;
            0    2     1     in  [B
            0    2     2  inOfs  I
            0    2     3  inLen  I
    Exceptions:
      throws javax.crypto.BadPaddingException, javax.crypto.IllegalBlockSizeException
    MethodParameters:
       Name  Flags
      in     
      inOfs  
      inLen  

  protected int engineDoFinal(byte[], int, int, byte[], int);
    descriptor: ([BII[BI)I
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=5, locals=8, args_size=6
        start local 0 // sun.security.mscapi.CRSACipher this
        start local 1 // byte[] in
        start local 2 // int inOfs
        start local 3 // int inLen
        start local 4 // byte[] out
        start local 5 // int outOfs
         0: .line 342
            aload 0 /* this */
            getfield sun.security.mscapi.CRSACipher.outputSize:I
            aload 4 /* out */
            arraylength
            iload 5 /* outOfs */
            isub
            if_icmple 4
         1: .line 343
            new javax.crypto.ShortBufferException
            dup
         2: .line 344
            new java.lang.StringBuilder
            dup
            ldc "Need "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield sun.security.mscapi.CRSACipher.outputSize:I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc " bytes for output"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         3: .line 343
            invokespecial javax.crypto.ShortBufferException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 346
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* in */
            iload 2 /* inOfs */
            iload 3 /* inLen */
            invokevirtual sun.security.mscapi.CRSACipher.update:([BII)V
         5: .line 347
            aload 0 /* this */
            invokevirtual sun.security.mscapi.CRSACipher.doFinal:()[B
            astore 6 /* result */
        start local 6 // byte[] result
         6: .line 348
            aload 6 /* result */
            arraylength
            istore 7 /* n */
        start local 7 // int n
         7: .line 349
            aload 6 /* result */
            iconst_0
            aload 4 /* out */
            iload 5 /* outOfs */
            iload 7 /* n */
            invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
         8: .line 350
            iload 7 /* n */
            ireturn
        end local 7 // int n
        end local 6 // byte[] result
        end local 5 // int outOfs
        end local 4 // byte[] out
        end local 3 // int inLen
        end local 2 // int inOfs
        end local 1 // byte[] in
        end local 0 // sun.security.mscapi.CRSACipher this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    9     0    this  Lsun/security/mscapi/CRSACipher;
            0    9     1      in  [B
            0    9     2   inOfs  I
            0    9     3   inLen  I
            0    9     4     out  [B
            0    9     5  outOfs  I
            6    9     6  result  [B
            7    9     7       n  I
    Exceptions:
      throws javax.crypto.ShortBufferException, javax.crypto.BadPaddingException, javax.crypto.IllegalBlockSizeException
    MethodParameters:
        Name  Flags
      in      
      inOfs   
      inLen   
      out     
      outOfs  

  protected byte[] engineWrap(java.security.Key);
    descriptor: (Ljava/security/Key;)[B
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=4, locals=4, args_size=2
        start local 0 // sun.security.mscapi.CRSACipher this
        start local 1 // java.security.Key key
         0: .line 356
            aload 1 /* key */
            invokeinterface java.security.Key.getEncoded:()[B
            astore 2 /* encoded */
        start local 2 // byte[] encoded
         1: .line 357
            aload 2 /* encoded */
            ifnull 2
            aload 2 /* encoded */
            arraylength
            ifne 3
         2: .line 358
      StackMap locals: byte[]
      StackMap stack:
            new java.security.InvalidKeyException
            dup
            ldc "Could not obtain encoded key"
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;)V
            athrow
         3: .line 360
      StackMap locals:
      StackMap stack:
            aload 2 /* encoded */
            arraylength
            aload 0 /* this */
            getfield sun.security.mscapi.CRSACipher.buffer:[B
            arraylength
            if_icmple 5
         4: .line 361
            new java.security.InvalidKeyException
            dup
            ldc "Key is too long for wrapping"
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;)V
            athrow
         5: .line 363
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 2 /* encoded */
            iconst_0
            aload 2 /* encoded */
            arraylength
            invokevirtual sun.security.mscapi.CRSACipher.update:([BII)V
         6: .line 365
            aload 0 /* this */
            invokevirtual sun.security.mscapi.CRSACipher.doFinal:()[B
         7: areturn
         8: .line 366
      StackMap locals:
      StackMap stack: javax.crypto.BadPaddingException
            astore 3 /* e */
        start local 3 // javax.crypto.BadPaddingException e
         9: .line 368
            new java.security.InvalidKeyException
            dup
            ldc "Wrapping failed"
            aload 3 /* e */
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 3 // javax.crypto.BadPaddingException e
        end local 2 // byte[] encoded
        end local 1 // java.security.Key key
        end local 0 // sun.security.mscapi.CRSACipher this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0   10     0     this  Lsun/security/mscapi/CRSACipher;
            0   10     1      key  Ljava/security/Key;
            1   10     2  encoded  [B
            9   10     3        e  Ljavax/crypto/BadPaddingException;
      Exception table:
        from    to  target  type
           6     7       8  Class javax.crypto.BadPaddingException
    Exceptions:
      throws java.security.InvalidKeyException, javax.crypto.IllegalBlockSizeException
    MethodParameters:
      Name  Flags
      key   

  protected java.security.Key engineUnwrap(byte[], java.lang.String, int);
    descriptor: ([BLjava/lang/String;I)Ljava/security/Key;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=5, locals=8, args_size=4
        start local 0 // sun.security.mscapi.CRSACipher this
        start local 1 // byte[] wrappedKey
        start local 2 // java.lang.String algorithm
        start local 3 // int type
         0: .line 378
            aload 1 /* wrappedKey */
            arraylength
            aload 0 /* this */
            getfield sun.security.mscapi.CRSACipher.buffer:[B
            arraylength
            if_icmple 2
         1: .line 379
            new java.security.InvalidKeyException
            dup
            ldc "Key is too long for unwrapping"
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 383
      StackMap locals:
      StackMap stack:
            aload 2 /* algorithm */
            ldc "TlsRsaPremasterSecret"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
         3: .line 382
            istore 4 /* isTlsRsaPremasterSecret */
        start local 4 // boolean isTlsRsaPremasterSecret
         4: .line 384
            aconst_null
            astore 5 /* failover */
        start local 5 // java.lang.Exception failover
         5: .line 385
            aconst_null
            astore 6 /* encoded */
        start local 6 // byte[] encoded
         6: .line 387
            aload 0 /* this */
            aload 1 /* wrappedKey */
            iconst_0
            aload 1 /* wrappedKey */
            arraylength
            invokevirtual sun.security.mscapi.CRSACipher.update:([BII)V
         7: .line 389
            aload 0 /* this */
            invokevirtual sun.security.mscapi.CRSACipher.doFinal:()[B
            astore 6 /* encoded */
         8: .line 390
            goto 16
      StackMap locals: sun.security.mscapi.CRSACipher byte[] java.lang.String int int java.lang.Exception byte[]
      StackMap stack: javax.crypto.BadPaddingException
         9: astore 7 /* e */
        start local 7 // javax.crypto.BadPaddingException e
        10: .line 391
            iload 4 /* isTlsRsaPremasterSecret */
            ifeq 13
        11: .line 392
            aload 7 /* e */
            astore 5 /* failover */
        12: .line 393
            goto 16
        13: .line 394
      StackMap locals: javax.crypto.BadPaddingException
      StackMap stack:
            new java.security.InvalidKeyException
            dup
            ldc "Unwrapping failed"
            aload 7 /* e */
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 7 // javax.crypto.BadPaddingException e
        14: .line 396
      StackMap locals: sun.security.mscapi.CRSACipher byte[] java.lang.String int int java.lang.Exception byte[]
      StackMap stack: javax.crypto.IllegalBlockSizeException
            astore 7 /* e */
        start local 7 // javax.crypto.IllegalBlockSizeException e
        15: .line 398
            new java.security.InvalidKeyException
            dup
            ldc "Unwrapping failed"
            aload 7 /* e */
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 7 // javax.crypto.IllegalBlockSizeException e
        16: .line 401
      StackMap locals:
      StackMap stack:
            iload 4 /* isTlsRsaPremasterSecret */
            ifeq 26
        17: .line 402
            aload 0 /* this */
            getfield sun.security.mscapi.CRSACipher.spec:Ljava/security/spec/AlgorithmParameterSpec;
            instanceof sun.security.internal.spec.TlsRsaPremasterSecretParameterSpec
            ifne 21
        18: .line 403
            new java.lang.IllegalStateException
            dup
        19: .line 404
            ldc "No TlsRsaPremasterSecretParameterSpec specified"
        20: .line 403
            invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
            athrow
        21: .line 409
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.mscapi.CRSACipher.spec:Ljava/security/spec/AlgorithmParameterSpec;
            checkcast sun.security.internal.spec.TlsRsaPremasterSecretParameterSpec
            invokevirtual sun.security.internal.spec.TlsRsaPremasterSecretParameterSpec.getClientVersion:()I
        22: .line 410
            aload 0 /* this */
            getfield sun.security.mscapi.CRSACipher.spec:Ljava/security/spec/AlgorithmParameterSpec;
            checkcast sun.security.internal.spec.TlsRsaPremasterSecretParameterSpec
            invokevirtual sun.security.internal.spec.TlsRsaPremasterSecretParameterSpec.getServerVersion:()I
        23: .line 411
            aload 0 /* this */
            getfield sun.security.mscapi.CRSACipher.random:Ljava/security/SecureRandom;
            aload 6 /* encoded */
            aload 5 /* failover */
            ifnull 24
            iconst_1
            goto 25
      StackMap locals: sun.security.mscapi.CRSACipher byte[] java.lang.String int int java.lang.Exception byte[]
      StackMap stack: int int java.security.SecureRandom byte[]
        24: iconst_0
        25: .line 408
      StackMap locals: sun.security.mscapi.CRSACipher byte[] java.lang.String int int java.lang.Exception byte[]
      StackMap stack: int int java.security.SecureRandom byte[] int
            invokestatic sun.security.util.KeyUtil.checkTlsPreMasterSecretKey:(IILjava/security/SecureRandom;[BZ)[B
            astore 6 /* encoded */
        26: .line 414
      StackMap locals:
      StackMap stack:
            aload 6 /* encoded */
            aload 2 /* algorithm */
            iload 3 /* type */
            invokestatic sun.security.mscapi.CRSACipher.constructKey:([BLjava/lang/String;I)Ljava/security/Key;
            areturn
        end local 6 // byte[] encoded
        end local 5 // java.lang.Exception failover
        end local 4 // boolean isTlsRsaPremasterSecret
        end local 3 // int type
        end local 2 // java.lang.String algorithm
        end local 1 // byte[] wrappedKey
        end local 0 // sun.security.mscapi.CRSACipher this
      LocalVariableTable:
        Start  End  Slot                     Name  Signature
            0   27     0                     this  Lsun/security/mscapi/CRSACipher;
            0   27     1               wrappedKey  [B
            0   27     2                algorithm  Ljava/lang/String;
            0   27     3                     type  I
            4   27     4  isTlsRsaPremasterSecret  Z
            5   27     5                 failover  Ljava/lang/Exception;
            6   27     6                  encoded  [B
           10   14     7                        e  Ljavax/crypto/BadPaddingException;
           15   16     7                        e  Ljavax/crypto/IllegalBlockSizeException;
      Exception table:
        from    to  target  type
           7     8       9  Class javax.crypto.BadPaddingException
           7     8      14  Class javax.crypto.IllegalBlockSizeException
    Exceptions:
      throws java.security.InvalidKeyException, java.security.NoSuchAlgorithmException
    MethodParameters:
            Name  Flags
      wrappedKey  
      algorithm   
      type        

  protected int engineGetKeySize(java.security.Key);
    descriptor: (Ljava/security/Key;)I
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=5, locals=2, args_size=2
        start local 0 // sun.security.mscapi.CRSACipher this
        start local 1 // java.security.Key key
         0: .line 420
            aload 1 /* key */
            instanceof sun.security.mscapi.CKey
            ifeq 2
         1: .line 421
            aload 1 /* key */
            checkcast sun.security.mscapi.CKey
            invokevirtual sun.security.mscapi.CKey.length:()I
            ireturn
         2: .line 423
      StackMap locals:
      StackMap stack:
            aload 1 /* key */
            instanceof java.security.interfaces.RSAKey
            ifeq 4
         3: .line 424
            aload 1 /* key */
            checkcast java.security.interfaces.RSAKey
            invokeinterface java.security.interfaces.RSAKey.getModulus:()Ljava/math/BigInteger;
            invokevirtual java.math.BigInteger.bitLength:()I
            ireturn
         4: .line 427
      StackMap locals:
      StackMap stack:
            new java.security.InvalidKeyException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Unsupported key type: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* key */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;)V
            athrow
        end local 1 // java.security.Key key
        end local 0 // sun.security.mscapi.CRSACipher this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lsun/security/mscapi/CRSACipher;
            0    5     1   key  Ljava/security/Key;
    Exceptions:
      throws java.security.InvalidKeyException
    MethodParameters:
      Name  Flags
      key   

  private static java.security.PublicKey constructPublicKey(byte[], java.lang.String);
    descriptor: ([BLjava/lang/String;)Ljava/security/PublicKey;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=5, locals=4, args_size=2
        start local 0 // byte[] encodedKey
        start local 1 // java.lang.String encodedKeyAlgorithm
         0: .line 437
            aload 1 /* encodedKeyAlgorithm */
            invokestatic java.security.KeyFactory.getInstance:(Ljava/lang/String;)Ljava/security/KeyFactory;
            astore 2 /* keyFactory */
        start local 2 // java.security.KeyFactory keyFactory
         1: .line 438
            new java.security.spec.X509EncodedKeySpec
            dup
            aload 0 /* encodedKey */
            invokespecial java.security.spec.X509EncodedKeySpec.<init>:([B)V
            astore 3 /* keySpec */
        start local 3 // java.security.spec.X509EncodedKeySpec keySpec
         2: .line 440
            aload 2 /* keyFactory */
            aload 3 /* keySpec */
            invokevirtual java.security.KeyFactory.generatePublic:(Ljava/security/spec/KeySpec;)Ljava/security/PublicKey;
         3: areturn
        end local 3 // java.security.spec.X509EncodedKeySpec keySpec
        end local 2 // java.security.KeyFactory keyFactory
         4: .line 442
      StackMap locals:
      StackMap stack: java.security.NoSuchAlgorithmException
            astore 2 /* nsae */
        start local 2 // java.security.NoSuchAlgorithmException nsae
         5: .line 443
            new java.security.NoSuchAlgorithmException
            dup
            new java.lang.StringBuilder
            dup
            ldc "No installed provider supports the "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         6: .line 444
            aload 1 /* encodedKeyAlgorithm */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc " algorithm"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            aload 2 /* nsae */
         7: .line 443
            invokespecial java.security.NoSuchAlgorithmException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 2 // java.security.NoSuchAlgorithmException nsae
         8: .line 446
      StackMap locals:
      StackMap stack: java.security.spec.InvalidKeySpecException
            astore 2 /* ike */
        start local 2 // java.security.spec.InvalidKeySpecException ike
         9: .line 447
            new java.security.InvalidKeyException
            dup
            ldc "Cannot construct public key"
            aload 2 /* ike */
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 2 // java.security.spec.InvalidKeySpecException ike
        end local 1 // java.lang.String encodedKeyAlgorithm
        end local 0 // byte[] encodedKey
      LocalVariableTable:
        Start  End  Slot                 Name  Signature
            0   10     0           encodedKey  [B
            0   10     1  encodedKeyAlgorithm  Ljava/lang/String;
            1    4     2           keyFactory  Ljava/security/KeyFactory;
            2    4     3              keySpec  Ljava/security/spec/X509EncodedKeySpec;
            5    8     2                 nsae  Ljava/security/NoSuchAlgorithmException;
            9   10     2                  ike  Ljava/security/spec/InvalidKeySpecException;
      Exception table:
        from    to  target  type
           0     3       4  Class java.security.NoSuchAlgorithmException
           0     3       8  Class java.security.spec.InvalidKeySpecException
    Exceptions:
      throws java.security.InvalidKeyException, java.security.NoSuchAlgorithmException
    MethodParameters:
                     Name  Flags
      encodedKey           
      encodedKeyAlgorithm  

  private static java.security.PrivateKey constructPrivateKey(byte[], java.lang.String);
    descriptor: ([BLjava/lang/String;)Ljava/security/PrivateKey;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=5, locals=4, args_size=2
        start local 0 // byte[] encodedKey
        start local 1 // java.lang.String encodedKeyAlgorithm
         0: .line 457
            aload 1 /* encodedKeyAlgorithm */
            invokestatic java.security.KeyFactory.getInstance:(Ljava/lang/String;)Ljava/security/KeyFactory;
            astore 2 /* keyFactory */
        start local 2 // java.security.KeyFactory keyFactory
         1: .line 458
            new java.security.spec.PKCS8EncodedKeySpec
            dup
            aload 0 /* encodedKey */
            invokespecial java.security.spec.PKCS8EncodedKeySpec.<init>:([B)V
            astore 3 /* keySpec */
        start local 3 // java.security.spec.PKCS8EncodedKeySpec keySpec
         2: .line 460
            aload 2 /* keyFactory */
            aload 3 /* keySpec */
            invokevirtual java.security.KeyFactory.generatePrivate:(Ljava/security/spec/KeySpec;)Ljava/security/PrivateKey;
         3: areturn
        end local 3 // java.security.spec.PKCS8EncodedKeySpec keySpec
        end local 2 // java.security.KeyFactory keyFactory
         4: .line 462
      StackMap locals:
      StackMap stack: java.security.NoSuchAlgorithmException
            astore 2 /* nsae */
        start local 2 // java.security.NoSuchAlgorithmException nsae
         5: .line 463
            new java.security.NoSuchAlgorithmException
            dup
            new java.lang.StringBuilder
            dup
            ldc "No installed provider supports the "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         6: .line 464
            aload 1 /* encodedKeyAlgorithm */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc " algorithm"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            aload 2 /* nsae */
         7: .line 463
            invokespecial java.security.NoSuchAlgorithmException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 2 // java.security.NoSuchAlgorithmException nsae
         8: .line 466
      StackMap locals:
      StackMap stack: java.security.spec.InvalidKeySpecException
            astore 2 /* ike */
        start local 2 // java.security.spec.InvalidKeySpecException ike
         9: .line 467
            new java.security.InvalidKeyException
            dup
            ldc "Cannot construct private key"
            aload 2 /* ike */
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 2 // java.security.spec.InvalidKeySpecException ike
        end local 1 // java.lang.String encodedKeyAlgorithm
        end local 0 // byte[] encodedKey
      LocalVariableTable:
        Start  End  Slot                 Name  Signature
            0   10     0           encodedKey  [B
            0   10     1  encodedKeyAlgorithm  Ljava/lang/String;
            1    4     2           keyFactory  Ljava/security/KeyFactory;
            2    4     3              keySpec  Ljava/security/spec/PKCS8EncodedKeySpec;
            5    8     2                 nsae  Ljava/security/NoSuchAlgorithmException;
            9   10     2                  ike  Ljava/security/spec/InvalidKeySpecException;
      Exception table:
        from    to  target  type
           0     3       4  Class java.security.NoSuchAlgorithmException
           0     3       8  Class java.security.spec.InvalidKeySpecException
    Exceptions:
      throws java.security.InvalidKeyException, java.security.NoSuchAlgorithmException
    MethodParameters:
                     Name  Flags
      encodedKey           
      encodedKeyAlgorithm  

  private static javax.crypto.SecretKey constructSecretKey(byte[], java.lang.String);
    descriptor: ([BLjava/lang/String;)Ljavax/crypto/SecretKey;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // byte[] encodedKey
        start local 1 // java.lang.String encodedKeyAlgorithm
         0: .line 475
            new javax.crypto.spec.SecretKeySpec
            dup
            aload 0 /* encodedKey */
            aload 1 /* encodedKeyAlgorithm */
            invokespecial javax.crypto.spec.SecretKeySpec.<init>:([BLjava/lang/String;)V
            areturn
        end local 1 // java.lang.String encodedKeyAlgorithm
        end local 0 // byte[] encodedKey
      LocalVariableTable:
        Start  End  Slot                 Name  Signature
            0    1     0           encodedKey  [B
            0    1     1  encodedKeyAlgorithm  Ljava/lang/String;
    MethodParameters:
                     Name  Flags
      encodedKey           
      encodedKeyAlgorithm  

  private static java.security.Key constructKey(byte[], java.lang.String, int);
    descriptor: ([BLjava/lang/String;I)Ljava/security/Key;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=5, locals=3, args_size=3
        start local 0 // byte[] encodedKey
        start local 1 // java.lang.String encodedKeyAlgorithm
        start local 2 // int keyType
         0: .line 482
            iload 2 /* keyType */
            tableswitch { // 1 - 3
                    1: 1
                    2: 2
                    3: 3
              default: 4
          }
         1: .line 484
      StackMap locals:
      StackMap stack:
            aload 0 /* encodedKey */
            aload 1 /* encodedKeyAlgorithm */
            invokestatic sun.security.mscapi.CRSACipher.constructPublicKey:([BLjava/lang/String;)Ljava/security/PublicKey;
            areturn
         2: .line 486
      StackMap locals:
      StackMap stack:
            aload 0 /* encodedKey */
            aload 1 /* encodedKeyAlgorithm */
            invokestatic sun.security.mscapi.CRSACipher.constructPrivateKey:([BLjava/lang/String;)Ljava/security/PrivateKey;
            areturn
         3: .line 488
      StackMap locals:
      StackMap stack:
            aload 0 /* encodedKey */
            aload 1 /* encodedKeyAlgorithm */
            invokestatic sun.security.mscapi.CRSACipher.constructSecretKey:([BLjava/lang/String;)Ljavax/crypto/SecretKey;
            areturn
         4: .line 490
      StackMap locals:
      StackMap stack:
            new java.security.InvalidKeyException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Unknown key type "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            iload 2 /* keyType */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;)V
            athrow
        end local 2 // int keyType
        end local 1 // java.lang.String encodedKeyAlgorithm
        end local 0 // byte[] encodedKey
      LocalVariableTable:
        Start  End  Slot                 Name  Signature
            0    5     0           encodedKey  [B
            0    5     1  encodedKeyAlgorithm  Ljava/lang/String;
            0    5     2              keyType  I
    Exceptions:
      throws java.security.InvalidKeyException, java.security.NoSuchAlgorithmException
    MethodParameters:
                     Name  Flags
      encodedKey           
      encodedKeyAlgorithm  
      keyType              

  private static native byte[] encryptDecrypt(byte[], int, long, boolean);
    descriptor: ([BIJZ)[B
    flags: (0x010a) ACC_PRIVATE, ACC_STATIC, ACC_NATIVE
    Exceptions:
      throws java.security.KeyException
    MethodParameters:
           Name  Flags
      data       
      dataSize   
      hCryptKey  
      doEncrypt  
}
SourceFile: "CRSACipher.java"
InnerClasses:
  RSA = sun.security.mscapi.CSignature$RSA of sun.security.mscapi.CSignature