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

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

1. 引言

所谓key agreement scheme K A KA KA,是指密码学协议中的双方agree a shared secret,每一方都使用 己方的private key和对方的public key。

key agreement scheme K A KA KA,其public key表示为 K A . P u b l i c KA.Public KA.Public,private key表示为 K A . P r i v a t e KA.Private KA.Private,shared secrets表示为 K A . S h a r e d S e c r e t KA.SharedSecret KA.SharedSecret

  • K A . D e r i v e P u b l i c : K A . P r i v a t e × K A . P u b l i c → K A . P u b l i c KA.DerivePublic: KA.Private\times KA.Public\rightarrow KA.Public KA.DerivePublic:KA.Private×KA.PublicKA.Public,为根据指定的KA private key和base point生成相应KA public key。

  • K A . A g r e e : K A . P r i v a t e × K A . P u b l i c → K A . S h a r e d S e c r e t KA.Agree: KA.Private\times KA.Public\rightarrow KA.SharedSecret KA.Agree:KA.Private×KA.PublicKA.SharedSecret,为the agreement function。

注意:

The range of K A . D e r i v e P u b l i c KA.DerivePublic KA.DerivePublic may be a strict subset of K A . P u b l i c KA.Public KA.Public

安全要求:

  • K A . F o r m a t P r i v a t e KA.FormatPrivate KA.FormatPrivate 必须从输入中保留足够的熵才能用作安全的 KA private key。
  • 下节介绍的key agreement 和 KDF (Key Derivation Function) 均必须满足类似 或 中的suitable adaptive security assumption。

2. Key Derivation

KDF (Key Derivation Function) 为一种特殊的key agreement scheme 和 authenticated one-time symmetric encryption scheme,其输入为:

  • 由key agreement输出的shared secret;
  • 其它参数。

其输出为:

  • a key suitable for the encryption scheme。

实际实现时,Sapling中的 K D F S a p l i n g KDF^{Sapling} KDFSapling的输入为:

  • the shared Diffie-Hellman secret s h a r e d S e c r e t sharedSecret sharedSecret
  • the ephermeral public key e p k epk epk

K D F S a p l i n g KDF^{Sapling} KDFSapling的输出为:

  • key for S y m . E n c r y p t Sym.Encrypt Sym.Encrypt

K D F S a p l i n g : K A S a p l i n g . S h a r e d S e c r e t × B Y [ l j / 8 ] → S y m . K KDF^{Sapling}: KA^{Sapling}.SharedSecret\times\mathbb{B}^{\mathbb{Y}^{[l_j/8]}}\rightarrow Sym.\mathbf{K} KDFSapling:KASapling.SharedSecret×BY[lj/8]Sym.K

【Shielded payment address 中包含的transmission key p k d pk_d pkd 可用于 a “key-private” asymmetric encryption scheme。所谓"key-private"是指,ciphertexts中不会泄露其加密key的信息,只对拥有加密key对应private key(此处也可称为receiving key)的一方可见。该机制主要用于communicate encrypted output notes on the block chain to their intended recipient,拥有receiving key的一方可扫描区块链来获取notes addressed to them 并 decrypt those notes。】

详细见博客 ,其中的基于 p k d pk_d pkd实现的asymmetric encrytion(输出为 C e n c C^{enc} Cenc)的构建过程中用到的 K A S a p l i n g 、 K D F S a p l i n g 和 S y m KA^{Sapling}、KDF^{Sapling}和Sym KASaplingKDFSaplingSym 都要求为 IND-CCA2-secure 和 key-private 的。

Key privacy的定义参见 。

3. Sapling key agreement 具体实现

Sapling key agreement K A S a p l i n g KA^{Sapling} KASapling 的具体实现为:

在这里插入图片描述

4. Sapling key derivation 具体实现

Sapling key derivation K D F S a p l i n g KDF^{Sapling} KDFSapling 的具体实现为:

在这里插入图片描述

参考资料

[1]

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

你可能感兴趣的文章
Node-RED中使用node-red-contrib-image-output节点实现图片预览
查看>>
Node-RED中使用node-red-node-ui-iframe节点实现内嵌iframe访问其他网站的效果
查看>>
Node-RED中使用Notification元件显示警告讯息框(温度过高提示)
查看>>
Node-RED中使用range范围节点实现从一个范围对应至另一个范围
查看>>
Node-RED中实现HTML表单提交和获取提交的内容
查看>>
Node-RED中将CSV数据写入txt文件并从文件中读取解析数据
查看>>
Node-RED中建立TCP服务端和客户端
查看>>
Node-RED中建立Websocket客户端连接
查看>>
Node-RED中建立静态网页和动态网页内容
查看>>
Vue3+Element-ul学生管理系统(第二十二课)
查看>>
Node-RED中根据HTML文件建立Web网站
查看>>
Node-RED中解析高德地图天气api的json数据显示天气仪表盘
查看>>
Node-RED中连接Mysql数据库并实现增删改查的操作
查看>>
Node-RED中通过node-red-ui-webcam节点实现访问摄像头并截取照片预览
查看>>
Node-RED中配置周期性执行、指定时间阶段执行、指定时间执行事件
查看>>
Node-RED安装图形化节点dashboard实现订阅mqtt主题并在仪表盘中显示温度
查看>>
Node-RED怎样导出导入流程为json文件
查看>>
Node-RED订阅MQTT主题并调试数据
查看>>
Node-RED通过npm安装的方式对应卸载
查看>>
node-request模块
查看>>