我正在发布我的“hacky”golang测试环境,该环境深入链接到go-ethereum代码库。
测试智能合约的一个重要部分是能够生成和使用任意数量的密钥/地址来签署/发送/接收交易。理想情况下,我们不应该使用实时密钥对,因此我创建了可以在https://github.com/DaveAppleton/memorykeys找到的内存密钥。
geth crypto模块的大部分工作是包装go crypto/ecdsa库。ECDSA代表椭圆曲线数字签名算法。GETH的加密库的工作是选择正确的参数来输入go的ecdsa库。例如,创建一个密钥只需调用GETH / crypto的GenerateKey函数,然后只选择go的crypto / ecdsa模块的参数。 geth的实现方式如下:
func GenerateKey() (*ecdsa.PrivateKey, error) {
return ecdsa.GenerateKey(S256(), rand.Reader)
}
s256()是一个返回用于加密的椭圆曲线的函数,另一个参数是提供一个好的随机数生成器,以确保您的私钥不可猜测。有趣的是,geth链接到曲线的两个不同版本,一个版本使用与机器相关的调用来提高性能,另一个版本则完全用go编写以实现可移植性。
ECDSA模块向我们返回公钥,但大多数时候我们希望以太坊地址不是公钥。Geth的加密库再次为我们实现了这一点。
func PubkeyToAddress(p ecdsa.PublicKey) common.Address {
pubBytes := FromECDSAPub(&p)
return common.BytesToAddress(Keccak256(pubBytes[1:])[12:])
}
其中,FromECDSAPUB()提取公钥。
你会发现慢慢探索Geth的密码库可以让非密码学家(像我一样)对正在发生的事情有一点了解,而不会让你的大脑超载。
库的目标
这个库旨在帮助我们在特定的基础上生成和使用密钥,而不将它们存储起来以便在以后的运行中重用。
我们通过名字引用这些密钥并获得:
1. 私钥(用于签名)
2. 封装该密钥的事务对象,以供将来与ABIGEN一起使用
3. 地址
限制
由于不需要同时创建密钥,因此密钥存储在对并发写入不安全的映射中。
函数
getprivatekey(keyname)在第一次调用时创建与名称关联的密钥对,后续调用返回上一个值。
launcher,err := memorykeys.GetPrivateKey(“launcher”)
getaddress(keyname string)获取与键关联的地址。如果密钥不存在,则创建该密钥
recipient,err := GetAddress(“recipient”)
GetTransactor(keyName string)获取一个用于ABIGEN对象的事务对象。 必要时创建密钥。
deployer, err := GetTransactor(“deployer”)
importprivatekey(keyname,hex key)导入十六进制编码的私钥以供使用。小心不要使用生产密钥
privateKey := “d31a46c5322e8e8a7e11f51cf9c4073fea42d33b431b5e7e76a82518fc178ea8”
key, err := ImportPrivateKey(“imported”, privateKey)
相关热词:#区块链
为什么需要MOSFET栅极电阻?MOSFET栅极电阻...
时间:2026-03-05
NTC/PTC/CTR热敏电阻是什么?热敏电阻的使用...
时间:2026-03-05
解析单电阻采样的原理以及注意点
时间:2026-03-05
共源极放大器的设计方法
时间:2026-03-05
关于STM32WL LSE 添加反馈电阻后无法起振的...
时间:2026-03-05
如何直观地判断两级放大器的零点位置呢?
时间:2026-03-05
时序分析基本概念介绍<wire load model&...
时间:2026-03-05
电子元器件解析—电阻
时间:2026-03-05
3PEAK高压零漂放大器契合精密应用
时间:2026-03-05
助力绿色5G数字式电流和功率监测芯片-TPA62...
时间:2026-03-05
未来什么技术占主流?会是区块链吗?
时间:2026-03-05
浅谈区块链下的智能合约
时间:2026-03-05
浅显易懂地揭开.Net生态系统的神秘面纱!
时间:2026-03-05
对技术的执着和美的追求变成了程序员的“诗...
时间:2026-03-05
什么是区块链技术_区块链技术解析
时间:2026-03-05
脑洞大开:玻璃窗也能发电?
时间:2026-03-05
如何布置无人值守变电站?
时间:2026-03-05
SCADA系统懂多少?
时间:2026-03-05
灰尘对光伏电站效率影响究竟多大
时间:2026-03-05
一种基于Agent的智能电网集成优化控制策略
时间:2026-03-05