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

python 复制代码
# 单次运行
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()
相关推荐
渔舟小调5 分钟前
P19 | 前端加密通信层 pikachuNetwork.js 完整实现
开发语言·前端·javascript
不爱吃炸鸡柳7 分钟前
数据结构精讲:树 → 二叉树 → 堆 从入门到实战
开发语言·数据结构
网络安全许木7 分钟前
自学渗透测试第21天(基础命令复盘与DVWA熟悉)
开发语言·网络安全·渗透测试·php
t***54412 分钟前
如何在Dev-C++中使用Clang编译器
开发语言·c++
qq_6543669815 分钟前
CSS如何处理@import样式表的嵌套加载_评估递归对加载的影响
jvm·数据库·python
weixin_3812881816 分钟前
苹果微软双修党福音:Navicat如何跨系统平滑迁移配置
jvm·数据库·python
xcbrand17 分钟前
政府事业机构品牌策划公司找哪家
大数据·人工智能·python
码界筑梦坊22 分钟前
93-基于Python的中药药材数据可视化分析系统
开发语言·python·信息可视化
阿荻在肝了25 分钟前
Agent学习六:LangGraph学习-持久化与记忆一
python·学习·agent
qingyulee25 分钟前
python多进程、线程、协程
python