生成新钱包

package main

import (
    "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
}

要生成新的钱包,首先我们需要导入提供生成随机私钥的方法的go - ethereum 包。cryptoGenerateKey

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

这是用于签署交易的私钥,应像密码一样对待,不得共享,因为拥有它的人就可以访问您的所有资金。

由于公钥是从私钥派生出来的,因此go - ethereum的加密私钥有一个Public方法可以返回公钥。

publicKey := privateKey.Public()

将其转换为十六进制的过程与我们对私钥进行的操作类似。我们删除0x前 2 个字符,04这 2 个字符始终是 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 crypto 包有一个PubkeyToAddress方法,它接受 ECDSA 公钥并返回公共地址。

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

公共地址只是公钥的Keccak-2560x哈希,然后我们取最后 40 个字符(20 个字节)并在其前面加上前缀。以下是使用crypto/sha3keccak256 函数手动执行此操作的方法。

hash := sha3.NewLegacyKeccak256()
hash.Write(publicKeyBytes[1:])
fmt.Println(hexutil.Encode(hash.Sum(nil)[12:])) // 0x96216849c49358b10257cb55b28ea603c874b05e
  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要实现根据邮箱生成钱包地址并储存私钥,可以使用Java中的Bouncy Castle加密库和BitcoinJ库。 首先,需要将用户的邮箱地址作为输入,并使用Bouncy Castle库中的SHA256哈希算法生成一个哈希值。然后,将哈希值与一个常量字符串连接起来,再次进行SHA256哈希得到一个最终的哈希值。 接下来,使用BitcoinJ库中的ECKey生成器来生成公钥和私钥对。公钥可以通过ECKey对象的getPublicKeyAsHex()方法获取,私钥可以通过ECKey对象的getPrivateKeyEncoded()方法获取。 最后,将公钥转换为钱包地址并将私钥储存在安全的地方,例如加密的本地文件或数据库中。 以下是一个简单的Java代码示例来实现上述过程: ```java import org.bouncycastle.crypto.digests.SHA256Digest; import org.bitcoinj.core.*; import org.bitcoinj.crypto.ECKey; import org.bitcoinj.params.MainNetParams; import java.math.BigInteger; import java.nio.charset.StandardCharsets; public class WalletGenerator { private static final String CONSTANT = "myconstantstring"; public static void main(String[] args) { String email = "example@example.com"; Address address = generateAddressFromEmail(email); System.out.println("Generated address: " + address.toString()); } private static Address generateAddressFromEmail(String email) { byte[] emailBytes = email.getBytes(StandardCharsets.UTF_8); byte[] hash = new byte[32]; SHA256Digest sha256 = new SHA256Digest(); sha256.update(emailBytes, 0, emailBytes.length); sha256.doFinal(hash, 0); sha256.update(hash, 0, hash.length); sha256.update(CONSTANT.getBytes(StandardCharsets.UTF_8), 0, CONSTANT.getBytes(StandardCharsets.UTF_8).length); sha256.doFinal(hash, 0); BigInteger privateKey = new BigInteger(hash); ECKey key = ECKey.fromPrivate(privateKey); Address address = LegacyAddress.fromKey(MainNetParams.get(), key); // Save private key to secure location return address; } } ``` 请注意,此代码示例仅用于演示目的。在实际应用中,需要使用更加安全的方式来储存私钥和生成钱包地址,例如使用硬件钱包或将私钥加密并储存在安全的服务器上。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值