使用Python语言生成区块链地址

文章详细介绍了如何使用Python的ecdsa库生成以太坊账户地址,包括私钥的生成、公钥获取,以及通过Keccak-256哈希和取特定字符来创建地址的过程。还展示了如何通过循环生成多组地址并保存到文本文件中。
摘要由CSDN通过智能技术生成
# 单次运行
import binascii
import sha3
from ecdsa import SigningKey, SECP256k1
 
 
priv = SigningKey.generate(curve=SECP256k1)  # 生成私钥
pub = priv.get_verifying_key()  # 生成公钥
 
keccak = sha3.keccak_256()
keccak.update(pub.to_string())  # keccak_256哈希运算
address = "0x" + keccak.hexdigest()[24:]
 
priv_key = binascii.hexlify(priv.to_string())
pub_key = binascii.hexlify(pub.to_string())
 
print("Private key: " + priv_key.decode())
print("Public key:  " + pub_key.decode())
print("Address:     " + address)
 
 
# 生成的以太坊生成账户地址是 私钥 -> 公钥 ->账户地址,
# 以太坊账户地址使用Secp256k1椭圆曲线得到私钥、公钥,得到公钥后,
# 对公钥做Keccak-256哈希运算,然后取最后的40位16进制字符,
# 得到的就是以太坊账户地址。


# 使用循环进行生成然后写入文本保存
import binascii
import sha3
from ecdsa import SigningKey, SECP256k1

for i in range(1,2):
    priv = SigningKey.generate(curve=SECP256k1)  # 生成私钥
    pub = priv.get_verifying_key()  # 生成公钥

    keccak = sha3.keccak_256()
    keccak.update(pub.to_string())  # keccak_256哈希运算
    address = "0x" + keccak.hexdigest()[24:]

    priv_key = binascii.hexlify(priv.to_string())
    pub_key = binascii.hexlify(pub.to_string())

    f = open('address.txt', 'a+', encoding='utf-8')
    Private_key = ('Private key: ' + priv_key.decode() + '\n')
    Pub_key = ("Public key:  " + pub_key.decode() + '\n')
    Produce_Address = ("Address:     " + address + '\n'+'\n'+'\n')
    f.write(Private_key + Pub_key + Produce_Address)
    f.close()

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

南城猿

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值