public class com.jcraft.jsch.jce.KeyPairGenECDSA implements com.jcraft.jsch.KeyPairGenECDSA
minor version: 0
major version: 59
flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
this_class: com.jcraft.jsch.jce.KeyPairGenECDSA
super_class: java.lang.Object
{
byte[] d;
descriptor: [B
flags: (0x0000)
byte[] r;
descriptor: [B
flags: (0x0000)
byte[] s;
descriptor: [B
flags: (0x0000)
java.security.interfaces.ECPublicKey pubKey;
descriptor: Ljava/security/interfaces/ECPublicKey;
flags: (0x0000)
java.security.interfaces.ECPrivateKey prvKey;
descriptor: Ljava/security/interfaces/ECPrivateKey;
flags: (0x0000)
java.security.spec.ECParameterSpec params;
descriptor: Ljava/security/spec/ECParameterSpec;
flags: (0x0000)
public void <init>();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
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 Lcom/jcraft/jsch/jce/KeyPairGenECDSA;
public void init(int);
descriptor: (I)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=5, locals=8, args_size=2
start local 0 start local 1 0: aconst_null
astore 2
start local 2 1: iload 1
sipush 256
if_icmpne 2
ldc "secp256r1"
astore 2
goto 5
2: StackMap locals: java.lang.String
StackMap stack:
iload 1
sipush 384
if_icmpne 3
ldc "secp384r1"
astore 2
goto 5
3: StackMap locals:
StackMap stack:
iload 1
sipush 521
if_icmpne 4
ldc "secp521r1"
astore 2
goto 5
4: StackMap locals:
StackMap stack:
new com.jcraft.jsch.JSchException
dup
new java.lang.StringBuilder
dup
ldc "unsupported key size: "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
iload 1
invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
invokespecial com.jcraft.jsch.JSchException.<init>:(Ljava/lang/String;)V
athrow
5: StackMap locals:
StackMap stack:
iconst_0
istore 3
start local 3 6: goto 23
7: StackMap locals: int
StackMap stack:
ldc "EC"
invokestatic java.security.KeyPairGenerator.getInstance:(Ljava/lang/String;)Ljava/security/KeyPairGenerator;
astore 4
start local 4 8: new java.security.spec.ECGenParameterSpec
dup
aload 2
invokespecial java.security.spec.ECGenParameterSpec.<init>:(Ljava/lang/String;)V
astore 5
start local 5 9: aload 4
aload 5
invokevirtual java.security.KeyPairGenerator.initialize:(Ljava/security/spec/AlgorithmParameterSpec;)V
10: aload 4
invokevirtual java.security.KeyPairGenerator.genKeyPair:()Ljava/security/KeyPair;
astore 6
start local 6 11: aload 0
aload 6
invokevirtual java.security.KeyPair.getPrivate:()Ljava/security/PrivateKey;
checkcast java.security.interfaces.ECPrivateKey
putfield com.jcraft.jsch.jce.KeyPairGenECDSA.prvKey:Ljava/security/interfaces/ECPrivateKey;
12: aload 0
aload 6
invokevirtual java.security.KeyPair.getPublic:()Ljava/security/PublicKey;
checkcast java.security.interfaces.ECPublicKey
putfield com.jcraft.jsch.jce.KeyPairGenECDSA.pubKey:Ljava/security/interfaces/ECPublicKey;
13: aload 0
aload 0
getfield com.jcraft.jsch.jce.KeyPairGenECDSA.pubKey:Ljava/security/interfaces/ECPublicKey;
invokeinterface java.security.interfaces.ECPublicKey.getParams:()Ljava/security/spec/ECParameterSpec;
putfield com.jcraft.jsch.jce.KeyPairGenECDSA.params:Ljava/security/spec/ECParameterSpec;
14: aload 0
aload 0
getfield com.jcraft.jsch.jce.KeyPairGenECDSA.prvKey:Ljava/security/interfaces/ECPrivateKey;
invokeinterface java.security.interfaces.ECPrivateKey.getS:()Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.toByteArray:()[B
putfield com.jcraft.jsch.jce.KeyPairGenECDSA.d:[B
15: aload 0
getfield com.jcraft.jsch.jce.KeyPairGenECDSA.pubKey:Ljava/security/interfaces/ECPublicKey;
invokeinterface java.security.interfaces.ECPublicKey.getW:()Ljava/security/spec/ECPoint;
astore 7
start local 7 16: aload 0
aload 7
invokevirtual java.security.spec.ECPoint.getAffineX:()Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.toByteArray:()[B
putfield com.jcraft.jsch.jce.KeyPairGenECDSA.r:[B
17: aload 0
aload 7
invokevirtual java.security.spec.ECPoint.getAffineY:()Ljava/math/BigInteger;
invokevirtual java.math.BigInteger.toByteArray:()[B
putfield com.jcraft.jsch.jce.KeyPairGenECDSA.s:[B
18: aload 0
getfield com.jcraft.jsch.jce.KeyPairGenECDSA.r:[B
arraylength
aload 0
getfield com.jcraft.jsch.jce.KeyPairGenECDSA.s:[B
arraylength
if_icmpeq 19
goto 22
19: StackMap locals: com.jcraft.jsch.jce.KeyPairGenECDSA int java.lang.String int java.security.KeyPairGenerator java.security.spec.ECGenParameterSpec java.security.KeyPair java.security.spec.ECPoint
StackMap stack:
iload 1
sipush 256
if_icmpne 20
aload 0
getfield com.jcraft.jsch.jce.KeyPairGenECDSA.r:[B
arraylength
bipush 32
if_icmpne 20
goto 24
20: StackMap locals:
StackMap stack:
iload 1
sipush 384
if_icmpne 21
aload 0
getfield com.jcraft.jsch.jce.KeyPairGenECDSA.r:[B
arraylength
bipush 48
if_icmpne 21
goto 24
21: StackMap locals:
StackMap stack:
iload 1
sipush 521
if_icmpne 22
aload 0
getfield com.jcraft.jsch.jce.KeyPairGenECDSA.r:[B
arraylength
bipush 66
if_icmpne 22
goto 24
end local 7 end local 6 end local 5 end local 4 22: StackMap locals: com.jcraft.jsch.jce.KeyPairGenECDSA int java.lang.String int
StackMap stack:
iinc 3 1
StackMap locals:
StackMap stack:
23: iload 3
sipush 1000
if_icmplt 7
end local 3 24: StackMap locals:
StackMap stack:
aload 0
getfield com.jcraft.jsch.jce.KeyPairGenECDSA.d:[B
arraylength
aload 0
getfield com.jcraft.jsch.jce.KeyPairGenECDSA.r:[B
arraylength
if_icmpge 26
25: aload 0
aload 0
aload 0
getfield com.jcraft.jsch.jce.KeyPairGenECDSA.d:[B
invokevirtual com.jcraft.jsch.jce.KeyPairGenECDSA.insert0:([B)[B
putfield com.jcraft.jsch.jce.KeyPairGenECDSA.d:[B
26: StackMap locals:
StackMap stack:
return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 27 0 this Lcom/jcraft/jsch/jce/KeyPairGenECDSA;
0 27 1 key_size I
1 27 2 name Ljava/lang/String;
6 24 3 i I
8 22 4 kpg Ljava/security/KeyPairGenerator;
9 22 5 ecsp Ljava/security/spec/ECGenParameterSpec;
11 22 6 kp Ljava/security/KeyPair;
16 22 7 w Ljava/security/spec/ECPoint;
Exceptions:
throws java.lang.Exception
MethodParameters:
Name Flags
key_size
public byte[] getD();
descriptor: ()[B
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield com.jcraft.jsch.jce.KeyPairGenECDSA.d:[B
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lcom/jcraft/jsch/jce/KeyPairGenECDSA;
public byte[] getR();
descriptor: ()[B
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield com.jcraft.jsch.jce.KeyPairGenECDSA.r:[B
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lcom/jcraft/jsch/jce/KeyPairGenECDSA;
public byte[] getS();
descriptor: ()[B
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield com.jcraft.jsch.jce.KeyPairGenECDSA.s:[B
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lcom/jcraft/jsch/jce/KeyPairGenECDSA;
java.security.interfaces.ECPublicKey getPublicKey();
descriptor: ()Ljava/security/interfaces/ECPublicKey;
flags: (0x0000)
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield com.jcraft.jsch.jce.KeyPairGenECDSA.pubKey:Ljava/security/interfaces/ECPublicKey;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lcom/jcraft/jsch/jce/KeyPairGenECDSA;
java.security.interfaces.ECPrivateKey getPrivateKey();
descriptor: ()Ljava/security/interfaces/ECPrivateKey;
flags: (0x0000)
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield com.jcraft.jsch.jce.KeyPairGenECDSA.prvKey:Ljava/security/interfaces/ECPrivateKey;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lcom/jcraft/jsch/jce/KeyPairGenECDSA;
private byte[] insert0(byte[]);
descriptor: ([B)[B
flags: (0x0002) ACC_PRIVATE
Code:
stack=5, locals=3, args_size=2
start local 0 start local 1 0: aload 1
arraylength
iconst_1
iadd
newarray 8
astore 2
start local 2 1: aload 1
iconst_0
aload 2
iconst_1
aload 1
arraylength
invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
2: aload 0
aload 1
invokevirtual com.jcraft.jsch.jce.KeyPairGenECDSA.bzero:([B)V
3: aload 2
areturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lcom/jcraft/jsch/jce/KeyPairGenECDSA;
0 4 1 buf [B
1 4 2 tmp [B
MethodParameters:
Name Flags
buf
private byte[] chop0(byte[]);
descriptor: ([B)[B
flags: (0x0002) ACC_PRIVATE
Code:
stack=5, locals=3, args_size=2
start local 0 start local 1 0: aload 1
iconst_0
baload
ifne 1
aload 1
iconst_1
baload
sipush 128
iand
ifne 2
StackMap locals:
StackMap stack:
1: aload 1
areturn
2: StackMap locals:
StackMap stack:
aload 1
arraylength
iconst_1
isub
newarray 8
astore 2
start local 2 3: aload 1
iconst_1
aload 2
iconst_0
aload 2
arraylength
invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
4: aload 0
aload 1
invokevirtual com.jcraft.jsch.jce.KeyPairGenECDSA.bzero:([B)V
5: aload 2
areturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 6 0 this Lcom/jcraft/jsch/jce/KeyPairGenECDSA;
0 6 1 buf [B
3 6 2 tmp [B
MethodParameters:
Name Flags
buf
private void bzero(byte[]);
descriptor: ([B)V
flags: (0x0002) ACC_PRIVATE
Code:
stack=3, locals=3, args_size=2
start local 0 start local 1 0: iconst_0
istore 2
start local 2 1: goto 3
StackMap locals: int
StackMap stack:
2: aload 1
iload 2
iconst_0
bastore
iinc 2 1
StackMap locals:
StackMap stack:
3: iload 2
aload 1
arraylength
if_icmplt 2
end local 2 4: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 5 0 this Lcom/jcraft/jsch/jce/KeyPairGenECDSA;
0 5 1 buf [B
1 4 2 i I
MethodParameters:
Name Flags
buf
}
SourceFile: "KeyPairGenECDSA.java"