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.ssl.Debug debug;
    descriptor: Lsun/security/ssl/Debug;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final sun.security.jca.ProviderList fipsProviderList;
    descriptor: Lsun/security/jca/ProviderList;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static volatile java.lang.Boolean ecAvailable;
    descriptor: Ljava/lang/Boolean;
    flags: (0x004a) ACC_PRIVATE, ACC_STATIC, ACC_VOLATILE

  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 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 57
            ldc "ssl"
            invokestatic sun.security.ssl.Debug.getInstance:(Ljava/lang/String;)Lsun/security/ssl/Debug;
            putstatic sun.security.ssl.JsseJce.debug:Lsun/security/ssl/Debug;
         1: .line 73
            new sun.security.ssl.JsseJce$1
            dup
            invokespecial sun.security.ssl.JsseJce$1.<init>:()V
         2: .line 72
            invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedExceptionAction;)Ljava/lang/Object;
            pop
         3: .line 81
            iconst_1
            istore 0 /* temp */
        start local 0 // boolean temp
         4: .line 83
            goto 7
        end local 0 // boolean temp
      StackMap locals:
      StackMap stack: java.lang.Exception
         5: pop
         6: .line 84
            iconst_0
            istore 0 /* temp */
        start local 0 // boolean temp
         7: .line 86
      StackMap locals: int
      StackMap stack:
            iload 0 /* temp */
            putstatic sun.security.ssl.JsseJce.kerberosAvailable:Z
        end local 0 // boolean temp
         8: .line 94
            invokestatic sun.security.ssl.SunJSSE.isFIPS:()Z
            ifne 11
         9: .line 95
            aconst_null
            putstatic sun.security.ssl.JsseJce.fipsProviderList:Lsun/security/jca/ProviderList;
        10: .line 96
            goto 18
        11: .line 101
      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
        12: .line 102
            aload 0 /* sun */
            ifnonnull 16
        13: .line 103
            new java.lang.RuntimeException
            dup
        14: .line 104
            ldc "FIPS mode: SUN provider must be installed"
        15: .line 103
            invokespecial java.lang.RuntimeException.<init>:(Ljava/lang/String;)V
            athrow
        16: .line 106
      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
        17: .line 107
            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
        18: .line 188
      StackMap locals:
      StackMap stack:
            return
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            4    5     0      temp  Z
            7    8     0      temp  Z
           12   18     0       sun  Ljava/security/Provider;
           17   18     1  sunCerts  Ljava/security/Provider;
      Exception table:
        from    to  target  type
           1     4       5  Class java.lang.Exception

  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 190
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 192
            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 195
            getstatic sun.security.ssl.JsseJce.ecAvailable:Ljava/lang/Boolean;
            ifnonnull 11
         1: .line 197
            ldc "SHA1withECDSA"
            invokestatic sun.security.ssl.JsseJce.getSignature:(Ljava/lang/String;)Ljava/security/Signature;
            pop
         2: .line 198
            ldc "NONEwithECDSA"
            invokestatic sun.security.ssl.JsseJce.getSignature:(Ljava/lang/String;)Ljava/security/Signature;
            pop
         3: .line 199
            ldc "ECDH"
            invokestatic sun.security.ssl.JsseJce.getKeyAgreement:(Ljava/lang/String;)Ljavax/crypto/KeyAgreement;
            pop
         4: .line 200
            ldc "EC"
            invokestatic sun.security.ssl.JsseJce.getKeyFactory:(Ljava/lang/String;)Ljava/security/KeyFactory;
            pop
         5: .line 201
            ldc "EC"
            invokestatic sun.security.ssl.JsseJce.getKeyPairGenerator:(Ljava/lang/String;)Ljava/security/KeyPairGenerator;
            pop
         6: .line 202
            ldc "EC"
            invokestatic sun.security.ssl.JsseJce.getAlgorithmParameters:(Ljava/lang/String;)Ljava/security/AlgorithmParameters;
            pop
         7: .line 203
            iconst_1
            invokestatic java.lang.Boolean.valueOf:(Z)Ljava/lang/Boolean;
            putstatic sun.security.ssl.JsseJce.ecAvailable:Ljava/lang/Boolean;
         8: .line 204
            goto 11
      StackMap locals:
      StackMap stack: java.lang.Exception
         9: pop
        10: .line 205
            iconst_0
            invokestatic java.lang.Boolean.valueOf:(Z)Ljava/lang/Boolean;
            putstatic sun.security.ssl.JsseJce.ecAvailable:Ljava/lang/Boolean;
        11: .line 208
      StackMap locals:
      StackMap stack:
            getstatic sun.security.ssl.JsseJce.ecAvailable:Ljava/lang/Boolean;
            invokevirtual java.lang.Boolean.booleanValue:()Z
            ireturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature
      Exception table:
        from    to  target  type
           1     8       9  Class java.lang.Exception

  static void clearEcAvailable();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 212
            aconst_null
            putstatic sun.security.ssl.JsseJce.ecAvailable:Ljava/lang/Boolean;
         1: .line 213
            return
      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 216
            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 225
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            ifnonnull 3
         1: .line 226
            aload 0 /* transformation */
            invokestatic javax.crypto.Cipher.getInstance:(Ljava/lang/String;)Ljavax/crypto/Cipher;
         2: areturn
         3: .line 228
      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 230
      StackMap locals:
      StackMap stack: javax.crypto.NoSuchPaddingException
            astore 1 /* e */
        start local 1 // javax.crypto.NoSuchPaddingException e
         6: .line 231
            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 242
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            ifnonnull 2
         1: .line 243
            aload 0 /* algorithm */
            invokestatic java.security.Signature.getInstance:(Ljava/lang/String;)Ljava/security/Signature;
            areturn
         2: .line 246
      StackMap locals:
      StackMap stack:
            aload 0 /* algorithm */
            ldc "MD5andSHA1withRSA"
            if_acmpne 8
         3: .line 251
            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 256
            aload 0 /* algorithm */
            ldc "SunJSSE"
            invokestatic java.security.Signature.getInstance:(Ljava/lang/String;Ljava/lang/String;)Ljava/security/Signature;
         5: areturn
         6: .line 257
      StackMap locals:
      StackMap stack: java.security.NoSuchProviderException
            astore 1 /* e */
        start local 1 // java.security.NoSuchProviderException e
         7: .line 258
            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 262
      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 268
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            ifnonnull 2
         1: .line 269
            aload 0 /* algorithm */
            invokestatic javax.crypto.KeyGenerator.getInstance:(Ljava/lang/String;)Ljavax/crypto/KeyGenerator;
            areturn
         2: .line 271
      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 277
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            ifnonnull 2
         1: .line 278
            aload 0 /* algorithm */
            invokestatic java.security.KeyPairGenerator.getInstance:(Ljava/lang/String;)Ljava/security/KeyPairGenerator;
            areturn
         2: .line 280
      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 286
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            ifnonnull 2
         1: .line 287
            aload 0 /* algorithm */
            invokestatic javax.crypto.KeyAgreement.getInstance:(Ljava/lang/String;)Ljavax/crypto/KeyAgreement;
            areturn
         2: .line 289
      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 295
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            ifnonnull 2
         1: .line 296
            aload 0 /* algorithm */
            invokestatic javax.crypto.Mac.getInstance:(Ljava/lang/String;)Ljavax/crypto/Mac;
            areturn
         2: .line 298
      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 304
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            ifnonnull 2
         1: .line 305
            aload 0 /* algorithm */
            invokestatic java.security.KeyFactory.getInstance:(Ljava/lang/String;)Ljava/security/KeyFactory;
            areturn
         2: .line 307
      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 313
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            ifnonnull 2
         1: .line 314
            aload 0 /* algorithm */
            invokestatic java.security.AlgorithmParameters.getInstance:(Ljava/lang/String;)Ljava/security/AlgorithmParameters;
            areturn
         2: .line 316
      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 321
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            ifnonnull 2
         1: .line 322
            new java.security.SecureRandom
            dup
            invokespecial java.security.SecureRandom.<init>:()V
            areturn
         2: .line 327
      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 328
      StackMap locals:
      StackMap stack: java.security.NoSuchAlgorithmException
            pop
         5: .line 331
            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 332
            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 334
            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 335
      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 331
      StackMap locals: top java.util.Iterator
      StackMap stack:
            aload 1
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 6
        12: .line 340
            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 341
            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 340
            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 345
            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 349
            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 354
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            ifnonnull 3
         1: .line 355
            aload 0 /* algorithm */
            invokestatic java.security.MessageDigest.getInstance:(Ljava/lang/String;)Ljava/security/MessageDigest;
         2: areturn
         3: .line 357
      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 359
      StackMap locals:
      StackMap stack: java.security.NoSuchAlgorithmException
            astore 1 /* e */
        start local 1 // java.security.NoSuchAlgorithmException e
         6: .line 360
            new java.lang.RuntimeException
            dup
         7: .line 361
            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 360
            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 367
            aload 0 /* key */
            instanceof java.security.interfaces.RSAPublicKey
            ifeq 3
         1: .line 368
            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 369
            goto 5
        end local 1 // java.math.BigInteger modulus
         3: .line 370
      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 371
            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 373
      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 377
            aload 0 /* key */
            instanceof java.security.interfaces.RSAPublicKey
            ifeq 5
         1: .line 378
            aload 0 /* key */
            checkcast java.security.interfaces.RSAPublicKey
            astore 1 /* rsaKey */
        start local 1 // java.security.interfaces.RSAPublicKey rsaKey
         2: .line 379
            new java.security.spec.RSAPublicKeySpec
            dup
            aload 1 /* rsaKey */
            invokeinterface java.security.interfaces.RSAPublicKey.getModulus:()Ljava/math/BigInteger;
         3: .line 380
            aload 1 /* rsaKey */
            invokeinterface java.security.interfaces.RSAPublicKey.getPublicExponent:()Ljava/math/BigInteger;
         4: .line 379
            invokespecial java.security.spec.RSAPublicKeySpec.<init>:(Ljava/math/BigInteger;Ljava/math/BigInteger;)V
            areturn
        end local 1 // java.security.interfaces.RSAPublicKey rsaKey
         5: .line 383
      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 384
            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 385
      StackMap locals:
      StackMap stack: java.lang.Exception
            astore 1 /* e */
        start local 1 // java.lang.Exception e
         9: .line 386
            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=1, locals=1, args_size=1
        start local 0 // java.lang.String namedCurveOid
         0: .line 391
            aload 0 /* namedCurveOid */
            invokestatic sun.security.ec.NamedCurve.getECParameterSpec:(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=1, locals=1, args_size=1
        start local 0 // java.security.spec.ECParameterSpec params
         0: .line 395
            aload 0 /* params */
            invokestatic sun.security.ec.ECParameters.getCurveName:(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 400
            aload 0 /* encoded */
            aload 1 /* curve */
            invokestatic sun.security.ec.ECParameters.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 404
            aload 0 /* point */
            aload 1 /* curve */
            invokestatic sun.security.ec.ECParameters.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 410
            getstatic sun.security.ssl.JsseJce.fipsProviderList:Lsun/security/jca/ProviderList;
            ifnonnull 2
         1: .line 411
            aconst_null
            areturn
         2: .line 413
      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 418
            getstatic sun.security.ssl.JsseJce.fipsProviderList:Lsun/security/jca/ProviderList;
            ifnull 2
         1: .line 419
            aload 0 /* o */
            checkcast sun.security.jca.ProviderList
            invokestatic sun.security.jca.Providers.endThreadProviderList:(Lsun/security/jca/ProviderList;)V
         2: .line 421
      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$1  sun.security.ssl.JsseJce$SunCertificates  sun.security.ssl.JsseJce$SunCertificates$1
InnerClasses:
  public Service = java.security.Provider$Service of java.security.Provider
  sun.security.ssl.JsseJce$1
  private final SunCertificates = sun.security.ssl.JsseJce$SunCertificates of sun.security.ssl.JsseJce