final class sun.security.ssl.JsseJce
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: sun.security.ssl.JsseJce
  super_class: java.lang.Object
{
  private static final sun.security.jca.ProviderList fipsProviderList;
    descriptor: Lsun/security/jca/ProviderList;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final boolean kerberosAvailable;
    descriptor: Z
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  static final java.lang.String CIPHER_RSA_PKCS1;
    descriptor: Ljava/lang/String;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: "RSA/ECB/PKCS1Padding"

  static final java.lang.String CIPHER_RC4;
    descriptor: Ljava/lang/String;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: "RC4"

  static final java.lang.String CIPHER_DES;
    descriptor: Ljava/lang/String;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: "DES/CBC/NoPadding"

  static final java.lang.String CIPHER_3DES;
    descriptor: Ljava/lang/String;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: "DESede/CBC/NoPadding"

  static final java.lang.String CIPHER_AES;
    descriptor: Ljava/lang/String;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: "AES/CBC/NoPadding"

  static final java.lang.String CIPHER_AES_GCM;
    descriptor: Ljava/lang/String;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: "AES/GCM/NoPadding"

  static final java.lang.String SIGNATURE_DSA;
    descriptor: Ljava/lang/String;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: "DSA"

  static final java.lang.String SIGNATURE_ECDSA;
    descriptor: Ljava/lang/String;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: "SHA1withECDSA"

  static final java.lang.String SIGNATURE_RAWDSA;
    descriptor: Ljava/lang/String;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: "RawDSA"

  static final java.lang.String SIGNATURE_RAWECDSA;
    descriptor: Ljava/lang/String;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: "NONEwithECDSA"

  static final java.lang.String SIGNATURE_RAWRSA;
    descriptor: Ljava/lang/String;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: "NONEwithRSA"

  static final java.lang.String SIGNATURE_SSLRSA;
    descriptor: Ljava/lang/String;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: "MD5andSHA1withRSA"

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=4, locals=2, args_size=0
         0: .line 64
            ldc "KRB5"
            invokestatic sun.security.ssl.ClientKeyExchangeService.find:(Ljava/lang/String;)Lsun/security/ssl/ClientKeyExchangeService;
         1: .line 63
            astore 0 /* p */
        start local 0 // sun.security.ssl.ClientKeyExchangeService p
         2: .line 65
            aload 0 /* p */
            ifnull 3
            iconst_1
            goto 4
      StackMap locals: sun.security.ssl.ClientKeyExchangeService
      StackMap stack:
         3: iconst_0
      StackMap locals:
      StackMap stack: int
         4: putstatic sun.security.ssl.JsseJce.kerberosAvailable:Z
        end local 0 // sun.security.ssl.ClientKeyExchangeService p
         5: .line 73
            invokestatic sun.security.ssl.SunJSSE.isFIPS:()Z
            ifne 8
         6: .line 74
            aconst_null
            putstatic sun.security.ssl.JsseJce.fipsProviderList:Lsun/security/jca/ProviderList;
         7: .line 75
            goto 15
         8: .line 80
      StackMap locals:
      StackMap stack:
            ldc "SUN"
            invokestatic java.security.Security.getProvider:(Ljava/lang/String;)Ljava/security/Provider;
            astore 0 /* sun */
        start local 0 // java.security.Provider sun
         9: .line 81
            aload 0 /* sun */
            ifnonnull 13
        10: .line 82
            new java.lang.RuntimeException
            dup
        11: .line 83
            ldc "FIPS mode: SUN provider must be installed"
        12: .line 82
            invokespecial java.lang.RuntimeException.<init>:(Ljava/lang/String;)V
            athrow
        13: .line 85
      StackMap locals: java.security.Provider
      StackMap stack:
            new sun.security.ssl.JsseJce$SunCertificates
            dup
            aload 0 /* sun */
            invokespecial sun.security.ssl.JsseJce$SunCertificates.<init>:(Ljava/security/Provider;)V
            astore 1 /* sunCerts */
        start local 1 // java.security.Provider sunCerts
        14: .line 86
            iconst_2
            anewarray java.security.Provider
            dup
            iconst_0
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            aastore
            dup
            iconst_1
            aload 1 /* sunCerts */
            aastore
            invokestatic sun.security.jca.ProviderList.newList:([Ljava/security/Provider;)Lsun/security/jca/ProviderList;
            putstatic sun.security.ssl.JsseJce.fipsProviderList:Lsun/security/jca/ProviderList;
        end local 1 // java.security.Provider sunCerts
        end local 0 // java.security.Provider sun
        15: .line 173
      StackMap locals:
      StackMap stack:
            return
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            2    5     0         p  Lsun/security/ssl/ClientKeyExchangeService;
            9   15     0       sun  Ljava/security/Provider;
           14   15     1  sunCerts  Ljava/security/Provider;

  private void <init>();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.ssl.JsseJce this
         0: .line 175
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 177
            return
        end local 0 // sun.security.ssl.JsseJce this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lsun/security/ssl/JsseJce;

  static boolean isEcAvailable();
    descriptor: ()Z
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 180
            getstatic sun.security.ssl.JsseJce$EcAvailability.isAvailable:Z
            ireturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  static boolean isKerberosAvailable();
    descriptor: ()Z
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 184
            getstatic sun.security.ssl.JsseJce.kerberosAvailable:Z
            ireturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  static javax.crypto.Cipher getCipher(java.lang.String);
    descriptor: (Ljava/lang/String;)Ljavax/crypto/Cipher;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=3, locals=2, args_size=1
        start local 0 // java.lang.String transformation
         0: .line 193
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            ifnonnull 3
         1: .line 194
            aload 0 /* transformation */
            invokestatic javax.crypto.Cipher.getInstance:(Ljava/lang/String;)Ljavax/crypto/Cipher;
         2: areturn
         3: .line 196
      StackMap locals:
      StackMap stack:
            aload 0 /* transformation */
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            invokestatic javax.crypto.Cipher.getInstance:(Ljava/lang/String;Ljava/security/Provider;)Ljavax/crypto/Cipher;
         4: areturn
         5: .line 198
      StackMap locals:
      StackMap stack: javax.crypto.NoSuchPaddingException
            astore 1 /* e */
        start local 1 // javax.crypto.NoSuchPaddingException e
         6: .line 199
            new java.security.NoSuchAlgorithmException
            dup
            aload 1 /* e */
            invokespecial java.security.NoSuchAlgorithmException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 1 // javax.crypto.NoSuchPaddingException e
        end local 0 // java.lang.String transformation
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0    7     0  transformation  Ljava/lang/String;
            6    7     1               e  Ljavax/crypto/NoSuchPaddingException;
      Exception table:
        from    to  target  type
           0     2       5  Class javax.crypto.NoSuchPaddingException
           3     4       5  Class javax.crypto.NoSuchPaddingException
    Exceptions:
      throws java.security.NoSuchAlgorithmException
    MethodParameters:
                Name  Flags
      transformation  

  static java.security.Signature getSignature(java.lang.String);
    descriptor: (Ljava/lang/String;)Ljava/security/Signature;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=3, locals=2, args_size=1
        start local 0 // java.lang.String algorithm
         0: .line 210
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            ifnonnull 2
         1: .line 211
            aload 0 /* algorithm */
            invokestatic java.security.Signature.getInstance:(Ljava/lang/String;)Ljava/security/Signature;
            areturn
         2: .line 214
      StackMap locals:
      StackMap stack:
            aload 0 /* algorithm */
            ldc "MD5andSHA1withRSA"
            if_acmpne 8
         3: .line 219
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            ldc "Signature"
            aload 0 /* algorithm */
            invokevirtual java.security.Provider.getService:(Ljava/lang/String;Ljava/lang/String;)Ljava/security/Provider$Service;
            ifnonnull 8
         4: .line 224
            aload 0 /* algorithm */
            ldc "SunJSSE"
            invokestatic java.security.Signature.getInstance:(Ljava/lang/String;Ljava/lang/String;)Ljava/security/Signature;
         5: areturn
         6: .line 225
      StackMap locals:
      StackMap stack: java.security.NoSuchProviderException
            astore 1 /* e */
        start local 1 // java.security.NoSuchProviderException e
         7: .line 226
            new java.security.NoSuchAlgorithmException
            dup
            aload 1 /* e */
            invokespecial java.security.NoSuchAlgorithmException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 1 // java.security.NoSuchProviderException e
         8: .line 230
      StackMap locals:
      StackMap stack:
            aload 0 /* algorithm */
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            invokestatic java.security.Signature.getInstance:(Ljava/lang/String;Ljava/security/Provider;)Ljava/security/Signature;
            areturn
        end local 0 // java.lang.String algorithm
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    9     0  algorithm  Ljava/lang/String;
            7    8     1          e  Ljava/security/NoSuchProviderException;
      Exception table:
        from    to  target  type
           4     5       6  Class java.security.NoSuchProviderException
    Exceptions:
      throws java.security.NoSuchAlgorithmException
    MethodParameters:
           Name  Flags
      algorithm  

  static javax.crypto.KeyGenerator getKeyGenerator(java.lang.String);
    descriptor: (Ljava/lang/String;)Ljavax/crypto/KeyGenerator;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // java.lang.String algorithm
         0: .line 236
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            ifnonnull 2
         1: .line 237
            aload 0 /* algorithm */
            invokestatic javax.crypto.KeyGenerator.getInstance:(Ljava/lang/String;)Ljavax/crypto/KeyGenerator;
            areturn
         2: .line 239
      StackMap locals:
      StackMap stack:
            aload 0 /* algorithm */
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            invokestatic javax.crypto.KeyGenerator.getInstance:(Ljava/lang/String;Ljava/security/Provider;)Ljavax/crypto/KeyGenerator;
            areturn
        end local 0 // java.lang.String algorithm
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    3     0  algorithm  Ljava/lang/String;
    Exceptions:
      throws java.security.NoSuchAlgorithmException
    MethodParameters:
           Name  Flags
      algorithm  

  static java.security.KeyPairGenerator getKeyPairGenerator(java.lang.String);
    descriptor: (Ljava/lang/String;)Ljava/security/KeyPairGenerator;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // java.lang.String algorithm
         0: .line 245
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            ifnonnull 2
         1: .line 246
            aload 0 /* algorithm */
            invokestatic java.security.KeyPairGenerator.getInstance:(Ljava/lang/String;)Ljava/security/KeyPairGenerator;
            areturn
         2: .line 248
      StackMap locals:
      StackMap stack:
            aload 0 /* algorithm */
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            invokestatic java.security.KeyPairGenerator.getInstance:(Ljava/lang/String;Ljava/security/Provider;)Ljava/security/KeyPairGenerator;
            areturn
        end local 0 // java.lang.String algorithm
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    3     0  algorithm  Ljava/lang/String;
    Exceptions:
      throws java.security.NoSuchAlgorithmException
    MethodParameters:
           Name  Flags
      algorithm  

  static javax.crypto.KeyAgreement getKeyAgreement(java.lang.String);
    descriptor: (Ljava/lang/String;)Ljavax/crypto/KeyAgreement;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // java.lang.String algorithm
         0: .line 254
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            ifnonnull 2
         1: .line 255
            aload 0 /* algorithm */
            invokestatic javax.crypto.KeyAgreement.getInstance:(Ljava/lang/String;)Ljavax/crypto/KeyAgreement;
            areturn
         2: .line 257
      StackMap locals:
      StackMap stack:
            aload 0 /* algorithm */
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            invokestatic javax.crypto.KeyAgreement.getInstance:(Ljava/lang/String;Ljava/security/Provider;)Ljavax/crypto/KeyAgreement;
            areturn
        end local 0 // java.lang.String algorithm
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    3     0  algorithm  Ljava/lang/String;
    Exceptions:
      throws java.security.NoSuchAlgorithmException
    MethodParameters:
           Name  Flags
      algorithm  

  static javax.crypto.Mac getMac(java.lang.String);
    descriptor: (Ljava/lang/String;)Ljavax/crypto/Mac;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // java.lang.String algorithm
         0: .line 263
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            ifnonnull 2
         1: .line 264
            aload 0 /* algorithm */
            invokestatic javax.crypto.Mac.getInstance:(Ljava/lang/String;)Ljavax/crypto/Mac;
            areturn
         2: .line 266
      StackMap locals:
      StackMap stack:
            aload 0 /* algorithm */
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            invokestatic javax.crypto.Mac.getInstance:(Ljava/lang/String;Ljava/security/Provider;)Ljavax/crypto/Mac;
            areturn
        end local 0 // java.lang.String algorithm
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    3     0  algorithm  Ljava/lang/String;
    Exceptions:
      throws java.security.NoSuchAlgorithmException
    MethodParameters:
           Name  Flags
      algorithm  

  static java.security.KeyFactory getKeyFactory(java.lang.String);
    descriptor: (Ljava/lang/String;)Ljava/security/KeyFactory;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // java.lang.String algorithm
         0: .line 272
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            ifnonnull 2
         1: .line 273
            aload 0 /* algorithm */
            invokestatic java.security.KeyFactory.getInstance:(Ljava/lang/String;)Ljava/security/KeyFactory;
            areturn
         2: .line 275
      StackMap locals:
      StackMap stack:
            aload 0 /* algorithm */
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            invokestatic java.security.KeyFactory.getInstance:(Ljava/lang/String;Ljava/security/Provider;)Ljava/security/KeyFactory;
            areturn
        end local 0 // java.lang.String algorithm
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    3     0  algorithm  Ljava/lang/String;
    Exceptions:
      throws java.security.NoSuchAlgorithmException
    MethodParameters:
           Name  Flags
      algorithm  

  static java.security.AlgorithmParameters getAlgorithmParameters(java.lang.String);
    descriptor: (Ljava/lang/String;)Ljava/security/AlgorithmParameters;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // java.lang.String algorithm
         0: .line 281
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            ifnonnull 2
         1: .line 282
            aload 0 /* algorithm */
            invokestatic java.security.AlgorithmParameters.getInstance:(Ljava/lang/String;)Ljava/security/AlgorithmParameters;
            areturn
         2: .line 284
      StackMap locals:
      StackMap stack:
            aload 0 /* algorithm */
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            invokestatic java.security.AlgorithmParameters.getInstance:(Ljava/lang/String;Ljava/security/Provider;)Ljava/security/AlgorithmParameters;
            areturn
        end local 0 // java.lang.String algorithm
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    3     0  algorithm  Ljava/lang/String;
    Exceptions:
      throws java.security.NoSuchAlgorithmException
    MethodParameters:
           Name  Flags
      algorithm  

  static java.security.SecureRandom getSecureRandom();
    descriptor: ()Ljava/security/SecureRandom;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=5, locals=2, args_size=0
         0: .line 289
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            ifnonnull 2
         1: .line 290
            new java.security.SecureRandom
            dup
            invokespecial java.security.SecureRandom.<init>:()V
            areturn
         2: .line 295
      StackMap locals:
      StackMap stack:
            ldc "PKCS11"
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            invokestatic java.security.SecureRandom.getInstance:(Ljava/lang/String;Ljava/security/Provider;)Ljava/security/SecureRandom;
         3: areturn
         4: .line 296
      StackMap locals:
      StackMap stack: java.security.NoSuchAlgorithmException
            pop
         5: .line 299
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            invokevirtual java.security.Provider.getServices:()Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 1
            goto 11
      StackMap locals: top java.util.Iterator
      StackMap stack:
         6: aload 1
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.security.Provider$Service
            astore 0 /* s */
        start local 0 // java.security.Provider$Service s
         7: .line 300
            aload 0 /* s */
            invokevirtual java.security.Provider$Service.getType:()Ljava/lang/String;
            ldc "SecureRandom"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 11
         8: .line 302
            aload 0 /* s */
            invokevirtual java.security.Provider$Service.getAlgorithm:()Ljava/lang/String;
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            invokestatic java.security.SecureRandom.getInstance:(Ljava/lang/String;Ljava/security/Provider;)Ljava/security/SecureRandom;
         9: areturn
        10: .line 303
      StackMap locals: java.security.Provider$Service java.util.Iterator
      StackMap stack: java.security.NoSuchAlgorithmException
            pop
        end local 0 // java.security.Provider$Service s
        11: .line 299
      StackMap locals: top java.util.Iterator
      StackMap stack:
            aload 1
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 6
        12: .line 308
            new java.security.KeyManagementException
            dup
            new java.lang.StringBuilder
            dup
            ldc "FIPS mode: no SecureRandom  implementation found in provider "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        13: .line 309
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            invokevirtual java.security.Provider.getName:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        14: .line 308
            invokespecial java.security.KeyManagementException.<init>:(Ljava/lang/String;)V
            athrow
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            7   11     0     s  Ljava/security/Provider$Service;
      Exception table:
        from    to  target  type
           2     3       4  Class java.security.NoSuchAlgorithmException
           8     9      10  Class java.security.NoSuchAlgorithmException
    Exceptions:
      throws java.security.KeyManagementException

  static java.security.MessageDigest getMD5();
    descriptor: ()Ljava/security/MessageDigest;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 313
            ldc "MD5"
            invokestatic sun.security.ssl.JsseJce.getMessageDigest:(Ljava/lang/String;)Ljava/security/MessageDigest;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  static java.security.MessageDigest getSHA();
    descriptor: ()Ljava/security/MessageDigest;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 317
            ldc "SHA"
            invokestatic sun.security.ssl.JsseJce.getMessageDigest:(Ljava/lang/String;)Ljava/security/MessageDigest;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  static java.security.MessageDigest getMessageDigest(java.lang.String);
    descriptor: (Ljava/lang/String;)Ljava/security/MessageDigest;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=5, locals=2, args_size=1
        start local 0 // java.lang.String algorithm
         0: .line 322
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            ifnonnull 3
         1: .line 323
            aload 0 /* algorithm */
            invokestatic java.security.MessageDigest.getInstance:(Ljava/lang/String;)Ljava/security/MessageDigest;
         2: areturn
         3: .line 325
      StackMap locals:
      StackMap stack:
            aload 0 /* algorithm */
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            invokestatic java.security.MessageDigest.getInstance:(Ljava/lang/String;Ljava/security/Provider;)Ljava/security/MessageDigest;
         4: areturn
         5: .line 327
      StackMap locals:
      StackMap stack: java.security.NoSuchAlgorithmException
            astore 1 /* e */
        start local 1 // java.security.NoSuchAlgorithmException e
         6: .line 328
            new java.lang.RuntimeException
            dup
         7: .line 329
            new java.lang.StringBuilder
            dup
            ldc "Algorithm "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* algorithm */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc " not available"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            aload 1 /* e */
         8: .line 328
            invokespecial java.lang.RuntimeException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 1 // java.security.NoSuchAlgorithmException e
        end local 0 // java.lang.String algorithm
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    9     0  algorithm  Ljava/lang/String;
            6    9     1          e  Ljava/security/NoSuchAlgorithmException;
      Exception table:
        from    to  target  type
           0     2       5  Class java.security.NoSuchAlgorithmException
           3     4       5  Class java.security.NoSuchAlgorithmException
    MethodParameters:
           Name  Flags
      algorithm  

  static int getRSAKeyLength(java.security.PublicKey);
    descriptor: (Ljava/security/PublicKey;)I
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=3, args_size=1
        start local 0 // java.security.PublicKey key
         0: .line 335
            aload 0 /* key */
            instanceof java.security.interfaces.RSAPublicKey
            ifeq 3
         1: .line 336
            aload 0 /* key */
            checkcast java.security.interfaces.RSAPublicKey
            invokeinterface java.security.interfaces.RSAPublicKey.getModulus:()Ljava/math/BigInteger;
            astore 1 /* modulus */
        start local 1 // java.math.BigInteger modulus
         2: .line 337
            goto 5
        end local 1 // java.math.BigInteger modulus
         3: .line 338
      StackMap locals:
      StackMap stack:
            aload 0 /* key */
            invokestatic sun.security.ssl.JsseJce.getRSAPublicKeySpec:(Ljava/security/PublicKey;)Ljava/security/spec/RSAPublicKeySpec;
            astore 2 /* spec */
        start local 2 // java.security.spec.RSAPublicKeySpec spec
         4: .line 339
            aload 2 /* spec */
            invokevirtual java.security.spec.RSAPublicKeySpec.getModulus:()Ljava/math/BigInteger;
            astore 1 /* modulus */
        end local 2 // java.security.spec.RSAPublicKeySpec spec
        start local 1 // java.math.BigInteger modulus
         5: .line 341
      StackMap locals: java.math.BigInteger
      StackMap stack:
            aload 1 /* modulus */
            invokevirtual java.math.BigInteger.bitLength:()I
            ireturn
        end local 1 // java.math.BigInteger modulus
        end local 0 // java.security.PublicKey key
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    6     0      key  Ljava/security/PublicKey;
            2    3     1  modulus  Ljava/math/BigInteger;
            5    6     1  modulus  Ljava/math/BigInteger;
            4    5     2     spec  Ljava/security/spec/RSAPublicKeySpec;
    MethodParameters:
      Name  Flags
      key   

  static java.security.spec.RSAPublicKeySpec getRSAPublicKeySpec(java.security.PublicKey);
    descriptor: (Ljava/security/PublicKey;)Ljava/security/spec/RSAPublicKeySpec;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=4, locals=2, args_size=1
        start local 0 // java.security.PublicKey key
         0: .line 345
            aload 0 /* key */
            instanceof java.security.interfaces.RSAPublicKey
            ifeq 5
         1: .line 346
            aload 0 /* key */
            checkcast java.security.interfaces.RSAPublicKey
            astore 1 /* rsaKey */
        start local 1 // java.security.interfaces.RSAPublicKey rsaKey
         2: .line 347
            new java.security.spec.RSAPublicKeySpec
            dup
            aload 1 /* rsaKey */
            invokeinterface java.security.interfaces.RSAPublicKey.getModulus:()Ljava/math/BigInteger;
         3: .line 348
            aload 1 /* rsaKey */
            invokeinterface java.security.interfaces.RSAPublicKey.getPublicExponent:()Ljava/math/BigInteger;
         4: .line 347
            invokespecial java.security.spec.RSAPublicKeySpec.<init>:(Ljava/math/BigInteger;Ljava/math/BigInteger;)V
            areturn
        end local 1 // java.security.interfaces.RSAPublicKey rsaKey
         5: .line 351
      StackMap locals:
      StackMap stack:
            ldc "RSA"
            invokestatic sun.security.ssl.JsseJce.getKeyFactory:(Ljava/lang/String;)Ljava/security/KeyFactory;
            astore 1 /* factory */
        start local 1 // java.security.KeyFactory factory
         6: .line 352
            aload 1 /* factory */
            aload 0 /* key */
            ldc Ljava/security/spec/RSAPublicKeySpec;
            invokevirtual java.security.KeyFactory.getKeySpec:(Ljava/security/Key;Ljava/lang/Class;)Ljava/security/spec/KeySpec;
            checkcast java.security.spec.RSAPublicKeySpec
         7: areturn
        end local 1 // java.security.KeyFactory factory
         8: .line 353
      StackMap locals:
      StackMap stack: java.lang.Exception
            astore 1 /* e */
        start local 1 // java.lang.Exception e
         9: .line 354
            new java.lang.RuntimeException
            dup
            aload 1 /* e */
            invokespecial java.lang.RuntimeException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 1 // java.lang.Exception e
        end local 0 // java.security.PublicKey key
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0   10     0      key  Ljava/security/PublicKey;
            2    5     1   rsaKey  Ljava/security/interfaces/RSAPublicKey;
            6    8     1  factory  Ljava/security/KeyFactory;
            9   10     1        e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           5     7       8  Class java.lang.Exception
    MethodParameters:
      Name  Flags
      key   

  static java.security.spec.ECParameterSpec getECParameterSpec(java.lang.String);
    descriptor: (Ljava/lang/String;)Ljava/security/spec/ECParameterSpec;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // java.lang.String namedCurveOid
         0: .line 359
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            aload 0 /* namedCurveOid */
            invokestatic sun.security.util.ECUtil.getECParameterSpec:(Ljava/security/Provider;Ljava/lang/String;)Ljava/security/spec/ECParameterSpec;
            areturn
        end local 0 // java.lang.String namedCurveOid
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0    1     0  namedCurveOid  Ljava/lang/String;
    MethodParameters:
               Name  Flags
      namedCurveOid  

  static java.lang.String getNamedCurveOid(java.security.spec.ECParameterSpec);
    descriptor: (Ljava/security/spec/ECParameterSpec;)Ljava/lang/String;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // java.security.spec.ECParameterSpec params
         0: .line 363
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            aload 0 /* params */
            invokestatic sun.security.util.ECUtil.getCurveName:(Ljava/security/Provider;Ljava/security/spec/ECParameterSpec;)Ljava/lang/String;
            areturn
        end local 0 // java.security.spec.ECParameterSpec params
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    1     0  params  Ljava/security/spec/ECParameterSpec;
    MethodParameters:
        Name  Flags
      params  

  static java.security.spec.ECPoint decodePoint(byte[], java.security.spec.EllipticCurve);
    descriptor: ([BLjava/security/spec/EllipticCurve;)Ljava/security/spec/ECPoint;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // byte[] encoded
        start local 1 // java.security.spec.EllipticCurve curve
         0: .line 368
            aload 0 /* encoded */
            aload 1 /* curve */
            invokestatic sun.security.util.ECUtil.decodePoint:([BLjava/security/spec/EllipticCurve;)Ljava/security/spec/ECPoint;
            areturn
        end local 1 // java.security.spec.EllipticCurve curve
        end local 0 // byte[] encoded
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    1     0  encoded  [B
            0    1     1    curve  Ljava/security/spec/EllipticCurve;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
         Name  Flags
      encoded  
      curve    

  static byte[] encodePoint(java.security.spec.ECPoint, java.security.spec.EllipticCurve);
    descriptor: (Ljava/security/spec/ECPoint;Ljava/security/spec/EllipticCurve;)[B
    flags: (0x0008) ACC_STATIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // java.security.spec.ECPoint point
        start local 1 // java.security.spec.EllipticCurve curve
         0: .line 372
            aload 0 /* point */
            aload 1 /* curve */
            invokestatic sun.security.util.ECUtil.encodePoint:(Ljava/security/spec/ECPoint;Ljava/security/spec/EllipticCurve;)[B
            areturn
        end local 1 // java.security.spec.EllipticCurve curve
        end local 0 // java.security.spec.ECPoint point
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    1     0  point  Ljava/security/spec/ECPoint;
            0    1     1  curve  Ljava/security/spec/EllipticCurve;
    MethodParameters:
       Name  Flags
      point  
      curve  

  static java.lang.Object beginFipsProvider();
    descriptor: ()Ljava/lang/Object;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 378
            getstatic sun.security.ssl.JsseJce.fipsProviderList:Lsun/security/jca/ProviderList;
            ifnonnull 2
         1: .line 379
            aconst_null
            areturn
         2: .line 381
      StackMap locals:
      StackMap stack:
            getstatic sun.security.ssl.JsseJce.fipsProviderList:Lsun/security/jca/ProviderList;
            invokestatic sun.security.jca.Providers.beginThreadProviderList:(Lsun/security/jca/ProviderList;)Lsun/security/jca/ProviderList;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  static void endFipsProvider(java.lang.Object);
    descriptor: (Ljava/lang/Object;)V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // java.lang.Object o
         0: .line 386
            getstatic sun.security.ssl.JsseJce.fipsProviderList:Lsun/security/jca/ProviderList;
            ifnull 2
         1: .line 387
            aload 0 /* o */
            checkcast sun.security.jca.ProviderList
            invokestatic sun.security.jca.Providers.endThreadProviderList:(Lsun/security/jca/ProviderList;)V
         2: .line 389
      StackMap locals:
      StackMap stack:
            return
        end local 0 // java.lang.Object o
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0     o  Ljava/lang/Object;
    MethodParameters:
      Name  Flags
      o     
}
SourceFile: "JsseJce.java"
NestMembers:
  sun.security.ssl.JsseJce$EcAvailability  sun.security.ssl.JsseJce$SunCertificates  sun.security.ssl.JsseJce$SunCertificates$1
InnerClasses:
  public Service = java.security.Provider$Service of java.security.Provider
  private EcAvailability = sun.security.ssl.JsseJce$EcAvailability of sun.security.ssl.JsseJce
  private final SunCertificates = sun.security.ssl.JsseJce$SunCertificates of sun.security.ssl.JsseJce