零知识证明以及其在 BSV 区块链中的应用简介

在通过一个例子介绍了零知识证明 (ZKP) 之后,我们展示了如何将它用作一个强大的工具来增加隐私并进一步开发许多构建在上面的应用程序。

零知识证明

零知识证明允许声称知道秘密的一方(即证明者)说服另一方(即验证者)该声明是有效的,同时不泄露秘密。

Waldo 在哪裡?

寻找 Waldo 是一款游戏,您必须在与他相似的人海中找到 Waldo。

在这里插入图片描述

Peggy(证明者)告诉 Victor(验证者)她知道 Waldo 在场景中的位置,但她不想向他展示他的确切位置。那么,她如何向他证明她找到了 Waldo 而不显示他的确切位置?

Peggy 找到了一大块硬纸板,在中间挖了一个 Waldo 形状的洞。

在这里插入图片描述

然后,她将 Waldo 的位置(在一张纸上)用胶带粘在纸板的背面,这样 Waldo 就在占据中心的 Waldo 形状的洞。当 Peggy 用胶带粘好纸板时,Victor 应该站在纸板前。

在这里插入图片描述

当 Victor 从洞里看到 Waldo 时,他确信 Peggy 的说法是有效的,但他不知道 Waldo 的确切位置

在这里插入图片描述

在 BSV 区块链中的应用

由于零知识证明的隐藏特性,它可以在需要隐私的许多情况下使用。更重要的是,它也可以作为构建更复杂协议的基础,如下所示。

通过加密和交换的托管1

Alice 想用比特币支付 Bob 购买商品。Alice 和 Bob 分别生成随机私钥 a/b, 对应公钥 A/B。Alice 在托管人的公钥 E 下加密她的私钥 a 并将密文 c = Enc(a, E) 发送给 Bob。她还向 Bob 发送了一个零知识证明,证明 c 确实是 a 通过 E 加密的。反之亦然,Bob 做同样的事情。

  1. 然后,Alice 将资金发送到共享公钥 S = A+B,以支付商品。在没有争议的情况下,Alice 发送 a 给 Bob,Bob 可以转移资金。
  2. 在存在争议的情况下,托管人会选择获胜者。如果获胜者是 Bob,他将 c 发送到托管。托管人解密 c 以获得 a 并将其发送回 Bob,后者可以赎回资金。同样,如果 Alice 是赢家,她可以拿走这笔资金。

与传统的 2-of-3 多重签名托管相比,有几个优点:

  1. 资金被锁定在一个普通的比特币 P2PKH 地址中。只有相关方知道涉及托管,从而增加隐私。
  2. 在没有争议的情况下,托管人不必参与存款或取款,从而有可能降低其运营成本。

我们已经实现了完整的协议,下面列出了代码的零知识证明部分。


const encryptionResultA = ve.encrypt(ucPubKeyEscrow, privKeyA.toBuffer());

const proofA = ve.prove(ucPubKeyEscrow, encryptionResultA);
// zero knowledge proof: Bob can verify if encryptionResultA is encrypted privKeyA (without knowing it) 
// with ucPubKeyEscrow, whose corresponding public key is ucPubKeyA
const isVerifiedA = ve.verify(proofA, ucPubKeyEscrow, ucPubKeyA, encryptionResultA.ciphertexts);
assert(isVerifiedA);

gist escrow_zkp.js

脚注


[1]: Escrow Protocols for Cryptocurrencies: How to Buy Physical Goods Using Bitcoin. Steven Goldfeder, 2017

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

sCrypt Web3应用开发

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值