public final class sun.security.ssl.SSLContextImpl$DefaultSSLContext extends sun.security.ssl.SSLContextImpl$ConservativeSSLContext
  minor version: 0
  major version: 59
  flags: flags: (0x0031) ACC_PUBLIC, ACC_FINAL, ACC_SUPER
  this_class: sun.security.ssl.SSLContextImpl$DefaultSSLContext
  super_class: sun.security.ssl.SSLContextImpl$ConservativeSSLContext
{
  private static final java.lang.String NONE;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "NONE"

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

  private static volatile sun.security.ssl.SSLContextImpl defaultImpl;
    descriptor: Lsun/security/ssl/SSLContextImpl;
    flags: (0x004a) ACC_PRIVATE, ACC_STATIC, ACC_VOLATILE

  private static javax.net.ssl.TrustManager[] defaultTrustManagers;
    descriptor: [Ljavax/net/ssl/TrustManager;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC

  private static javax.net.ssl.KeyManager[] defaultKeyManagers;
    descriptor: [Ljavax/net/ssl/KeyManager;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC

  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=2, args_size=1
        start local 0 // sun.security.ssl.SSLContextImpl$DefaultSSLContext this
         0: .line 521
            aload 0 /* this */
            invokespecial sun.security.ssl.SSLContextImpl$ConservativeSSLContext.<init>:()V
         1: .line 523
            aload 0 /* this */
            invokestatic sun.security.ssl.SSLContextImpl$DefaultSSLContext.getDefaultKeyManager:()[Ljavax/net/ssl/KeyManager;
         2: .line 524
            invokestatic sun.security.ssl.SSLContextImpl$DefaultSSLContext.getDefaultTrustManager:()[Ljavax/net/ssl/TrustManager;
            aconst_null
         3: .line 523
            invokespecial sun.security.ssl.SSLContextImpl$ConservativeSSLContext.engineInit:([Ljavax/net/ssl/KeyManager;[Ljavax/net/ssl/TrustManager;Ljava/security/SecureRandom;)V
         4: .line 525
            goto 9
      StackMap locals: sun.security.ssl.SSLContextImpl$DefaultSSLContext
      StackMap stack: java.lang.Exception
         5: astore 1 /* e */
        start local 1 // java.lang.Exception e
         6: .line 526
            getstatic sun.security.ssl.SSLContextImpl.debug:Lsun/security/ssl/Debug;
            ifnull 8
            ldc "defaultctx"
            invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
            ifeq 8
         7: .line 527
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "default context init failed: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* e */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
         8: .line 529
      StackMap locals: java.lang.Exception
      StackMap stack:
            aload 1 /* e */
            athrow
        end local 1 // java.lang.Exception e
         9: .line 532
      StackMap locals:
      StackMap stack:
            getstatic sun.security.ssl.SSLContextImpl$DefaultSSLContext.defaultImpl:Lsun/security/ssl/SSLContextImpl;
            ifnonnull 11
        10: .line 533
            aload 0 /* this */
            putstatic sun.security.ssl.SSLContextImpl$DefaultSSLContext.defaultImpl:Lsun/security/ssl/SSLContextImpl;
        11: .line 535
      StackMap locals:
      StackMap stack:
            return
        end local 0 // sun.security.ssl.SSLContextImpl$DefaultSSLContext this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   12     0  this  Lsun/security/ssl/SSLContextImpl$DefaultSSLContext;
            6    9     1     e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           1     4       5  Class java.lang.Exception
    Exceptions:
      throws java.lang.Exception

  protected void engineInit(javax.net.ssl.KeyManager[], javax.net.ssl.TrustManager[], java.security.SecureRandom);
    descriptor: ([Ljavax/net/ssl/KeyManager;[Ljavax/net/ssl/TrustManager;Ljava/security/SecureRandom;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=3, locals=4, args_size=4
        start local 0 // sun.security.ssl.SSLContextImpl$DefaultSSLContext this
        start local 1 // javax.net.ssl.KeyManager[] km
        start local 2 // javax.net.ssl.TrustManager[] tm
        start local 3 // java.security.SecureRandom sr
         0: .line 539
            new java.security.KeyManagementException
            dup
         1: .line 540
            ldc "Default SSLContext is initialized automatically"
         2: .line 539
            invokespecial java.security.KeyManagementException.<init>:(Ljava/lang/String;)V
            athrow
        end local 3 // java.security.SecureRandom sr
        end local 2 // javax.net.ssl.TrustManager[] tm
        end local 1 // javax.net.ssl.KeyManager[] km
        end local 0 // sun.security.ssl.SSLContextImpl$DefaultSSLContext this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lsun/security/ssl/SSLContextImpl$DefaultSSLContext;
            0    3     1    km  [Ljavax/net/ssl/KeyManager;
            0    3     2    tm  [Ljavax/net/ssl/TrustManager;
            0    3     3    sr  Ljava/security/SecureRandom;
    Exceptions:
      throws java.security.KeyManagementException
    MethodParameters:
      Name  Flags
      km    
      tm    
      sr    

  static synchronized sun.security.ssl.SSLContextImpl getDefaultImpl();
    descriptor: ()Lsun/security/ssl/SSLContextImpl;
    flags: (0x0028) ACC_STATIC, ACC_SYNCHRONIZED
    Code:
      stack=1, locals=0, args_size=0
         0: .line 544
            getstatic sun.security.ssl.SSLContextImpl$DefaultSSLContext.defaultImpl:Lsun/security/ssl/SSLContextImpl;
            ifnonnull 2
         1: .line 545
            new sun.security.ssl.SSLContextImpl$DefaultSSLContext
            invokespecial sun.security.ssl.SSLContextImpl$DefaultSSLContext.<init>:()V
         2: .line 547
      StackMap locals:
      StackMap stack:
            getstatic sun.security.ssl.SSLContextImpl$DefaultSSLContext.defaultImpl:Lsun/security/ssl/SSLContextImpl;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature
    Exceptions:
      throws java.lang.Exception

  private static synchronized javax.net.ssl.TrustManager[] getDefaultTrustManager();
    descriptor: ()[Ljavax/net/ssl/TrustManager;
    flags: (0x002a) ACC_PRIVATE, ACC_STATIC, ACC_SYNCHRONIZED
    Code:
      stack=2, locals=2, args_size=0
         0: .line 552
            getstatic sun.security.ssl.SSLContextImpl$DefaultSSLContext.defaultTrustManagers:[Ljavax/net/ssl/TrustManager;
            ifnull 2
         1: .line 553
            getstatic sun.security.ssl.SSLContextImpl$DefaultSSLContext.defaultTrustManagers:[Ljavax/net/ssl/TrustManager;
            areturn
         2: .line 557
      StackMap locals:
      StackMap stack:
            ldc "defaultctx"
            invokestatic sun.security.ssl.TrustManagerFactoryImpl.getCacertsKeyStore:(Ljava/lang/String;)Ljava/security/KeyStore;
         3: .line 556
            astore 0 /* ks */
        start local 0 // java.security.KeyStore ks
         4: .line 560
            invokestatic javax.net.ssl.TrustManagerFactory.getDefaultAlgorithm:()Ljava/lang/String;
         5: .line 559
            invokestatic javax.net.ssl.TrustManagerFactory.getInstance:(Ljava/lang/String;)Ljavax/net/ssl/TrustManagerFactory;
            astore 1 /* tmf */
        start local 1 // javax.net.ssl.TrustManagerFactory tmf
         6: .line 561
            aload 1 /* tmf */
            aload 0 /* ks */
            invokevirtual javax.net.ssl.TrustManagerFactory.init:(Ljava/security/KeyStore;)V
         7: .line 562
            aload 1 /* tmf */
            invokevirtual javax.net.ssl.TrustManagerFactory.getTrustManagers:()[Ljavax/net/ssl/TrustManager;
            putstatic sun.security.ssl.SSLContextImpl$DefaultSSLContext.defaultTrustManagers:[Ljavax/net/ssl/TrustManager;
         8: .line 563
            getstatic sun.security.ssl.SSLContextImpl$DefaultSSLContext.defaultTrustManagers:[Ljavax/net/ssl/TrustManager;
            areturn
        end local 1 // javax.net.ssl.TrustManagerFactory tmf
        end local 0 // java.security.KeyStore ks
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            4    9     0    ks  Ljava/security/KeyStore;
            6    9     1   tmf  Ljavax/net/ssl/TrustManagerFactory;
    Exceptions:
      throws java.lang.Exception

  private static synchronized javax.net.ssl.KeyManager[] getDefaultKeyManager();
    descriptor: ()[Ljavax/net/ssl/KeyManager;
    flags: (0x002a) ACC_PRIVATE, ACC_STATIC, ACC_SYNCHRONIZED
    Code:
      stack=4, locals=9, args_size=0
         0: .line 568
            getstatic sun.security.ssl.SSLContextImpl$DefaultSSLContext.defaultKeyManagers:[Ljavax/net/ssl/KeyManager;
            ifnull 2
         1: .line 569
            getstatic sun.security.ssl.SSLContextImpl$DefaultSSLContext.defaultKeyManagers:[Ljavax/net/ssl/KeyManager;
            areturn
         2: .line 572
      StackMap locals:
      StackMap stack:
            new java.util.HashMap
            dup
            invokespecial java.util.HashMap.<init>:()V
            astore 0 /* props */
        start local 0 // java.util.Map props
         3: .line 574
            new sun.security.ssl.SSLContextImpl$DefaultSSLContext$1
            dup
            aload 0 /* props */
            invokespecial sun.security.ssl.SSLContextImpl$DefaultSSLContext$1.<init>:(Ljava/util/Map;)V
         4: .line 573
            invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedExceptionAction;)Ljava/lang/Object;
            pop
         5: .line 589
            aload 0 /* props */
            ldc "keyStore"
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.String
            astore 1 /* defaultKeyStore */
        start local 1 // java.lang.String defaultKeyStore
         6: .line 590
            aload 0 /* props */
            ldc "keyStoreType"
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.String
            astore 2 /* defaultKeyStoreType */
        start local 2 // java.lang.String defaultKeyStoreType
         7: .line 591
            aload 0 /* props */
            ldc "keyStoreProvider"
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.String
            astore 3 /* defaultKeyStoreProvider */
        start local 3 // java.lang.String defaultKeyStoreProvider
         8: .line 592
            getstatic sun.security.ssl.SSLContextImpl.debug:Lsun/security/ssl/Debug;
            ifnull 16
            ldc "defaultctx"
            invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
            ifeq 16
         9: .line 593
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "keyStore is : "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* defaultKeyStore */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        10: .line 594
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "keyStore type is : "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        11: .line 595
            aload 2 /* defaultKeyStoreType */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        12: .line 594
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        13: .line 596
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "keyStore provider is : "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        14: .line 597
            aload 3 /* defaultKeyStoreProvider */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        15: .line 596
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        16: .line 600
      StackMap locals: java.util.Map java.lang.String java.lang.String java.lang.String
      StackMap stack:
            ldc "PKCS11"
            aload 2 /* defaultKeyStoreType */
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 19
        17: .line 601
            ldc "NONE"
            aload 1 /* defaultKeyStore */
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 19
        18: .line 602
            new java.lang.IllegalArgumentException
            dup
            ldc "if keyStoreType is PKCS11, then keyStore must be NONE"
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
        19: .line 606
      StackMap locals:
      StackMap stack:
            aconst_null
            astore 4 /* fs */
        start local 4 // java.io.FileInputStream fs
        20: .line 607
            aload 1 /* defaultKeyStore */
            invokevirtual java.lang.String.length:()I
            ifeq 23
            ldc "NONE"
            aload 1 /* defaultKeyStore */
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 23
        21: .line 609
            new sun.security.ssl.SSLContextImpl$DefaultSSLContext$2
            dup
            aload 1 /* defaultKeyStore */
            invokespecial sun.security.ssl.SSLContextImpl$DefaultSSLContext$2.<init>:(Ljava/lang/String;)V
        22: .line 608
            invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedExceptionAction;)Ljava/lang/Object;
            checkcast java.io.FileInputStream
            astore 4 /* fs */
        23: .line 616
      StackMap locals: java.io.FileInputStream
      StackMap stack:
            aload 0 /* props */
            ldc "keyStorePasswd"
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.String
            astore 5 /* defaultKeyStorePassword */
        start local 5 // java.lang.String defaultKeyStorePassword
        24: .line 617
            aconst_null
            astore 6 /* passwd */
        start local 6 // char[] passwd
        25: .line 618
            aload 5 /* defaultKeyStorePassword */
            invokevirtual java.lang.String.length:()I
            ifeq 27
        26: .line 619
            aload 5 /* defaultKeyStorePassword */
            invokevirtual java.lang.String.toCharArray:()[C
            astore 6 /* passwd */
        27: .line 625
      StackMap locals: java.lang.String char[]
      StackMap stack:
            aconst_null
            astore 7 /* ks */
        start local 7 // java.security.KeyStore ks
        28: .line 626
            aload 2 /* defaultKeyStoreType */
            invokevirtual java.lang.String.length:()I
            ifeq 38
        29: .line 627
            getstatic sun.security.ssl.SSLContextImpl.debug:Lsun/security/ssl/Debug;
            ifnull 31
            ldc "defaultctx"
            invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
            ifeq 31
        30: .line 628
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc "init keystore"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        31: .line 630
      StackMap locals: java.security.KeyStore
      StackMap stack:
            aload 3 /* defaultKeyStoreProvider */
            invokevirtual java.lang.String.length:()I
            ifne 34
        32: .line 631
            aload 2 /* defaultKeyStoreType */
            invokestatic java.security.KeyStore.getInstance:(Ljava/lang/String;)Ljava/security/KeyStore;
            astore 7 /* ks */
        33: .line 632
            goto 37
        34: .line 633
      StackMap locals:
      StackMap stack:
            aload 2 /* defaultKeyStoreType */
        35: .line 634
            aload 3 /* defaultKeyStoreProvider */
        36: .line 633
            invokestatic java.security.KeyStore.getInstance:(Ljava/lang/String;Ljava/lang/String;)Ljava/security/KeyStore;
            astore 7 /* ks */
        37: .line 638
      StackMap locals:
      StackMap stack:
            aload 7 /* ks */
            aload 4 /* fs */
            aload 6 /* passwd */
            invokevirtual java.security.KeyStore.load:(Ljava/io/InputStream;[C)V
        38: .line 640
      StackMap locals:
      StackMap stack:
            aload 4 /* fs */
            ifnull 41
        39: .line 641
            aload 4 /* fs */
            invokevirtual java.io.FileInputStream.close:()V
        40: .line 642
            aconst_null
            astore 4 /* fs */
        41: .line 648
      StackMap locals:
      StackMap stack:
            getstatic sun.security.ssl.SSLContextImpl.debug:Lsun/security/ssl/Debug;
            ifnull 45
            ldc "defaultctx"
            invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
            ifeq 45
        42: .line 649
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "init keymanager of type "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        43: .line 650
            invokestatic javax.net.ssl.KeyManagerFactory.getDefaultAlgorithm:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        44: .line 649
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        45: .line 653
      StackMap locals:
      StackMap stack:
            invokestatic javax.net.ssl.KeyManagerFactory.getDefaultAlgorithm:()Ljava/lang/String;
        46: .line 652
            invokestatic javax.net.ssl.KeyManagerFactory.getInstance:(Ljava/lang/String;)Ljavax/net/ssl/KeyManagerFactory;
            astore 8 /* kmf */
        start local 8 // javax.net.ssl.KeyManagerFactory kmf
        47: .line 655
            ldc "PKCS11"
            aload 2 /* defaultKeyStoreType */
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 50
        48: .line 656
            aload 8 /* kmf */
            aload 7 /* ks */
            aconst_null
            invokevirtual javax.net.ssl.KeyManagerFactory.init:(Ljava/security/KeyStore;[C)V
        49: .line 657
            goto 51
        50: .line 658
      StackMap locals: javax.net.ssl.KeyManagerFactory
      StackMap stack:
            aload 8 /* kmf */
            aload 7 /* ks */
            aload 6 /* passwd */
            invokevirtual javax.net.ssl.KeyManagerFactory.init:(Ljava/security/KeyStore;[C)V
        51: .line 661
      StackMap locals:
      StackMap stack:
            aload 8 /* kmf */
            invokevirtual javax.net.ssl.KeyManagerFactory.getKeyManagers:()[Ljavax/net/ssl/KeyManager;
            putstatic sun.security.ssl.SSLContextImpl$DefaultSSLContext.defaultKeyManagers:[Ljavax/net/ssl/KeyManager;
        52: .line 662
            getstatic sun.security.ssl.SSLContextImpl$DefaultSSLContext.defaultKeyManagers:[Ljavax/net/ssl/KeyManager;
            areturn
        end local 8 // javax.net.ssl.KeyManagerFactory kmf
        end local 7 // java.security.KeyStore ks
        end local 6 // char[] passwd
        end local 5 // java.lang.String defaultKeyStorePassword
        end local 4 // java.io.FileInputStream fs
        end local 3 // java.lang.String defaultKeyStoreProvider
        end local 2 // java.lang.String defaultKeyStoreType
        end local 1 // java.lang.String defaultKeyStore
        end local 0 // java.util.Map props
      LocalVariableTable:
        Start  End  Slot                     Name  Signature
            3   53     0                    props  Ljava/util/Map<Ljava/lang/String;Ljava/lang/String;>;
            6   53     1          defaultKeyStore  Ljava/lang/String;
            7   53     2      defaultKeyStoreType  Ljava/lang/String;
            8   53     3  defaultKeyStoreProvider  Ljava/lang/String;
           20   53     4                       fs  Ljava/io/FileInputStream;
           24   53     5  defaultKeyStorePassword  Ljava/lang/String;
           25   53     6                   passwd  [C
           28   53     7                       ks  Ljava/security/KeyStore;
           47   53     8                      kmf  Ljavax/net/ssl/KeyManagerFactory;
    Exceptions:
      throws java.lang.Exception
}
SourceFile: "SSLContextImpl.java"
NestHost: sun.security.ssl.SSLContextImpl
InnerClasses:
  private ConservativeSSLContext = sun.security.ssl.SSLContextImpl$ConservativeSSLContext of sun.security.ssl.SSLContextImpl
  public final DefaultSSLContext = sun.security.ssl.SSLContextImpl$DefaultSSLContext of sun.security.ssl.SSLContextImpl
  sun.security.ssl.SSLContextImpl$DefaultSSLContext$1
  sun.security.ssl.SSLContextImpl$DefaultSSLContext$2