使用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()
相关推荐
心扬几秒前
python网络编程
开发语言·网络·python·tcp/ip
忧陌6064 分钟前
DAY 44 预训练模型
python
qq_454175798 分钟前
c++学习-this指针
开发语言·c++·学习
点云SLAM20 分钟前
PyTorch 中contiguous函数使用详解和代码演示
人工智能·pytorch·python·3d深度学习·contiguous函数·张量内存布局优化·张量操作
尘浮72834 分钟前
60天python训练计划----day45
开发语言·python
sss191s39 分钟前
校招 java 面试基础题目及解析
java·开发语言·面试
哆啦A梦的口袋呀1 小时前
基于Python学习《Head First设计模式》第六章 命令模式
python·学习·设计模式
努力搬砖的咸鱼1 小时前
从零开始搭建 Pytest 测试框架(Python 3.8 + PyCharm 版)
python·pycharm·pytest
Calvex1 小时前
PyCharm集成Conda环境
python·pycharm·conda
一千柯橘1 小时前
python 项目搭建(类比 node 来学习)
python