是的,这是正确的,EC私钥只是一个数字.如果您打印出私钥,您将看到相应公钥的X和Y坐标.
例如,假设生成了以下密钥对(secp256r1):
> EC私钥:
1b9cdf53588f99cea61c6482c4549b0316bafde19f76851940d71babaec5e569
> EC公钥:
0458ff2cd70c9a0897eb90a7c43d6a656bd76bb8089d52c259db6d9a45bfb37eb9882521c3b1e20a8bae181233b939174ee95e12a47bf62f41a62f1a20381a6f03
我们将私钥字节插入到您的函数中:
BigInteger priv = new BigInteger("1b9cdf53588f99cea61c6482c4549b0316bafde19f76851940d71babaec5e569", 16);
PrivateKey privateKey = getPrivateKeyFromECBigIntAndCurve(priv, "secp256r1");
System.out.println(privateKey);
并打印:
EC Private Key [91:05:8a:28:94:f9:5c:cb:c4:34:b8:69:e4:39:d4:57:59:c7:51:35]
X: 58ff2cd70c9a0897eb90a7c43d6a656bd76bb8089d52c259db6d9a45bfb37eb9
Y: 882521c3b1e20a8bae181233b939174ee95e12a47bf62f41a62f1a20381a6f03
如您所见,如果串联04 X Y,您将获得原始的公钥(04是未压缩的EC点标记).