繁体   English   中英

矿工如何隐藏区块链密钥对私钥?它们是如何首先生成的?

[英]How are blockchain keypair private keys hidden from miners, and how are they generated in the first place?

我不知道如何以编程方式生成区块链密钥对,并且同样重要-它们如何能够使用远程服务器的私钥来验证其密钥对-同时保持其私钥完全私有。

如何生成区块链密钥对,并通过能够通过某种签名对您的帐户进行身份验证的远程服务器隐藏私钥?

公钥是随机散列,私钥是作为公钥父项的散列吗? 如果没有,怎么办? 以及它们如何隐藏在目标网络中?

我在IDE中使用加密引用,但不确定如何在区块链网络中有效利用它们。

Private Declare Sub MD5Init Lib "cryptdll" (Context As MD5_CTX)
Private Declare Sub MD5Update Lib "cryptdll" (Context As MD5_CTX, ByVal strInput As String, ByVal lLen As Long)
Private Declare Sub MD5Final Lib "cryptdll" (Context As MD5_CTX)

Private Function CalcMD5(sEncryptString As String) As String
    Dim strBuffer As String
    Dim myContext As MD5_CTX
    Dim result As String
    Dim lp As Long
    Dim MD5 As String

    strBuffer = sEncryptString

    MD5Init myContext
    MD5Update myContext, strBuffer, Len(strBuffer)
    MD5Final myContext

    result = StrConv(myContext.digest, vbUnicode)

    For lp = 1 To Len(result)
        CalcMD5 = CalcMD5 & Right("00" & Hex(Asc(Mid(result, lp, 1))), 2)
    Next

End Function

是的,那是VB Classic。 我老了,让我休息一下。

我本来希望了解密钥对,但实际上我不知道它们在整个过程中如何工作。

在比特币中,私钥是(或应该)由您的钱包软件随机生成的,理想情况下,由于使用大量的熵,它可以脱机。

比特币中使用的加密是椭圆曲线,特别是secp256k1曲线。 是非对称/公钥加密的一种形式,其中私钥是非常大的集合中的任何有效值(难以理解的大,如10 ^ 70),并且可以通过将私钥乘以曲线的生成点来确定性地计算公钥。用椭圆曲线点乘法

私钥用于签署交易(私钥从不离开钱包软件,并且不与任何人(包括节点)共享)。 该签名算法被称为椭圆曲线数字签名算法(ECDSA) 可以使用数据本身和公共密钥来验证数据的签名。 如果签名验证算法成功,则可以推断出实际上与公钥相对应的私钥已用于签名数据,证明私钥的所有者产生了签名。 这在比特币中很重要,因为它授权硬币的所有者使用它们。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM