博客
关于我
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/

    你可能感兴趣的文章
    npm切换到淘宝源
    查看>>
    npm切换源淘宝源的两种方法
    查看>>
    npm前端包管理工具简介---npm工作笔记001
    查看>>
    npm包管理深度探索:从基础到进阶全面教程!
    查看>>
    npm升级以及使用淘宝npm镜像
    查看>>
    npm发布包--所遇到的问题
    查看>>
    npm发布自己的组件UI包(详细步骤,图文并茂)
    查看>>
    npm和package.json那些不为常人所知的小秘密
    查看>>
    npm和yarn清理缓存命令
    查看>>
    npm和yarn的使用对比
    查看>>
    npm如何清空缓存并重新打包?
    查看>>
    npm学习(十一)之package-lock.json
    查看>>
    npm安装 出现 npm ERR! code ETIMEDOUT npm ERR! syscall connect npm ERR! errno ETIMEDOUT npm ERR! 解决方法
    查看>>
    npm安装crypto-js 如何安装crypto-js, python爬虫安装加解密插件 找不到模块crypto-js python报错解决丢失crypto-js模块
    查看>>
    npm安装教程
    查看>>
    npm报错Cannot find module ‘webpack‘ Require stack
    查看>>
    npm报错Failed at the node-sass@4.14.1 postinstall script
    查看>>
    npm报错fatal: Could not read from remote repository
    查看>>
    npm报错File to import not found or unreadable: @/assets/styles/global.scss.
    查看>>
    npm报错TypeError: this.getOptions is not a function
    查看>>