Go语言开发以太坊:生成新钱包

要首先生成一个新的包,我们需要导入go - ethereum crypto包,该包提供了GenerateKey生成随机的方法。

privateKey, err := crypto.GenerateKey()if err != nil {
  log.Fatal(err)}

然后,我们可以通过导入golang crypto/ecdsa包并使用FromECDSA方法将其转换为字节。

privateKeyBytes := crypto.FromECDSA(privateKey)

现在,我们可以使用go - ethereum hexutil程序包将其转换为十六进制字符串,该程序包提供Encode采用字节切片的方法。然后,我们将0x十六进制编码后的内容剥离掉。

fmt.Println(hexutil.Encode(privateKeyBytes)[2:]) // fad9c8855b740a0b7ed4c221dbad0f33a83a49cad6b3fe8d5817ac83d38b6a19

这是用于签署交易的,将其视为密码,并且永远不会被共享,因为拥有它的人将有权使用您的所有资金。

由于公钥是从派生的私 - 以太的加密拥有Public将返回公钥方法。

publicKey := privateKey.Public()

将其转换为十六进制与我们使用所经历的过程类似。我们去除了0x和前2个字符04,它们始终是EC前缀,不是必需的。

publicKeyECDSA, ok := publicKey.(*ecdsa.PublicKey)if !ok {
  log.Fatal("cannot assert type: publicKey is not of type *ecdsa.PublicKey")}publicKeyBytes := crypto.FromECDSAPub(publicKeyECDSA)fmt.Println(hexutil.Encode(publicKeyBytes)[4:]) // 9a7df67f79246283fdc93af76d4f8cdd62c4886e8cd870944e817dd0b97934fdd7719d0810951e03418205868a5c1b40b192451367f28e0088dd75e15de40c05

现在我们有了公共密钥,我们可以轻松生成您经常使用的公共地址。为了做到这一点,go - ethereum加密软件包具有一种PubkeyToAddress接受ECDSA公共密钥并返回公共地址的方法。

address := crypto.PubkeyToAddress(*publicKeyECDSA).Hex()fmt.Println(address) // 0x96216849c49358B10257cb55b28eA603c874b05E

公用地址只是公用密钥的Keccak-256哈希,然后我们使用最后40个字符(20个字节)并为其加上前缀0x。这是使用crypto/sha3keccak256函数手动进行操作的方法。

hash := sha3.NewLegacyKeccak256()hash.Write(publicKeyBytes[1:])fmt.Println(hexutil.Encode(hash.Sum(nil)[12:])) // 0x96216849c49358b10257cb55b28ea603c874b05e

完整代码

generate_wallet.go

package mainimport (    "crypto/ecdsa"
    "fmt"
    "log"
    "github.com/ethereum/go-ethereum/common/hexutil"
    "github.com/ethereum/go-ethereum/crypto"
    "golang.org/x/crypto/sha3")func main() {
    privateKey, err := crypto.GenerateKey()
    if err != nil {
        log.Fatal(err)
    }
    privateKeyBytes := crypto.FromECDSA(privateKey)
    fmt.Println(hexutil.Encode(privateKeyBytes)[2:]) // fad9c8855b740a0b7ed4c221dbad0f33a83a49cad6b3fe8d5817ac83d38b6a19
    publicKey := privateKey.Public()
    publicKeyECDSA, ok := publicKey.(*ecdsa.PublicKey)
    if !ok {
        log.Fatal("cannot assert type: publicKey is not of type *ecdsa.PublicKey")
    }
    publicKeyBytes := crypto.FromECDSAPub(publicKeyECDSA)
    fmt.Println(hexutil.Encode(publicKeyBytes)[4:]) // 9a7df67f79246283fdc93af76d4f8cdd62c4886e8cd870944e817dd0b97934fdd7719d0810951e03418205868a5c1b40b192451367f28e0088dd75e15de40c05
    address := crypto.PubkeyToAddress(*publicKeyECDSA).Hex()
    fmt.Println(address) // 0x96216849c49358B10257cb55b28eA603c874b05E
    hash := sha3.NewLegacyKeccak256()
    hash.Write(publicKeyBytes[1:])
    fmt.Println(hexutil.Encode(hash.Sum(nil)[12:])) // 0x96216849c49358b10257cb55b28ea603c874b05e}


链客

2019.11.26
11265
收藏

个评论:

发表评论

感谢您的善举,每一次解答会成为新人的灯塔。回答被采纳后获得20算力和相应LK币奖励。

关闭