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

    你可能感兴趣的文章
    OpenCV与AI深度学习 | 使用PyTorch进行小样本学习的图像分类
    查看>>
    OpenCV与AI深度学习 | 使用YOLO11实现区域内目标跟踪
    查看>>
    OpenCV与AI深度学习 | 使用YOLOv8做目标检测、实例分割和图像分类(包含实例操作代码)
    查看>>
    OpenCV与AI深度学习 | 使用单相机对已知物体进行3D位置估计
    查看>>
    OpenCV与AI深度学习 | 初学者指南 -- 什么是迁移学习?
    查看>>
    OpenCV与AI深度学习 | 十分钟掌握Pytorch搭建神经网络的流程
    查看>>
    OpenCV与AI深度学习 | 基于GAN的零缺陷样本产品表面缺陷检测
    查看>>
    OpenCV与AI深度学习 | 基于OpenCV和深度学习预测年龄和性别
    查看>>
    OpenCV与AI深度学习 | 基于OpenCV实现模糊检测 / 自动对焦
    查看>>
    OpenCV与AI深度学习 | 基于Python和OpenCV将图像转为ASCII艺术效果
    查看>>
    OpenCV与AI深度学习 | 基于PyTorch实现Faster RCNN目标检测
    查看>>
    OpenCV与AI深度学习 | 基于PyTorch语义分割实现洪水识别(数据集 + 源码)
    查看>>
    OpenCV与AI深度学习 | 基于YOLO11的车体部件检测与分割
    查看>>
    OpenCV与AI深度学习 | 基于YoloV11自定义数据集实现车辆事故检测(有源码,建议收藏!)
    查看>>
    OpenCV与AI深度学习 | 基于YOLOv8 + BotSORT实现球员和足球检测与跟踪 (步骤 + 源码)
    查看>>
    OpenCV与AI深度学习 | 基于YOLOv8实现高级目标检测和区域计数
    查看>>
    VS2003 Front Page Server Extension
    查看>>
    OpenCV与AI深度学习 | 基于YOLOv8的停车对齐检测
    查看>>
    OpenCV与AI深度学习 | 基于YoloV8的药丸/片剂类型识别
    查看>>
    OpenCV与AI深度学习 | 基于YOLO和EasyOCR从视频中识别车牌
    查看>>