使用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()
相关推荐
专注VB编程开发20年32 分钟前
javascript的类,ES6模块写法在VSCODE中智能提示
开发语言·javascript·vscode
TechubNews2 小时前
东方之珠·数链未来:香港回归28周年RWA革命赋能全球金融
区块链·稳定币
郭庆汝5 小时前
pytorch、torchvision与python版本对应关系
人工智能·pytorch·python
黄雪超8 小时前
JVM——函数式语法糖:如何使用Function、Stream来编写函数式程序?
java·开发语言·jvm
ThetaarSofVenice8 小时前
对象的finalization机制Test
java·开发语言·jvm
思则变8 小时前
[Pytest] [Part 2]增加 log功能
开发语言·python·pytest
lijingguang8 小时前
在C#中根据URL下载文件并保存到本地,可以使用以下方法(推荐使用现代异步方式)
开发语言·c#
漫谈网络9 小时前
WebSocket 在前后端的完整使用流程
javascript·python·websocket
¥-oriented9 小时前
【C#中路径相关的概念】
开发语言·c#
CoderCodingNo9 小时前
【GESP】C++四级考试大纲知识点梳理, (7) 排序算法基本概念
开发语言·c++·排序算法