public abstract class java.security.cert.Certificate implements java.io.Serializable
  minor version: 0
  major version: 59
  flags: flags: (0x0421) ACC_PUBLIC, ACC_SUPER, ACC_ABSTRACT
  this_class: java.security.cert.Certificate
  super_class: java.lang.Object
{
  private static final long serialVersionUID;
    descriptor: J
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: -3585440601605666277

  private final java.lang.String type;
    descriptor: Ljava/lang/String;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

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

  protected void <init>(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // java.security.cert.Certificate this
        start local 1 // java.lang.String type
         0: .line 82
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 71
            aload 0 /* this */
            iconst_m1
            putfield java.security.cert.Certificate.hash:I
         2: .line 83
            aload 0 /* this */
            aload 1 /* type */
            putfield java.security.cert.Certificate.type:Ljava/lang/String;
         3: .line 84
            return
        end local 1 // java.lang.String type
        end local 0 // java.security.cert.Certificate this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Ljava/security/cert/Certificate;
            0    4     1  type  Ljava/lang/String;
    MethodParameters:
      Name  Flags
      type  

  public final java.lang.String getType();
    descriptor: ()Ljava/lang/String;
    flags: (0x0011) ACC_PUBLIC, ACC_FINAL
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // java.security.cert.Certificate this
         0: .line 92
            aload 0 /* this */
            getfield java.security.cert.Certificate.type:Ljava/lang/String;
            areturn
        end local 0 // java.security.cert.Certificate this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Ljava/security/cert/Certificate;

  public boolean equals(java.lang.Object);
    descriptor: (Ljava/lang/Object;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=4, args_size=2
        start local 0 // java.security.cert.Certificate this
        start local 1 // java.lang.Object other
         0: .line 107
            aload 0 /* this */
            aload 1 /* other */
            if_acmpne 2
         1: .line 108
            iconst_1
            ireturn
         2: .line 110
      StackMap locals:
      StackMap stack:
            aload 1 /* other */
            instanceof java.security.cert.Certificate
            ifne 4
         3: .line 111
            iconst_0
            ireturn
         4: .line 114
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokestatic sun.security.x509.X509CertImpl.getEncodedInternal:(Ljava/security/cert/Certificate;)[B
            astore 2 /* thisCert */
        start local 2 // byte[] thisCert
         5: .line 115
            aload 1 /* other */
            checkcast java.security.cert.Certificate
            invokestatic sun.security.x509.X509CertImpl.getEncodedInternal:(Ljava/security/cert/Certificate;)[B
            astore 3 /* otherCert */
        start local 3 // byte[] otherCert
         6: .line 117
            aload 2 /* thisCert */
            aload 3 /* otherCert */
            invokestatic java.util.Arrays.equals:([B[B)Z
         7: ireturn
        end local 3 // byte[] otherCert
        end local 2 // byte[] thisCert
         8: .line 118
      StackMap locals:
      StackMap stack: java.security.cert.CertificateException
            pop
         9: .line 119
            iconst_0
            ireturn
        end local 1 // java.lang.Object other
        end local 0 // java.security.cert.Certificate this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   10     0       this  Ljava/security/cert/Certificate;
            0   10     1      other  Ljava/lang/Object;
            5    8     2   thisCert  [B
            6    8     3  otherCert  [B
      Exception table:
        from    to  target  type
           4     7       8  Class java.security.cert.CertificateException
    MethodParameters:
       Name  Flags
      other  

  public int hashCode();
    descriptor: ()I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=1
        start local 0 // java.security.cert.Certificate this
         0: .line 130
            aload 0 /* this */
            getfield java.security.cert.Certificate.hash:I
            istore 1 /* h */
        start local 1 // int h
         1: .line 131
            iload 1 /* h */
            iconst_m1
            if_icmpne 7
         2: .line 133
            aload 0 /* this */
            invokestatic sun.security.x509.X509CertImpl.getEncodedInternal:(Ljava/security/cert/Certificate;)[B
            invokestatic java.util.Arrays.hashCode:([B)I
            istore 1 /* h */
         3: .line 134
            goto 6
      StackMap locals: java.security.cert.Certificate int
      StackMap stack: java.security.cert.CertificateException
         4: pop
         5: .line 135
            iconst_0
            istore 1 /* h */
         6: .line 137
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iload 1 /* h */
            putfield java.security.cert.Certificate.hash:I
         7: .line 139
      StackMap locals:
      StackMap stack:
            iload 1 /* h */
            ireturn
        end local 1 // int h
        end local 0 // java.security.cert.Certificate this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    8     0  this  Ljava/security/cert/Certificate;
            1    8     1     h  I
      Exception table:
        from    to  target  type
           2     3       4  Class java.security.cert.CertificateException

  public abstract byte[] getEncoded();
    descriptor: ()[B
    flags: (0x0401) ACC_PUBLIC, ACC_ABSTRACT
    Exceptions:
      throws java.security.cert.CertificateEncodingException

  public abstract void verify(java.security.PublicKey);
    descriptor: (Ljava/security/PublicKey;)V
    flags: (0x0401) ACC_PUBLIC, ACC_ABSTRACT
    Exceptions:
      throws java.security.cert.CertificateException, java.security.NoSuchAlgorithmException, java.security.InvalidKeyException, java.security.NoSuchProviderException, java.security.SignatureException
    MethodParameters:
      Name  Flags
      key   

  public abstract void verify(java.security.PublicKey, java.lang.String);
    descriptor: (Ljava/security/PublicKey;Ljava/lang/String;)V
    flags: (0x0401) ACC_PUBLIC, ACC_ABSTRACT
    Exceptions:
      throws java.security.cert.CertificateException, java.security.NoSuchAlgorithmException, java.security.InvalidKeyException, java.security.NoSuchProviderException, java.security.SignatureException
    MethodParameters:
             Name  Flags
      key          
      sigProvider  

  public void verify(java.security.PublicKey, java.security.Provider);
    descriptor: (Ljava/security/PublicKey;Ljava/security/Provider;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=3
        start local 0 // java.security.cert.Certificate this
        start local 1 // java.security.PublicKey key
        start local 2 // java.security.Provider sigProvider
         0: .line 220
            new java.lang.UnsupportedOperationException
            dup
            invokespecial java.lang.UnsupportedOperationException.<init>:()V
            athrow
        end local 2 // java.security.Provider sigProvider
        end local 1 // java.security.PublicKey key
        end local 0 // java.security.cert.Certificate this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    1     0         this  Ljava/security/cert/Certificate;
            0    1     1          key  Ljava/security/PublicKey;
            0    1     2  sigProvider  Ljava/security/Provider;
    Exceptions:
      throws java.security.cert.CertificateException, java.security.NoSuchAlgorithmException, java.security.InvalidKeyException, java.security.SignatureException
    MethodParameters:
             Name  Flags
      key          
      sigProvider  

  public abstract java.lang.String toString();
    descriptor: ()Ljava/lang/String;
    flags: (0x0401) ACC_PUBLIC, ACC_ABSTRACT

  public abstract java.security.PublicKey getPublicKey();
    descriptor: ()Ljava/security/PublicKey;
    flags: (0x0401) ACC_PUBLIC, ACC_ABSTRACT

  protected java.lang.Object writeReplace();
    descriptor: ()Ljava/lang/Object;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=5, locals=2, args_size=1
        start local 0 // java.security.cert.Certificate this
         0: .line 295
            new java.security.cert.Certificate$CertificateRep
            dup
            aload 0 /* this */
            getfield java.security.cert.Certificate.type:Ljava/lang/String;
            aload 0 /* this */
            invokevirtual java.security.cert.Certificate.getEncoded:()[B
            invokespecial java.security.cert.Certificate$CertificateRep.<init>:(Ljava/lang/String;[B)V
         1: areturn
         2: .line 296
      StackMap locals:
      StackMap stack: java.security.cert.CertificateException
            astore 1 /* e */
        start local 1 // java.security.cert.CertificateException e
         3: .line 297
            new java.io.NotSerializableException
            dup
         4: .line 298
            new java.lang.StringBuilder
            dup
            ldc "java.security.cert.Certificate: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         5: .line 299
            aload 0 /* this */
            getfield java.security.cert.Certificate.type:Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
         6: .line 300
            ldc ": "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
         7: .line 301
            aload 1 /* e */
            invokevirtual java.security.cert.CertificateException.getMessage:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
         8: .line 298
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         9: .line 297
            invokespecial java.io.NotSerializableException.<init>:(Ljava/lang/String;)V
            athrow
        end local 1 // java.security.cert.CertificateException e
        end local 0 // java.security.cert.Certificate this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   10     0  this  Ljava/security/cert/Certificate;
            3   10     1     e  Ljava/security/cert/CertificateException;
      Exception table:
        from    to  target  type
           0     1       2  Class java.security.cert.CertificateException
    Exceptions:
      throws java.io.ObjectStreamException
}
SourceFile: "Certificate.java"
NestMembers:
  java.security.cert.Certificate$CertificateRep
InnerClasses:
  protected CertificateRep = java.security.cert.Certificate$CertificateRep of java.security.cert.Certificate