要首先生成一个新的
钱
包,我们需要导入
go -
eth
ereum
crypto
包,该包提供了
GenerateKey
生成随机
私
钥的方法。
privateKey, err := crypto.GenerateKey()if err != nil { log.Fatal(err)}
然后,我们可以通过导入
gola
ng
crypto/ecdsa
包并使用
FromECDSA
方法将其转换为字节。
privateKeyBytes := crypto.FromECDSA(privateKey)
现在,我们可以使用
go -
eth
ereum
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 -
eth
ereum加密软件包具有一种
PubkeyToAddress
接受ECDSA公共密钥并返回公共地址的方法。
address := crypto.PubkeyToAddress(*publicKeyECDSA).Hex()fmt.Println(address) // 0x96216849c49358B10257cb55b28eA603c874b05E
公用地址只是公用密钥的
Kecc
ak-256哈希,然后我们使用最后40个字符(20个字节)并为其加上前缀
0x
。这是使用
crypto/sha3
keccak256函数手动进行操作的方法。
hash := sha3.NewLegacyKeccak256()hash.Write(publicKeyBytes[1:])fmt.Println(hexutil.Encode(hash.Sum(nil)[12:])) // 0x96216849c49358b10257cb55b28ea603c874b05e
完整代码
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}