从私钥创建以太坊公共地址

时间:2020-03-15 20:59:21

标签: c# cryptography rsa private

https://www.freecodecamp.org/news/how-to-create-an-ethereum-wallet-address-from-a-private-key-ae72b0eee27b/

为什么 secp256k1椭圆曲线失败?

// C#

// I am using HashLib
var ecdsaRaw = Ecdsa(Encoding.ASCII.GetBytes(privKey));
var ecdsaCombined = (BitConverter.ToString(ecdsaRaw.Item1) + BitConverter.ToString(ecdsaRaw.Item2)).Replace("-", "");
var finalResult = HashFactory.Crypto.SHA3.CreateKeccak256().ComputeString(ecdsaCombined, Encoding.ASCII).ToString().Replace("-", "");
var pubKey = "0x" + finalResult.Substring(finalResult.Length - 40, 40);
Console.WriteLine("ECDSA + Keccak256 : " + pubKey);

// Ecdsa Method 
public static Tuple<byte[], byte[]> Ecdsa(byte[] privateKey)
{
     var privKeyInt = new BigInteger(+1, privateKey);

     var parameters = SecNamedCurves.GetByName("secp256k1");
     var qa = parameters.G.Multiply(privKeyInt);

     var pubKeyX = qa.X.ToBigInteger().ToByteArrayUnsigned();
     var pubKeyY = qa.Y.ToBigInteger().ToByteArrayUnsigned();

     return Tuple.Create(pubKeyX, pubKeyY);
}

输出:

enter image description here

预期输出:

enter image description here

0 个答案:

没有答案