久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

從私鑰派生 ECDSA 公鑰

Deriving ECDSA Public Key from Private Key(從私鑰派生 ECDSA 公鑰)
本文介紹了從私鑰派生 ECDSA 公鑰的處理方法,對大家解決問題具有一定的參考價值,需要的朋友們下面隨著小編來一起學習吧!

問題描述

我試圖從私鑰生成公共 ECDSA 密鑰,但我沒有設法在互聯網上找到有關如何執行此操作的太多幫助.幾乎所有東西都是為了從公鑰規范生成公鑰,我不知道如何得到它.到目前為止,這是我整理的:

I was attempting to generate a public ECDSA key from a private key, and I haven't managed to find much help on the internet as to how to do this. Pretty much everything is for generating a public key from a public key spec, and I don't know how to get that. So far, this is what I've put together:

public void setPublic() throws GeneralSecurityException {
    ECNamedCurveParameterSpec params = ECNamedCurveTable.getParameterSpec("secp256k1");
    KeyFactory fact = KeyFactory.getInstance("ECDSA", "BC");
    ECCurve curve = params.getCurve();
    java.security.spec.EllipticCurve ellipticCurve = EC5Util.convertCurve(curve, params.getSeed());
    java.security.spec.ECPoint point = ECPointUtil.decodePoint(ellipticCurve, this.privateKey.getEncoded());
    java.security.spec.ECParameterSpec params2=EC5Util.convertSpec(ellipticCurve, params);
    java.security.spec.ECPublicKeySpec keySpec = new java.security.spec.ECPublicKeySpec(point,params2);
    this.publicKey = fact.generatePublic(keySpec);
}

但是,在運行時,我收到以下錯誤:

However, when running, I get the following error:

Exception in thread "main" java.lang.IllegalArgumentException: Invalid point encoding 0x30
at org.bouncycastle.math.ec.ECCurve.decodePoint(Unknown Source)
at org.bouncycastle.jce.ECPointUtil.decodePoint(Unknown Source)
at Wallet.Wallet.setPublic(Wallet.java:125)

我做錯了什么?有沒有更好/更簡單的方法來做到這一點?

What am I doing wrong? Is there a better/easier way to do this?

我已經設法編譯了一些代碼,但它不能正常工作:

I've managed to get some code to compile, but it does not work correctly:

public void setPublic() throws GeneralSecurityException {
    BigInteger privKey = new BigInteger(getHex(privateKey.getEncoded()),16);
    X9ECParameters ecp = SECNamedCurves.getByName("secp256k1");
    ECPoint curvePt = ecp.getG().multiply(privKey);
    BigInteger x = curvePt.getX().toBigInteger();
    BigInteger y = curvePt.getY().toBigInteger();
    byte[] xBytes = removeSignByte(x.toByteArray());
    byte[] yBytes = removeSignByte(y.toByteArray());
    byte[] pubKeyBytes = new byte[65];
    pubKeyBytes[0] = new Byte("04");
    System.arraycopy(xBytes, 0, pubKeyBytes, 1, xBytes.length);
    System.arraycopy(yBytes, 0, pubKeyBytes, 33, xBytes.length);




    ECNamedCurveParameterSpec params = ECNamedCurveTable.getParameterSpec("secp256k1");
    KeyFactory fact = KeyFactory.getInstance("ECDSA", "BC");
    ECCurve curve = params.getCurve();
    java.security.spec.EllipticCurve ellipticCurve = EC5Util.convertCurve(curve, params.getSeed());
    java.security.spec.ECPoint point = ECPointUtil.decodePoint(ellipticCurve, pubKeyBytes);
    java.security.spec.ECParameterSpec params2 = EC5Util.convertSpec(ellipticCurve, params);
    java.security.spec.ECPublicKeySpec keySpec = new java.security.spec.ECPublicKeySpec(point,params2);
    this.publicKey = fact.generatePublic(keySpec);
}

private byte[] removeSignByte(byte[] arr)
{
    if(arr.length==33)
    {
        byte[] newArr = new byte[32];
        System.arraycopy(arr, 1, newArr, 0, newArr.length);
        return newArr;
    }
    return arr;
}

當我運行它時,它會生成一個公鑰,但它與私鑰對應的不是同一個.

When I run it, it generates a publicKey, but it's not the same one that the private key corresponds to.

推薦答案

所以過了一會兒,我想出了一個解決方案,并決定發布它以防其他人和我有同樣的問題:

So after a while, I figured out a solution and decided to post it in case anyone else has the same issue as me:

KeyFactory keyFactory = KeyFactory.getInstance("ECDSA", "BC");
    ECParameterSpec ecSpec = ECNamedCurveTable.getParameterSpec("secp256k1");

    ECPoint Q = ecSpec.getG().multiply(((org.bouncycastle.jce.interfaces.ECPrivateKey) this.privateKey).getD());

    ECPublicKeySpec pubSpec = new ECPublicKeySpec(Q, ecSpec);
    PublicKey publicKeyGenerated = keyFactory.generatePublic(pubSpec);
    this.publicKey = publicKeyGenerated;

根據@MaartenBodewes 評論刪除了解碼 ECPoint 的代碼.

Removed the code decoding the ECPoint as per @MaartenBodewes comment.

這篇關于從私鑰派生 ECDSA 公鑰的文章就介紹到這了,希望我們推薦的答案對大家有所幫助,也希望大家多多支持html5模板網!

【網站聲明】本站部分內容來源于互聯網,旨在幫助大家更快的解決問題,如果有圖片或者內容侵犯了您的權益,請聯系我們刪除處理,感謝您的支持!

相關文檔推薦

Java Remove Duplicates from an Array?(Java從數組中刪除重復項?)
How to fix Invocation failed Unexpected Response from Server: Unauthorized in Android studio(如何修復調用失敗來自服務器的意外響應:在 Android 工作室中未經授權)
AES encryption, got extra trash characters in decrypted file(AES 加密,解密文件中有多余的垃圾字符)
AES Error: Given final block not properly padded(AES 錯誤:給定的最終塊未正確填充)
Detecting incorrect key using AES/GCM in JAVA(在 JAVA 中使用 AES/GCM 檢測不正確的密鑰)
AES-256-CBC in Java(Java 中的 AES-256-CBC)
主站蜘蛛池模板: 亚洲成人一区二区三区 | 亚洲成人av| 日韩欧美中文字幕在线观看 | 天堂色 | 最新超碰 | 黄毛片| 日韩成人在线视频 | 国产视频久 | 91精品国产一区二区在线观看 | 精品一区二区久久 | 国产精品日女人 | 亚洲视频第一页 | 国产日韩精品一区二区三区 | 国产精品视频一区二区三区 | 亚洲国产成人精品女人久久久野战 | av黄色在线| 91久久精品国产 | 天天插天天舔 | 亚洲欧洲综合av | 欧美日韩在线一区二区三区 | 国产精品久久久久久久岛一牛影视 | 国产视频久 | 国产福利一区二区 | 黑人精品欧美一区二区蜜桃 | 欧美成人a | 久久天堂| 国产高清在线观看 | 中文字幕亚洲精品在线观看 | 亚洲精品一区二区三区蜜桃久 | 2020天天操| 亚洲另类视频 | 亚洲一区二区免费视频 | 九九热精| 欧美二区在线 | 色毛片| 中文字幕亚洲精品 | 国产精品久久久久久婷婷天堂 | 国产综合久久久久久鬼色 | 狠狠色综合网站久久久久久久 | 亚洲午夜精品视频 | 亚洲高清视频在线观看 |