分布式密钥生成

可验证且无经销商

分布式密钥生成 (DKG) 是一种加密协议,使多方能够协作生成共享密钥,而无需任何一方完全了解密钥。 它通过在多个参与者之间分配信任来增强各种应用程序的安全性,从而降低密钥泄露的风险。 我们引入了一种可验证且无经销商的 DKG,适合在区块链中使用。

Shamir 密钥共享(SSS)

Shamir的密钥共享 (SSS) 是一种密码学方法,允许将密钥分为多个部分,每个参与者都持有一部分密钥,称为共享。 SSS 的关键特征是,只有当预定义数量的共享(称为阈值)组合在一起时才能重建密钥。 它是一个阈值方案,表示为 (t,n),其中 n 是分配的份额总数,t 是重构密钥所需的最小份额数量。

SSS 方案的核心是点唯一定义多项式的数学概念。 具体来说,需要两个点来定义直线,需要三个点来定义抛物线,等等。 因此,次数为 (t-1) 的多项式由 t 个点唯一确定。 在此方案中,构建了一个 (t-1) 次多项式,使得 n 个参与者中的每一个都与该多项式上的一个点相关联,该点编码了一个密钥。 为了恢复多项式,从而恢复密钥,只需要这些点中的 t 个。 任何由 t 个参与者组成的组,每个人都持有自己的份额,都可以重建原始的次数多项式 (t-1)。 该密钥作为 y 截距嵌入到多项式中,表示多项式在 x=0 处的值,这实际上使其成为多项式的常数项。 通过这种方法,可以安全、准确地检索密钥。

让我们检查 (3, 4) 密钥共享方案。 负责划分密钥的实体(称为经销商)构造一个 2 次多项式,即 (t-1)

f(x) = s + a₁x + a₂x²

s 表示 y 轴截距处的密钥值(即 f(0)),而 a₁a2 是随机数。

图片来源:https://medium.com/numen-cyber-labs/ledger-key-recovery-understanding-the-principles-of-mpc-wallets-dc2eacfd39f3

(3, 4) 经销商的 SSS,其中 s = f(0)

SSS 由两个主要过程组成:

  1. 密钥份额的分配:在分配阶段,交易者将密钥分成几个部分或份额,并将其分配给一组 n(即 4)个参与者。 每个参与者 Pᵢ 都会收到一份份额 sᵢ = f(i)
  2. 密钥的重建:重建过程仅允许 t(即 3)个参与者组合他们的份额并恢复原始密钥,而少于 t 份的任何其他组都无法推断出有关该密钥的任何重要信息。 例如,前 3 个参与者可以形成一组点 (1, s₁)、(2, s2)(3, s₃) 并重建唯一的多项式 f(x),通常使用拉格朗日插值方法。 密钥 s 就是 f(0)

Youtube 上密钥共享的可视化解释

可验证的密钥共享(VSS)

在Shamir密钥共享中,参与者不知道自己收到的份额与其他参与者收到的份额是否一致。 例如,恶意经销商给予 P₁P2P₃ 正确的份额 f(1)f(2)f(3),但给予 P₄ 错误的份额,即不是 f(4)。 如果稍后选择 P₄,则无法正确恢复密钥值。

可验证密钥共享(VSS)是 Shamir 密钥共享方案的扩展,允许验证密钥共享的正确性。 这是在不泄露共享本身的情况下完成的,否则每个人都知道所有共享,从而可以恢复密钥本身,从而破坏了密钥共享的整个目的。

在 VSS 中,除了份额之外,经销商还向每个参与者发送对所有多项式系数的承诺。 一种提交方法是使用椭圆曲线:

c₀ = sGc₁ = a₁Gc₂ = a₂G

cᵢ 承诺 aᵢG 是生成点。

Pᵢ 可以通过检查以下等式是否成立来独立验证其份额的有效性:

f(i)G =? c₀ + c₁i + c₂i²

这是因为:

f(i)G = (s + a₁i + a₂i²)G = sG + a₁iG + a₂i²G = c₀ + c₁i + c₂i²

请注意,她知道方程式中所需的所有信息。 如果等式不成立,她就知道经销商不诚实,可以直接终止。

分布式密钥生成

在这个阶段,我们已经掌握了分发密钥的技术,以便所有参与者都可以接收并验证它。 然而,我们面临着一个问题——经销商知道最初的密钥。

分布式密钥生成(DKG)通过允许每个参与者为密钥的整体随机性做出贡献来解决这个问题。 无经销商 DKG 基本上进行 n 次独立的 VSS 运行。 在第 i 次运行中,Pᵢ 充当经销商来分发密钥 sᵢ。 每个参与者从其他参与者那里收集密钥份额,最终份额是每次运行中份额的总和。 最终的密钥是所有运行中密钥的总和。

为了了解原因,让我们考虑以下两个代表密钥 a 和 b 的多项式:

