博客
关于我
Zcash中的key aggrement
阅读量:283 次
发布时间:2019-03-01

本文共 1133 字,大约阅读时间需要 3 分钟。

引言

所谓Key Agreement Scheme(KA Scheme),是密码学协议中的一个重要概念。它描述了双方通过各自的私钥和对方的公钥来达成共享秘密的过程。在这个协议中,私钥公钥是如何生成的,以及如何确保共享秘密的安全性,是KA Scheme的核心问题。

在KA Scheme中,公钥通常表示为K.A.Public,而私钥则表示为K.A.Private。共享秘密K.A.SharedSecret是通过这两个密钥生成的。具体来说,K.A.DerivePublic函数将私钥K.A.Private与公钥K.A.Public相乘,生成K.A.Public。而K.A.Agree函数则将私钥K.A.Private与公钥K.A.Public相乘,生成K.A.SharedSecret

需要注意的是,K.A.DerivePublic生成的结果可能是一个K.A.Public的严格子集,这意味着它可能不包含所有可能的公钥。因此,在实际应用中,必须确保生成的私钥具有足够的熵,以确保K.A.Private的安全性。

安全要求

为了确保KA Scheme的安全性,K.A.FormatPrivate函数必须从输入中提取足够的熵,以生成一个安全的私钥K.A.Private。此外,接下来的章节将介绍Key Derivation Function(KDF),特别是Sapling版本的KDF,它需要满足类似的安全假设。

Key Derivation Function(KDF)

**Key Derivation Function(KDF)**是一种特殊的密钥协议和一次性对称加密方案。它的输入包括:

  • 由KA Scheme生成的共享秘密sharedSecret
  • 其他参数,如密钥扩展的基数等。
  • KDF的输出是一个适用于加密方案的密钥。在Sapling版本的KDF中,输入包括共享秘密sharedSecret和临时公钥epk,输出则是一个适用于对称加密方案的密钥。

    Sapling Key Agreement的具体实现

    Sapling Key Agreement(KA^{Sapling})的实现过程如图1所示。它通过将私钥K.A.Private与共享秘密K.A.SharedSecret结合,生成一个新的密钥用于加密数据。

    Sapling Key Derivation的具体实现

    Sapling Key Derivation(KDF^{Sapling})的实现过程如图2所示。它通过将共享秘密K.A.SharedSecret与临时公钥epk结合,并扩展基数B^{Y^{[l_j/8]}},生成一个适用于对称加密的密钥。

    参考资料

    [1] 详细内容可参考相关技术文档和博客文章。

    转载地址:http://fkqx.baihongyu.com/

    你可能感兴趣的文章
    pc3-12800
    查看>>
    PCA---主成成分分析
    查看>>
    PCA和自动编码器:每个人都能理解的算法
    查看>>
    pca算法
    查看>>
    PCA降维demo
    查看>>
    SharePoint 2013 图文开发系列之定义站点模板
    查看>>
    PCB生产流程详解-ChatGPT4o作答
    查看>>
    PCB设计十条黄金法则
    查看>>
    SpringSecurity框架介绍
    查看>>
    PCI Express学习篇:Power Management(二)
    查看>>
    pcie握手机制_【博文连载】PCIe扫盲——Ack/Nak 机制详解(一)
    查看>>
    pcm转wav的方法及代码示例
    查看>>
    PC史上最悲剧的16次失败
    查看>>
    PC端恶意代码分析Lab1.1-5.1,从零基础到精通,收藏这篇就够了!
    查看>>
    PC端稳定性测试探索
    查看>>
    PC端编辑 但能在PC端模拟移动端预览的富文本编辑器
    查看>>
    PDB文件:每个开发人员都必须知道的
    查看>>
    springMVC学习(二)
    查看>>
    Pdfkit页眉和页脚
    查看>>
    PDF中的Pandoc语法突出显示不起作用
    查看>>