如何将公钥转换为BigInteger

时间:2012-04-12 06:08:05

标签: java elliptic-curve

我需要将公钥转换为BigInteger。在下面的代码中,我提取了私钥并将其存储为BigInteger。但是,当我对公众采用相同的方法时,它无法正常工作。

public static void main(String[] args) throws  Exception {
    Security.addProvider(new BouncyCastleProvider());
    BigInteger ZERO=new BigInteger("0");
    int c;
    //  ECParameterSpec ecSpec = ECNamedCurveTable.getParameterSpec("P-224");
    ECCurve curve = new ECCurve.Fp(
          new       BigInteger("883423532389192164791648750360308885314476597252960362792450860609699839"), // q
          new BigInteger("7fffffffffffffffffffffff7fffffffffff8000000000007ffffffffffc", 16), // a
          new BigInteger("6b016c3bdcf18941d0d654921475ca71a9db2fb27d1d37796185c2942c0a", 16)); // b

    ECParameterSpec ecSpec = new ECParameterSpec(
          curve,
          curve.decodePoint( Hex.decode("020ffa963cdca8816ccc33b8642bedf905c3d358573d3f27fbbd3b3cb9aaaf")), // G
              new   BigInteger("883423532389192164791648750360308884807550341691627752275345424702807307")); // n
    KeyPairGenerator kpg = KeyPairGenerator.getInstance("ECDSA", "BC");
    kpg.initialize(ecSpec, new SecureRandom());
    KeyPair keyPair = kpg.generateKeyPair();
    PublicKey pubKey = keyPair.getPublic();
    System.out.println(pubKey);
    PrivateKey privKey = keyPair.getPrivate();
    System.out.println(privKey);
    BigInteger s = ((ECPrivateKey) privKey).getS();
    System.out.println(s);

1 个答案:

答案 0 :(得分:1)

在ECDSA中,私钥是BigInteger,但公钥是ECPoint(由两个BigInteger值组成)。将其转换为BigInteger将无效。使用

ECPoint w = ((ECPublicKey)pubKey).getW();
BigInteger wx = w.getAffineX(), wy = w.getAffineY();
System.out.println(wx);
System.out.println(wy);