如何利用gethcrypto模块进行密钥加载测试

我正在发布我的“hacky”golang     测试   环境,该环境深入链接到go-ethereum代码库。

测试智能合约的一个重要部分是能够生成和使用任意数量的密钥/地址来签署/发送/接收交易。理想情况下,我们不应该使用实时密钥对,因此我创建了可以在https://github.com/DaveAppleton/memorykeys找到的内存密钥。

 如何利用gethcrypto模块进行密钥加载测试_设计制作_接口/总线/驱动

geth crypto模块的大部分工作是     包装   go crypto/ecdsa库。ECDSA代表椭圆曲线数字签名算法。GETH的加密库的工作是选择正确的参数来输入go的ecdsa库。例如,创建一个密钥只需调用GETH / crypto的Genera     te   Key函数,然后只选择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 := F     rom   ECDSAPub(&p)

return common.BytesToAddress(Keccak256(pubBytes[1:])[12:])

}

其中,FromECDSAPUB()提取公钥。

你会发现慢慢探索Geth的密码库可以让非密码学家(像我一样)对正在发生的事情有一点了解,而不会让你的大脑超载。

库的目标

这个库旨在帮助我们在特定的基础上生成和使用密钥,而不将它们     存储   起来以便在以后的运行中重用。

我们通过名字引用这些密钥并获得:

1. 私钥(用于签名)

2. 封装该密钥的事务对象,以供将来与ABIGEN一起使用

3. 地址

限制

由于不需要同时创建密钥,因此密钥存储在对并发写入不安全的映射中。

函数

getprivatekey(keyname)在第一次调用时创建与名称关联的密钥对,后续调用返回上一个值。

launcher,err := memorykeys.GetPrivateKey(“launcher”)

getaddress(keyname string)获取与键关联的地址。如果密钥不存在,则创建该密钥

reci     pi   ent,err := GetAddress(“recipient”)

GetTransactor(keyName string)获取一个用于ABIGEN对象的事务对象。 必要时创建密钥。

deployer, err := GetTransactor(“deployer”)

importprivatekey(keyname,hex key)导入十六进制编码的私钥以供使用。小心不要使用生产密钥

privateKey := “d31a46c5322e8e8a7e11f51cf9c4073fea42d33b431b5e7e76a82518fc178ea8”

key, err := ImportPrivateKey(“imported”, privateKey)

0
8
0
86

相关资讯

  1. 1、花滑王子羽生结玄谈为何客串电影一切都是为了更好的滑冰2777
  2. 2、《制服》广州宣传颖儿:最想演变态女杀手2203
  3. 3、《声动》踢馆赛一触即发8强或将遭遇大洗牌1957
  4. 4、甘比500平豪宅首露真容,看到这个后网友感叹:有钱人真痛苦!62
  5. 5、前TVB小花结束8年长跑升级万能人妻晒海底照自嘲十足洋葱头3102
  6. 6、电影《五个姐姐》曝定档海报预告小姐姐集结疯狂“虐”弟1008
  7. 7、林心如的“丫鬟”都火了,杨幂、范冰冰上榜,吴谨言还差一口气2675
  8. 8、首支预告就搞事情!电影《爱情公寓》这次要玩票大的4232
  9. 9、《第十一回》中奖名单来啦|开奖3741
  10. 10、《速激7》或推迟导演:改剧本不会亵渎保罗3524
全部评论(0)
我也有话说
0
收藏
点赞
顶部