f₁(x) = a + a₁x + a₂x² + …f₂(x) = b + b₁x + b₂x² + …

这两个多项式可以相加形成最终的密钥多项式:

f(x) = (a+b) + (a₁+b₁)x + (a₂+b₂)x² + …

f(x) 编码密钥 a+b,它是两个单独密钥的总和。 它的份额也是原始两个多项式的两个单独份额的总和。

两个多项式相加

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/650951.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Python实现飞机大战

提供学习或者毕业设计使用,功能基本都有,不能和市场上正式游戏相提比论,请理性对待! 本博文将开启免费试读,如有您需要完整源码或者素材材料等,请订阅本专栏或者找博主购买!购买后将提供源码文件…

什么是独立服务器?独立服务器最全面介绍

独立服务器是单个客户端具有独占访问权的服务器类型,在服务器开发过程中,以前使用虚拟主机和虚拟独立服务器(VPS)的公司几乎不可避免地转向独立服务器。 什么是独立服务器? 独立服务器是单个客户端具有独占访问权的服…

Golang | Leetcode Golang题解之第50题Pow(x,n)

题目: 题解: func myPow(x float64, n int) float64 {if n > 0 {return quickMul(x, n)}return 1.0 / quickMul(x, -n) }func quickMul(x float64, n int) float64 {if n 0 {return 1}y : quickMul(x, n/2)if n%2 0 {return y * y}return y * y * …

随笔Ubuntu上的的一些使用

Ubuntu简易使用 常用指令 cdlsmkdirrf -rm 路径 换源 备份镜像 sudo cp /etc/apt/sources.list /etc/apt/sources.list.bak编辑文件设置 sudo gedit /etc/apt/sources.list清华源 # 阿里源 deb http://mirrors.aliyun.com/ubuntu/ bionic main restricted universe mul…

跨界客户服务:拓展服务边界,创造更多价值

在日益激烈的市场竞争中,企业如何突破传统服务模式的限制,创造更多价值,已成为业界关注的焦点。跨界客户服务作为一种新兴服务模式,正逐渐受到企业的青睐。通过跨界合作,企业可以拓展服务边界,提供更加多元…

PS常见问题总结

目录 基础问题PS如何将两张图片叠加且第一张图片的背景变为透明?ps中多个图片重叠到一起如何分开? 快捷键待续、更新中 基础 图像文件格式 PSD、JPG、PNG、GIF、PDF PSD: Photoshop默认的存储格式, 单用存储空间大 JPG: 有损压缩格式, 存储空间小, 但压缩容易导致…

鸿蒙OpenHarmony【轻量系统 编写“Hello World”程序】 (基于Hi3861开发板)

编写“Hello World”程序 下方将通过修改源码的方式展示如何编写简单程序,输出“Hello world”。请在下载的源码目录中进行下述操作。 确定目录结构。 开发者编写业务时,务必先在./applications/sample/wifi-iot/app路径下新建一个目录(或一…

C++ 核心编程(1)

c面向对象编程 1.内存分区模型 程序运行前为代码区和全局区。程序运行后才有栈区和堆区。。 1.1 程序运行前 #include<iostream> #include <bits/stdc.h> using namespace std; /*全局区全局变量、静态变量、常量 */ //全局变量 int g_1 20; int g_2 30; //const…

[C++][算法基础]分组背包问题(动态规划)

有 &#x1d441; 组物品和一个容量是 &#x1d449; 的背包。 每组物品有若干个&#xff0c;同一组内的物品最多只能选一个。 每件物品的体积是 &#xff0c;价值是 &#xff0c;其中 &#x1d456; 是组号&#xff0c;&#x1d457; 是组内编号。 求解将哪些物品装入背包&a…

了解Cookie登录:原理、实践与安全指南

什么是Cookie登录&#xff1f; Cookie是什么 当你首次登录网站时&#xff0c;你会输入用户名和密码。在后台&#xff0c;网站的服务器验证这些凭据是否正确。一旦确认你的身份无误&#xff0c;服务器就会创建一个Cookie&#xff0c;并将其发送到你的浏览器。这了解Cookie登录…

Kubectl常见排查pod问题命令

一.查看命名空间pod及其日志 #查看命名空间pod kubectl get pods -n <命名空间名称> #该命令不加-n命名空间名称&#xff0c;默认是查看default命名空间的pod#查看对应pod的日志kubectl logs -f <pod-name> -n <namespace>#同样的如果查看的是default命名空…

[Java EE] 多线程(五):单例模式与阻塞队列

1. 单例模式 单例模式是校招中最长考的设计模式之一,首先我们来谈一谈什么是设计模式: 设计模式就好像象棋中的棋谱一样,如果红方走了什么样的局势,黑方就有一定地固定地套路,来应对这样的局势,按照固定地套路来,可以保证在该局势下不会吃亏. 软件开发也是同样的道理,有很多…