使用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()
相关推荐
程序炼丹师8 分钟前
CMakeLists中 get_filename_component详解
开发语言
꧁Q༒ོγ꧂32 分钟前
C++ 入门完全指南(四)--函数与模块化编程
开发语言·c++
且去填词39 分钟前
DeepSeek API 深度解析:从流式输出、Function Calling 到构建拥有“手脚”的 AI 应用
人工智能·python·语言模型·llm·agent·deepseek
listhi5201 小时前
对LeNet-5的matlab实现,识别MINST手写数字集
开发语言·matlab
电报号dapp1191 小时前
钱包开发:在虚无中为数字自我筑巢
游戏·去中心化·区块链·智能合约
qq_433554541 小时前
C++ manacher(求解回文串问题)
开发语言·c++·算法
csbysj20201 小时前
Chart.js 饼图:全面解析与实例教程
开发语言
rgeshfgreh1 小时前
Python条件与循环实战指南
python
rgeshfgreh1 小时前
通达信LC1文件结构解析指南
python
浩瀚地学1 小时前
【Java】常用API(二)
java·开发语言·经验分享·笔记·学习