public class javax.crypto.EncryptedPrivateKeyInfo
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: javax.crypto.EncryptedPrivateKeyInfo
  super_class: java.lang.Object
{
  private sun.security.x509.AlgorithmId algid;
    descriptor: Lsun/security/x509/AlgorithmId;
    flags: (0x0002) ACC_PRIVATE

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

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

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

  public void <init>(byte[]);
    descriptor: ([B)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=4, args_size=2
        start local 0 // javax.crypto.EncryptedPrivateKeyInfo this
        start local 1 // byte[] encoded
         0: .line 80
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 70
            aload 0 /* this */
            aconst_null
            putfield javax.crypto.EncryptedPrivateKeyInfo.encoded:[B
         2: .line 82
            aload 1 /* encoded */
            ifnonnull 4
         3: .line 83
            new java.lang.NullPointerException
            dup
            ldc "the encoded parameter must be non-null"
            invokespecial java.lang.NullPointerException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 86
      StackMap locals: javax.crypto.EncryptedPrivateKeyInfo byte[]
      StackMap stack:
            aload 0 /* this */
            aload 1 /* encoded */
            invokevirtual byte[].clone:()Ljava/lang/Object;
            checkcast byte[]
            putfield javax.crypto.EncryptedPrivateKeyInfo.encoded:[B
         5: .line 87
            new sun.security.util.DerValue
            dup
            aload 0 /* this */
            getfield javax.crypto.EncryptedPrivateKeyInfo.encoded:[B
            invokespecial sun.security.util.DerValue.<init>:([B)V
            astore 2 /* val */
        start local 2 // sun.security.util.DerValue val
         6: .line 89
            iconst_2
            anewarray sun.security.util.DerValue
            astore 3 /* seq */
        start local 3 // sun.security.util.DerValue[] seq
         7: .line 91
            aload 3 /* seq */
            iconst_0
            aload 2 /* val */
            getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
            invokevirtual sun.security.util.DerInputStream.getDerValue:()Lsun/security/util/DerValue;
            aastore
         8: .line 92
            aload 3 /* seq */
            iconst_1
            aload 2 /* val */
            getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
            invokevirtual sun.security.util.DerInputStream.getDerValue:()Lsun/security/util/DerValue;
            aastore
         9: .line 94
            aload 2 /* val */
            getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
            invokevirtual sun.security.util.DerInputStream.available:()I
            ifeq 11
        10: .line 95
            new java.io.IOException
            dup
            new java.lang.StringBuilder
            dup
            ldc "overrun, bytes = "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 2 /* val */
            getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
            invokevirtual sun.security.util.DerInputStream.available:()I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        11: .line 98
      StackMap locals: sun.security.util.DerValue sun.security.util.DerValue[]
      StackMap stack:
            aload 0 /* this */
            aload 3 /* seq */
            iconst_0
            aaload
            invokestatic sun.security.x509.AlgorithmId.parse:(Lsun/security/util/DerValue;)Lsun/security/x509/AlgorithmId;
            putfield javax.crypto.EncryptedPrivateKeyInfo.algid:Lsun/security/x509/AlgorithmId;
        12: .line 99
            aload 3 /* seq */
            iconst_0
            aaload
            getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
            invokevirtual sun.security.util.DerInputStream.available:()I
            ifeq 14
        13: .line 100
            new java.io.IOException
            dup
            ldc "encryptionAlgorithm field overrun"
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        14: .line 103
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 3 /* seq */
            iconst_1
            aaload
            invokevirtual sun.security.util.DerValue.getOctetString:()[B
            putfield javax.crypto.EncryptedPrivateKeyInfo.encryptedData:[B
        15: .line 104
            aload 3 /* seq */
            iconst_1
            aaload
            getfield sun.security.util.DerValue.data:Lsun/security/util/DerInputStream;
            invokevirtual sun.security.util.DerInputStream.available:()I
            ifeq 17
        16: .line 105
            new java.io.IOException
            dup
            ldc "encryptedData field overrun"
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        17: .line 107
      StackMap locals:
      StackMap stack:
            return
        end local 3 // sun.security.util.DerValue[] seq
        end local 2 // sun.security.util.DerValue val
        end local 1 // byte[] encoded
        end local 0 // javax.crypto.EncryptedPrivateKeyInfo this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0   18     0     this  Ljavax/crypto/EncryptedPrivateKeyInfo;
            0   18     1  encoded  [B
            6   18     2      val  Lsun/security/util/DerValue;
            7   18     3      seq  [Lsun/security/util/DerValue;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
         Name  Flags
      encoded  

  public void <init>(java.lang.String, byte[]);
    descriptor: (Ljava/lang/String;[B)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // javax.crypto.EncryptedPrivateKeyInfo this
        start local 1 // java.lang.String algName
        start local 2 // byte[] encryptedData
         0: .line 133
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 70
            aload 0 /* this */
            aconst_null
            putfield javax.crypto.EncryptedPrivateKeyInfo.encoded:[B
         2: .line 136
            aload 1 /* algName */
            ifnonnull 4
         3: .line 137
            new java.lang.NullPointerException
            dup
            ldc "the algName parameter must be non-null"
            invokespecial java.lang.NullPointerException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 139
      StackMap locals: javax.crypto.EncryptedPrivateKeyInfo java.lang.String byte[]
      StackMap stack:
            aload 0 /* this */
            aload 1 /* algName */
            invokestatic sun.security.x509.AlgorithmId.get:(Ljava/lang/String;)Lsun/security/x509/AlgorithmId;
            putfield javax.crypto.EncryptedPrivateKeyInfo.algid:Lsun/security/x509/AlgorithmId;
         5: .line 141
            aload 2 /* encryptedData */
            ifnonnull 7
         6: .line 142
            new java.lang.NullPointerException
            dup
            ldc "the encryptedData parameter must be non-null"
            invokespecial java.lang.NullPointerException.<init>:(Ljava/lang/String;)V
            athrow
         7: .line 144
      StackMap locals:
      StackMap stack:
            aload 2 /* encryptedData */
            arraylength
            ifne 9
         8: .line 145
            new java.lang.IllegalArgumentException
            dup
            ldc "the encryptedData parameter must not be empty"
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
         9: .line 148
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 2 /* encryptedData */
            invokevirtual byte[].clone:()Ljava/lang/Object;
            checkcast byte[]
            putfield javax.crypto.EncryptedPrivateKeyInfo.encryptedData:[B
        10: .line 152
            aload 0 /* this */
            aconst_null
            putfield javax.crypto.EncryptedPrivateKeyInfo.encoded:[B
        11: .line 153
            return
        end local 2 // byte[] encryptedData
        end local 1 // java.lang.String algName
        end local 0 // javax.crypto.EncryptedPrivateKeyInfo this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   12     0           this  Ljavax/crypto/EncryptedPrivateKeyInfo;
            0   12     1        algName  Ljava/lang/String;
            0   12     2  encryptedData  [B
    Exceptions:
      throws java.security.NoSuchAlgorithmException
    MethodParameters:
               Name  Flags
      algName        
      encryptedData  

  public void <init>(java.security.AlgorithmParameters, byte[]);
    descriptor: (Ljava/security/AlgorithmParameters;[B)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // javax.crypto.EncryptedPrivateKeyInfo this
        start local 1 // java.security.AlgorithmParameters algParams
        start local 2 // byte[] encryptedData
         0: .line 174
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 70
            aload 0 /* this */
            aconst_null
            putfield javax.crypto.EncryptedPrivateKeyInfo.encoded:[B
         2: .line 177
            aload 1 /* algParams */
            ifnonnull 4
         3: .line 178
            new java.lang.NullPointerException
            dup
            ldc "algParams must be non-null"
            invokespecial java.lang.NullPointerException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 180
      StackMap locals: javax.crypto.EncryptedPrivateKeyInfo java.security.AlgorithmParameters byte[]
      StackMap stack:
            aload 0 /* this */
            aload 1 /* algParams */
            invokestatic sun.security.x509.AlgorithmId.get:(Ljava/security/AlgorithmParameters;)Lsun/security/x509/AlgorithmId;
            putfield javax.crypto.EncryptedPrivateKeyInfo.algid:Lsun/security/x509/AlgorithmId;
         5: .line 182
            aload 2 /* encryptedData */
            ifnonnull 7
         6: .line 183
            new java.lang.NullPointerException
            dup
            ldc "encryptedData must be non-null"
            invokespecial java.lang.NullPointerException.<init>:(Ljava/lang/String;)V
            athrow
         7: .line 184
      StackMap locals:
      StackMap stack:
            aload 2 /* encryptedData */
            arraylength
            ifne 9
         8: .line 185
            new java.lang.IllegalArgumentException
            dup
            ldc "the encryptedData parameter must not be empty"
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
         9: .line 188
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 2 /* encryptedData */
            invokevirtual byte[].clone:()Ljava/lang/Object;
            checkcast byte[]
            putfield javax.crypto.EncryptedPrivateKeyInfo.encryptedData:[B
        10: .line 193
            aload 0 /* this */
            aconst_null
            putfield javax.crypto.EncryptedPrivateKeyInfo.encoded:[B
        11: .line 194
            return
        end local 2 // byte[] encryptedData
        end local 1 // java.security.AlgorithmParameters algParams
        end local 0 // javax.crypto.EncryptedPrivateKeyInfo this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   12     0           this  Ljavax/crypto/EncryptedPrivateKeyInfo;
            0   12     1      algParams  Ljava/security/AlgorithmParameters;
            0   12     2  encryptedData  [B
    Exceptions:
      throws java.security.NoSuchAlgorithmException
    MethodParameters:
               Name  Flags
      algParams      
      encryptedData  

  public java.lang.String getAlgName();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // javax.crypto.EncryptedPrivateKeyInfo this
         0: .line 208
            aload 0 /* this */
            getfield javax.crypto.EncryptedPrivateKeyInfo.algid:Lsun/security/x509/AlgorithmId;
            invokevirtual sun.security.x509.AlgorithmId.getName:()Ljava/lang/String;
            areturn
        end local 0 // javax.crypto.EncryptedPrivateKeyInfo this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljavax/crypto/EncryptedPrivateKeyInfo;

  public java.security.AlgorithmParameters getAlgParameters();
    descriptor: ()Ljava/security/AlgorithmParameters;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // javax.crypto.EncryptedPrivateKeyInfo this
         0: .line 216
            aload 0 /* this */
            getfield javax.crypto.EncryptedPrivateKeyInfo.algid:Lsun/security/x509/AlgorithmId;
            invokevirtual sun.security.x509.AlgorithmId.getParameters:()Ljava/security/AlgorithmParameters;
            areturn
        end local 0 // javax.crypto.EncryptedPrivateKeyInfo this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljavax/crypto/EncryptedPrivateKeyInfo;

  public byte[] getEncryptedData();
    descriptor: ()[B
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // javax.crypto.EncryptedPrivateKeyInfo this
         0: .line 225
            aload 0 /* this */
            getfield javax.crypto.EncryptedPrivateKeyInfo.encryptedData:[B
            invokevirtual byte[].clone:()Ljava/lang/Object;
            checkcast byte[]
            areturn
        end local 0 // javax.crypto.EncryptedPrivateKeyInfo this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljavax/crypto/EncryptedPrivateKeyInfo;

  public java.security.spec.PKCS8EncodedKeySpec getKeySpec(javax.crypto.Cipher);
    descriptor: (Ljavax/crypto/Cipher;)Ljava/security/spec/PKCS8EncodedKeySpec;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=4, args_size=2
        start local 0 // javax.crypto.EncryptedPrivateKeyInfo this
        start local 1 // javax.crypto.Cipher cipher
         0: .line 248
            aconst_null
            astore 2 /* encoded */
        start local 2 // byte[] encoded
         1: .line 250
            aload 1 /* cipher */
            aload 0 /* this */
            getfield javax.crypto.EncryptedPrivateKeyInfo.encryptedData:[B
            invokevirtual javax.crypto.Cipher.doFinal:([B)[B
            astore 2 /* encoded */
         2: .line 251
            aload 0 /* this */
            aload 2 /* encoded */
            invokevirtual javax.crypto.EncryptedPrivateKeyInfo.checkPKCS8Encoding:([B)V
         3: .line 252
            goto 8
         4: .line 254
      StackMap locals: javax.crypto.EncryptedPrivateKeyInfo javax.crypto.Cipher byte[]
      StackMap stack: java.lang.Exception
            astore 3 /* ex */
        start local 3 // java.lang.Exception ex
         5: .line 255
            new java.security.spec.InvalidKeySpecException
            dup
         6: .line 256
            ldc "Cannot retrieve the PKCS8EncodedKeySpec"
            aload 3 /* ex */
         7: .line 255
            invokespecial java.security.spec.InvalidKeySpecException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 3 // java.lang.Exception ex
         8: .line 258
      StackMap locals:
      StackMap stack:
            new java.security.spec.PKCS8EncodedKeySpec
            dup
            aload 2 /* encoded */
            aload 0 /* this */
            getfield javax.crypto.EncryptedPrivateKeyInfo.keyAlg:Ljava/lang/String;
            invokespecial java.security.spec.PKCS8EncodedKeySpec.<init>:([BLjava/lang/String;)V
            areturn
        end local 2 // byte[] encoded
        end local 1 // javax.crypto.Cipher cipher
        end local 0 // javax.crypto.EncryptedPrivateKeyInfo this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    9     0     this  Ljavax/crypto/EncryptedPrivateKeyInfo;
            0    9     1   cipher  Ljavax/crypto/Cipher;
            1    9     2  encoded  [B
            5    8     3       ex  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           1     3       4  Class java.security.GeneralSecurityException
           1     3       4  Class java.io.IOException
           1     3       4  Class java.lang.IllegalStateException
    Exceptions:
      throws java.security.spec.InvalidKeySpecException
    MethodParameters:
        Name  Flags
      cipher  

  private java.security.spec.PKCS8EncodedKeySpec getKeySpecImpl(java.security.Key, java.security.Provider);
    descriptor: (Ljava/security/Key;Ljava/security/Provider;)Ljava/security/spec/PKCS8EncodedKeySpec;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=6, args_size=3
        start local 0 // javax.crypto.EncryptedPrivateKeyInfo this
        start local 1 // java.security.Key decryptKey
        start local 2 // java.security.Provider provider
         0: .line 264
            aconst_null
            astore 3 /* encoded */
        start local 3 // byte[] encoded
         1: .line 267
            aload 2 /* provider */
            ifnonnull 4
         2: .line 269
            aload 0 /* this */
            getfield javax.crypto.EncryptedPrivateKeyInfo.algid:Lsun/security/x509/AlgorithmId;
            invokevirtual sun.security.x509.AlgorithmId.getName:()Ljava/lang/String;
            invokestatic javax.crypto.Cipher.getInstance:(Ljava/lang/String;)Ljavax/crypto/Cipher;
            astore 4 /* c */
        start local 4 // javax.crypto.Cipher c
         3: .line 270
            goto 5
        end local 4 // javax.crypto.Cipher c
         4: .line 271
      StackMap locals: byte[]
      StackMap stack:
            aload 0 /* this */
            getfield javax.crypto.EncryptedPrivateKeyInfo.algid:Lsun/security/x509/AlgorithmId;
            invokevirtual sun.security.x509.AlgorithmId.getName:()Ljava/lang/String;
            aload 2 /* provider */
            invokestatic javax.crypto.Cipher.getInstance:(Ljava/lang/String;Ljava/security/Provider;)Ljavax/crypto/Cipher;
            astore 4 /* c */
        start local 4 // javax.crypto.Cipher c
         5: .line 273
      StackMap locals: javax.crypto.Cipher
      StackMap stack:
            aload 4 /* c */
            iconst_2
            aload 1 /* decryptKey */
            aload 0 /* this */
            getfield javax.crypto.EncryptedPrivateKeyInfo.algid:Lsun/security/x509/AlgorithmId;
            invokevirtual sun.security.x509.AlgorithmId.getParameters:()Ljava/security/AlgorithmParameters;
            invokevirtual javax.crypto.Cipher.init:(ILjava/security/Key;Ljava/security/AlgorithmParameters;)V
         6: .line 274
            aload 4 /* c */
            aload 0 /* this */
            getfield javax.crypto.EncryptedPrivateKeyInfo.encryptedData:[B
            invokevirtual javax.crypto.Cipher.doFinal:([B)[B
            astore 3 /* encoded */
         7: .line 275
            aload 0 /* this */
            aload 3 /* encoded */
            invokevirtual javax.crypto.EncryptedPrivateKeyInfo.checkPKCS8Encoding:([B)V
         8: .line 276
            goto 15
        end local 4 // javax.crypto.Cipher c
      StackMap locals: javax.crypto.EncryptedPrivateKeyInfo java.security.Key java.security.Provider byte[]
      StackMap stack: java.security.NoSuchAlgorithmException
         9: astore 5 /* nsae */
        start local 5 // java.security.NoSuchAlgorithmException nsae
        10: .line 278
            aload 5 /* nsae */
            athrow
        end local 5 // java.security.NoSuchAlgorithmException nsae
        11: .line 279
      StackMap locals:
      StackMap stack: java.lang.Exception
            astore 5 /* ex */
        start local 5 // java.lang.Exception ex
        12: .line 280
            new java.security.InvalidKeyException
            dup
        13: .line 281
            ldc "Cannot retrieve the PKCS8EncodedKeySpec"
            aload 5 /* ex */
        14: .line 280
            invokespecial java.security.InvalidKeyException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 5 // java.lang.Exception ex
        start local 4 // javax.crypto.Cipher c
        15: .line 283
      StackMap locals: javax.crypto.Cipher
      StackMap stack:
            new java.security.spec.PKCS8EncodedKeySpec
            dup
            aload 3 /* encoded */
            aload 0 /* this */
            getfield javax.crypto.EncryptedPrivateKeyInfo.keyAlg:Ljava/lang/String;
            invokespecial java.security.spec.PKCS8EncodedKeySpec.<init>:([BLjava/lang/String;)V
            areturn
        end local 4 // javax.crypto.Cipher c
        end local 3 // byte[] encoded
        end local 2 // java.security.Provider provider
        end local 1 // java.security.Key decryptKey
        end local 0 // javax.crypto.EncryptedPrivateKeyInfo this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   16     0        this  Ljavax/crypto/EncryptedPrivateKeyInfo;
            0   16     1  decryptKey  Ljava/security/Key;
            0   16     2    provider  Ljava/security/Provider;
            1   16     3     encoded  [B
            3    4     4           c  Ljavax/crypto/Cipher;
            5    9     4           c  Ljavax/crypto/Cipher;
           15   16     4           c  Ljavax/crypto/Cipher;
           10   11     5        nsae  Ljava/security/NoSuchAlgorithmException;
           12   15     5          ex  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           1     8       9  Class java.security.NoSuchAlgorithmException
           1     8      11  Class java.security.GeneralSecurityException
           1     8      11  Class java.io.IOException
    Exceptions:
      throws java.security.NoSuchAlgorithmException, java.security.InvalidKeyException
    MethodParameters:
            Name  Flags
      decryptKey  
      provider    

  public java.security.spec.PKCS8EncodedKeySpec getKeySpec(java.security.Key);
    descriptor: (Ljava/security/Key;)Ljava/security/spec/PKCS8EncodedKeySpec;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // javax.crypto.EncryptedPrivateKeyInfo this
        start local 1 // java.security.Key decryptKey
         0: .line 303
            aload 1 /* decryptKey */
            ifnonnull 2
         1: .line 304
            new java.lang.NullPointerException
            dup
            ldc "decryptKey is null"
            invokespecial java.lang.NullPointerException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 306
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* decryptKey */
            aconst_null
            invokevirtual javax.crypto.EncryptedPrivateKeyInfo.getKeySpecImpl:(Ljava/security/Key;Ljava/security/Provider;)Ljava/security/spec/PKCS8EncodedKeySpec;
            areturn
        end local 1 // java.security.Key decryptKey
        end local 0 // javax.crypto.EncryptedPrivateKeyInfo this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    3     0        this  Ljavax/crypto/EncryptedPrivateKeyInfo;
            0    3     1  decryptKey  Ljava/security/Key;
    Exceptions:
      throws java.security.NoSuchAlgorithmException, java.security.InvalidKeyException
    MethodParameters:
            Name  Flags
      decryptKey  

  public java.security.spec.PKCS8EncodedKeySpec getKeySpec(java.security.Key, java.lang.String);
    descriptor: (Ljava/security/Key;Ljava/lang/String;)Ljava/security/spec/PKCS8EncodedKeySpec;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=4, args_size=3
        start local 0 // javax.crypto.EncryptedPrivateKeyInfo this
        start local 1 // java.security.Key decryptKey
        start local 2 // java.lang.String providerName
         0: .line 331
            aload 1 /* decryptKey */
            ifnonnull 2
         1: .line 332
            new java.lang.NullPointerException
            dup
            ldc "decryptKey is null"
            invokespecial java.lang.NullPointerException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 334
      StackMap locals:
      StackMap stack:
            aload 2 /* providerName */
            ifnonnull 4
         3: .line 335
            new java.lang.NullPointerException
            dup
            ldc "provider is null"
            invokespecial java.lang.NullPointerException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 337
      StackMap locals:
      StackMap stack:
            aload 2 /* providerName */
            invokestatic java.security.Security.getProvider:(Ljava/lang/String;)Ljava/security/Provider;
            astore 3 /* provider */
        start local 3 // java.security.Provider provider
         5: .line 338
            aload 3 /* provider */
            ifnonnull 9
         6: .line 339
            new java.security.NoSuchProviderException
            dup
            new java.lang.StringBuilder
            dup
            ldc "provider "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         7: .line 340
            aload 2 /* providerName */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc " not found"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         8: .line 339
            invokespecial java.security.NoSuchProviderException.<init>:(Ljava/lang/String;)V
            athrow
         9: .line 342
      StackMap locals: java.security.Provider
      StackMap stack:
            aload 0 /* this */
            aload 1 /* decryptKey */
            aload 3 /* provider */
            invokevirtual javax.crypto.EncryptedPrivateKeyInfo.getKeySpecImpl:(Ljava/security/Key;Ljava/security/Provider;)Ljava/security/spec/PKCS8EncodedKeySpec;
            areturn
        end local 3 // java.security.Provider provider
        end local 2 // java.lang.String providerName
        end local 1 // java.security.Key decryptKey
        end local 0 // javax.crypto.EncryptedPrivateKeyInfo this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   10     0          this  Ljavax/crypto/EncryptedPrivateKeyInfo;
            0   10     1    decryptKey  Ljava/security/Key;
            0   10     2  providerName  Ljava/lang/String;
            5   10     3      provider  Ljava/security/Provider;
    Exceptions:
      throws java.security.NoSuchProviderException, java.security.NoSuchAlgorithmException, java.security.InvalidKeyException
    MethodParameters:
              Name  Flags
      decryptKey    
      providerName  

  public java.security.spec.PKCS8EncodedKeySpec getKeySpec(java.security.Key, java.security.Provider);
    descriptor: (Ljava/security/Key;Ljava/security/Provider;)Ljava/security/spec/PKCS8EncodedKeySpec;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // javax.crypto.EncryptedPrivateKeyInfo this
        start local 1 // java.security.Key decryptKey
        start local 2 // java.security.Provider provider
         0: .line 365
            aload 1 /* decryptKey */
            ifnonnull 2
         1: .line 366
            new java.lang.NullPointerException
            dup
            ldc "decryptKey is null"
            invokespecial java.lang.NullPointerException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 368
      StackMap locals:
      StackMap stack:
            aload 2 /* provider */
            ifnonnull 4
         3: .line 369
            new java.lang.NullPointerException
            dup
            ldc "provider is null"
            invokespecial java.lang.NullPointerException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 371
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* decryptKey */
            aload 2 /* provider */
            invokevirtual javax.crypto.EncryptedPrivateKeyInfo.getKeySpecImpl:(Ljava/security/Key;Ljava/security/Provider;)Ljava/security/spec/PKCS8EncodedKeySpec;
            areturn
        end local 2 // java.security.Provider provider
        end local 1 // java.security.Key decryptKey
        end local 0 // javax.crypto.EncryptedPrivateKeyInfo this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    5     0        this  Ljavax/crypto/EncryptedPrivateKeyInfo;
            0    5     1  decryptKey  Ljava/security/Key;
            0    5     2    provider  Ljava/security/Provider;
    Exceptions:
      throws java.security.NoSuchAlgorithmException, java.security.InvalidKeyException
    MethodParameters:
            Name  Flags
      decryptKey  
      provider    

  public byte[] getEncoded();
    descriptor: ()[B
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=1
        start local 0 // javax.crypto.EncryptedPrivateKeyInfo this
         0: .line 382
            aload 0 /* this */
            getfield javax.crypto.EncryptedPrivateKeyInfo.encoded:[B
            ifnonnull 7
         1: .line 383
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 1 /* out */
        start local 1 // sun.security.util.DerOutputStream out
         2: .line 384
            new sun.security.util.DerOutputStream
            dup
            invokespecial sun.security.util.DerOutputStream.<init>:()V
            astore 2 /* tmp */
        start local 2 // sun.security.util.DerOutputStream tmp
         3: .line 387
            aload 0 /* this */
            getfield javax.crypto.EncryptedPrivateKeyInfo.algid:Lsun/security/x509/AlgorithmId;
            aload 2 /* tmp */
            invokevirtual sun.security.x509.AlgorithmId.encode:(Lsun/security/util/DerOutputStream;)V
         4: .line 390
            aload 2 /* tmp */
            aload 0 /* this */
            getfield javax.crypto.EncryptedPrivateKeyInfo.encryptedData:[B
            invokevirtual sun.security.util.DerOutputStream.putOctetString:([B)V
         5: .line 393
            aload 1 /* out */
            bipush 48
            aload 2 /* tmp */
            invokevirtual sun.security.util.DerOutputStream.write:(BLsun/security/util/DerOutputStream;)V
         6: .line 394
            aload 0 /* this */
            aload 1 /* out */
            invokevirtual sun.security.util.DerOutputStream.toByteArray:()[B
            putfield javax.crypto.EncryptedPrivateKeyInfo.encoded:[B
        end local 2 // sun.security.util.DerOutputStream tmp
        end local 1 // sun.security.util.DerOutputStream out
         7: .line 396
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield javax.crypto.EncryptedPrivateKeyInfo.encoded:[B
            invokevirtual byte[].clone:()Ljava/lang/Object;
            checkcast byte[]
            areturn
        end local 0 // javax.crypto.EncryptedPrivateKeyInfo this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    8     0  this  Ljavax/crypto/EncryptedPrivateKeyInfo;
            2    7     1   out  Lsun/security/util/DerOutputStream;
            3    7     2   tmp  Lsun/security/util/DerOutputStream;
    Exceptions:
      throws java.io.IOException

  private static void checkTag(sun.security.util.DerValue, byte, java.lang.String);
    descriptor: (Lsun/security/util/DerValue;BLjava/lang/String;)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=5, locals=3, args_size=3
        start local 0 // sun.security.util.DerValue val
        start local 1 // byte tag
        start local 2 // java.lang.String valName
         0: .line 401
            aload 0 /* val */
            invokevirtual sun.security.util.DerValue.getTag:()B
            iload 1 /* tag */
            if_icmpeq 4
         1: .line 402
            new java.io.IOException
            dup
            new java.lang.StringBuilder
            dup
            ldc "invalid key encoding - wrong tag for "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         2: .line 403
            aload 2 /* valName */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         3: .line 402
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 405
      StackMap locals:
      StackMap stack:
            return
        end local 2 // java.lang.String valName
        end local 1 // byte tag
        end local 0 // sun.security.util.DerValue val
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    5     0      val  Lsun/security/util/DerValue;
            0    5     1      tag  B
            0    5     2  valName  Ljava/lang/String;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
         Name  Flags
      val      
      tag      
      valName  

  private void checkPKCS8Encoding(byte[]);
    descriptor: ([B)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=4, args_size=2
        start local 0 // javax.crypto.EncryptedPrivateKeyInfo this
        start local 1 // byte[] encodedKey
         0: .line 410
            new sun.security.util.DerInputStream
            dup
            aload 1 /* encodedKey */
            invokespecial sun.security.util.DerInputStream.<init>:([B)V
            astore 2 /* in */
        start local 2 // sun.security.util.DerInputStream in
         1: .line 411
            aload 2 /* in */
            iconst_3
            invokevirtual sun.security.util.DerInputStream.getSequence:(I)[Lsun/security/util/DerValue;
            astore 3 /* values */
        start local 3 // sun.security.util.DerValue[] values
         2: .line 413
            aload 3 /* values */
            arraylength
            tableswitch { // 3 - 4
                    3: 4
                    4: 3
              default: 8
          }
         3: .line 415
      StackMap locals: sun.security.util.DerInputStream sun.security.util.DerValue[]
      StackMap stack:
            aload 3 /* values */
            iconst_3
            aaload
            bipush -128
            ldc "attributes"
            invokestatic javax.crypto.EncryptedPrivateKeyInfo.checkTag:(Lsun/security/util/DerValue;BLjava/lang/String;)V
         4: .line 418
      StackMap locals:
      StackMap stack:
            aload 3 /* values */
            iconst_0
            aaload
            iconst_2
            ldc "version"
            invokestatic javax.crypto.EncryptedPrivateKeyInfo.checkTag:(Lsun/security/util/DerValue;BLjava/lang/String;)V
         5: .line 419
            aload 0 /* this */
            aload 3 /* values */
            iconst_1
            aaload
            invokestatic sun.security.x509.AlgorithmId.parse:(Lsun/security/util/DerValue;)Lsun/security/x509/AlgorithmId;
            invokevirtual sun.security.x509.AlgorithmId.getName:()Ljava/lang/String;
            putfield javax.crypto.EncryptedPrivateKeyInfo.keyAlg:Ljava/lang/String;
         6: .line 420
            aload 3 /* values */
            iconst_2
            aaload
            iconst_4
            ldc "privateKey"
            invokestatic javax.crypto.EncryptedPrivateKeyInfo.checkTag:(Lsun/security/util/DerValue;BLjava/lang/String;)V
         7: .line 421
            goto 9
         8: .line 423
      StackMap locals:
      StackMap stack:
            new java.io.IOException
            dup
            ldc "invalid key encoding"
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
         9: .line 425
      StackMap locals:
      StackMap stack:
            return
        end local 3 // sun.security.util.DerValue[] values
        end local 2 // sun.security.util.DerInputStream in
        end local 1 // byte[] encodedKey
        end local 0 // javax.crypto.EncryptedPrivateKeyInfo this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   10     0        this  Ljavax/crypto/EncryptedPrivateKeyInfo;
            0   10     1  encodedKey  [B
            1   10     2          in  Lsun/security/util/DerInputStream;
            2   10     3      values  [Lsun/security/util/DerValue;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
            Name  Flags
      encodedKey  
}
SourceFile: "EncryptedPrivateKeyInfo.java"