知世金融网专注于股票行情,期货开户,外汇储备等最新相关资讯信息提供投资者参考学习!

当前位置:网站首页 > 区块链 > 正文

在go开发环境中进行密钥加载测试

原创
文章作者
知世-金融领域资深作者
知名金融领域作者,从事金融超过十余年,在行业内有一定影响力。
金融风险管理师认证证书 常识职业资格认证 特许金融分析师 国际金融理财师认证证书
发布时间:2020-02-16 18:31:36 发布来源:区块链研究实验室 文章点击:110

我正在发布我的“hacky”golang测试环境,该环境深入链接到go-ethereum代码库。 测试智能合约的一个重要部分是能够生成和使用任意数量的密钥/地址来签署/发送/接收交易。理想情况下,我...

目录

    本文标题在go开发环境中进行密钥加载测试,作者:知世,本文有709个文字,大小约为3KB,预计阅读时间2分钟,请您欣赏。知世金融网众多优秀文章,如果想要浏览更多相关文章,请使用网站导航的搜索进行搜索。本站虽然不乏优秀之作,但仅作为投资者学习参考。

    我正在发布我的“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)

    原作者:Dave Appleton

    本文相关推荐: EOS密钥被盗后怎么恢复的方式方法?

    以上便是知世金融网给大家分享的关于在go开发环境中进行密钥加载测试/qkl/27059.html的相关信息了,希望能帮助到大家,更多金融相关信息,敬请关注知世金融网!

    网站内容均来自互联网,如侵害您的利益联系客服进行删除!

    关键词:密钥
    (0)
    (0)

    上一篇:区块链安全入门笔记:越权访问攻击、女巫攻击、假错误通知攻击

    下一篇:美国经济趋于混乱,美股、黄金、biteb将走向“三角”关系

    本文标题:在go开发环境中进行密钥加载测试

    本文地址:/index.php?s=article&c=search&keyword=%E5%AF%86%E9%92%A5

    金融知名领域

    南方财富网 | 金融界 | 金融界 |

    更多推荐

    • 茅台吃饱,经销商哭倒
      茅台吃饱,经销商哭倒
    • 汇金的五次增持从短期看具有一定的“稳定器“作用,但从市场表现看效果逐次递减
      汇金的五次增持从短期看具有一定的“稳定器“作用,但从市场表现看效果逐次递减
    • 158亿元!比亚迪收购!
      158亿元!比亚迪收购!
    • 9月价格回落近五成 “冷静期”酒店业备战“十一”市场
      9月价格回落近五成 “冷静期”酒店业备战“十一”市场
    • 2023哈马博览会哈尔滨银行展区精彩纷呈
      2023哈马博览会哈尔滨银行展区精彩纷呈
    • 大额解禁撂倒股价 医疗影像龙头跌出千亿俱乐部 葛兰二季度大幅减仓
      大额解禁撂倒股价 医疗影像龙头跌出千亿俱乐部 葛兰二季度大幅减仓
    • A股,又上了热搜!数字要素概念走高多股涨停,锂电池板块走低恩捷股份大举跌停
      A股,又上了热搜!数字要素概念走高多股涨停,锂电池板块走低恩捷股份大举跌停
    • 最新!巨头出手,加仓宁王51%
      最新!巨头出手,加仓宁王51%
    • 600亿巨头暴雷
      600亿巨头暴雷
    • 一天32家!科创板回购潮涌来
      一天32家!科创板回购潮涌来
    • 提振信心实招来了!30余家上市公司密集出手 最高要买10亿
      提振信心实招来了!30余家上市公司密集出手 最高要买10亿
    • 高盛再发50年后预测:2075年印度股市全球市值占比将升4倍 中国升3成
      高盛再发50年后预测:2075年印度股市全球市值占比将升4倍 中国升3成

    新闻资讯栏目

    站长QQ: 2397470084