class sun.security.ssl.NamedGroup$ECDHEScheme implements sun.security.ssl.NamedGroup$NamedGroupScheme
minor version: 0
major version: 59
flags: flags: (0x0020) ACC_SUPER
this_class: sun.security.ssl.NamedGroup$ECDHEScheme
super_class: java.lang.Object
{
private static final sun.security.ssl.NamedGroup$ECDHEScheme instance;
descriptor: Lsun/security/ssl/NamedGroup$ECDHEScheme;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
static void <clinit>();
descriptor: ()V
flags: (0x0008) ACC_STATIC
Code:
stack=2, locals=0, args_size=0
0: new sun.security.ssl.NamedGroup$ECDHEScheme
dup
invokespecial sun.security.ssl.NamedGroup$ECDHEScheme.<init>:()V
putstatic sun.security.ssl.NamedGroup$ECDHEScheme.instance:Lsun/security/ssl/NamedGroup$ECDHEScheme;
return
LocalVariableTable:
Start End Slot Name Signature
private void <init>();
descriptor: ()V
flags: (0x0002) ACC_PRIVATE
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
invokespecial java.lang.Object.<init>:()V
return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lsun/security/ssl/NamedGroup$ECDHEScheme;
public byte[] encodePossessionPublicKey(sun.security.ssl.NamedGroupPossession);
descriptor: (Lsun/security/ssl/NamedGroupPossession;)[B
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=2, args_size=2
start local 0 start local 1 0: aload 1
checkcast sun.security.ssl.ECDHKeyExchange$ECDHEPossession
invokevirtual sun.security.ssl.ECDHKeyExchange$ECDHEPossession.encode:()[B
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lsun/security/ssl/NamedGroup$ECDHEScheme;
0 1 1 namedGroupPossession Lsun/security/ssl/NamedGroupPossession;
MethodParameters:
Name Flags
namedGroupPossession
public sun.security.ssl.SSLCredentials decodeCredentials(sun.security.ssl.NamedGroup, byte[], java.security.AlgorithmConstraints, sun.security.ssl.NamedGroup$ExceptionSupplier);
descriptor: (Lsun/security/ssl/NamedGroup;[BLjava/security/AlgorithmConstraints;Lsun/security/ssl/NamedGroup$ExceptionSupplier;)Lsun/security/ssl/SSLCredentials;
flags: (0x0001) ACC_PUBLIC
Code:
stack=4, locals=6, args_size=5
start local 0 start local 1 start local 2 start local 3 start local 4 0: aload 1
aload 2
invokestatic sun.security.ssl.ECDHKeyExchange$ECDHECredentials.valueOf:(Lsun/security/ssl/NamedGroup;[B)Lsun/security/ssl/ECDHKeyExchange$ECDHECredentials;
1: astore 5
start local 5 2: aload 0
aload 5
invokevirtual sun.security.ssl.ECDHKeyExchange$ECDHECredentials.getPublicKey:()Ljava/security/PublicKey;
aload 3
3: aload 4
4: invokevirtual sun.security.ssl.NamedGroup$ECDHEScheme.checkConstraints:(Ljava/security/PublicKey;Ljava/security/AlgorithmConstraints;Lsun/security/ssl/NamedGroup$ExceptionSupplier;)V
5: aload 5
areturn
end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 6 0 this Lsun/security/ssl/NamedGroup$ECDHEScheme;
0 6 1 ng Lsun/security/ssl/NamedGroup;
0 6 2 encoded [B
0 6 3 constraints Ljava/security/AlgorithmConstraints;
0 6 4 onConstraintFail Lsun/security/ssl/NamedGroup$ExceptionSupplier;
2 6 5 result Lsun/security/ssl/ECDHKeyExchange$ECDHECredentials;
Exceptions:
throws java.io.IOException, java.security.GeneralSecurityException
MethodParameters:
Name Flags
ng
encoded
constraints
onConstraintFail
public sun.security.ssl.SSLPossession createPossession(sun.security.ssl.NamedGroup, java.security.SecureRandom);
descriptor: (Lsun/security/ssl/NamedGroup;Ljava/security/SecureRandom;)Lsun/security/ssl/SSLPossession;
flags: (0x0001) ACC_PUBLIC
Code:
stack=4, locals=3, args_size=3
start local 0 start local 1 start local 2 0: new sun.security.ssl.ECDHKeyExchange$ECDHEPossession
dup
aload 1
aload 2
invokespecial sun.security.ssl.ECDHKeyExchange$ECDHEPossession.<init>:(Lsun/security/ssl/NamedGroup;Ljava/security/SecureRandom;)V
areturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lsun/security/ssl/NamedGroup$ECDHEScheme;
0 1 1 ng Lsun/security/ssl/NamedGroup;
0 1 2 random Ljava/security/SecureRandom;
MethodParameters:
Name Flags
ng
random
public sun.security.ssl.SSLKeyDerivation createKeyDerivation(sun.security.ssl.HandshakeContext);
descriptor: (Lsun/security/ssl/HandshakeContext;)Lsun/security/ssl/SSLKeyDerivation;
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: getstatic sun.security.ssl.ECDHKeyExchange.ecdheKAGenerator:Lsun/security/ssl/SSLKeyAgreementGenerator;
aload 1
invokeinterface sun.security.ssl.SSLKeyAgreementGenerator.createKeyDerivation:(Lsun/security/ssl/HandshakeContext;)Lsun/security/ssl/SSLKeyDerivation;
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lsun/security/ssl/NamedGroup$ECDHEScheme;
0 1 1 hc Lsun/security/ssl/HandshakeContext;
Exceptions:
throws java.io.IOException
MethodParameters:
Name Flags
hc
}
SourceFile: "NamedGroup.java"
NestHost: sun.security.ssl.NamedGroup
InnerClasses:
final ECDHECredentials = sun.security.ssl.ECDHKeyExchange$ECDHECredentials of sun.security.ssl.ECDHKeyExchange
final ECDHEPossession = sun.security.ssl.ECDHKeyExchange$ECDHEPossession of sun.security.ssl.ECDHKeyExchange
private ECDHEScheme = sun.security.ssl.NamedGroup$ECDHEScheme of sun.security.ssl.NamedGroup
abstract ExceptionSupplier = sun.security.ssl.NamedGroup$ExceptionSupplier of sun.security.ssl.NamedGroup
private abstract NamedGroupScheme = sun.security.ssl.NamedGroup$NamedGroupScheme of sun.security.ssl.NamedGroup