分布式密钥生成

news2024/11/27 2:49:40

可验证且无经销商

分布式密钥生成 (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₀ = sG

c₁ = a₁G

c₂ = 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.coloradmin.cn/o/1625695.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

C语言中整型与浮点型在内存中的存储

今天让我们来看看整型的数据和浮点型的数据在内存中是怎么存储的呢 整型数据在内存中的存储 整型数据在内存中存储的是二进制的补码 正数的话也没什么可说的,原码反码补码都相同 我们来看看负数: 以-5为例 原码:10000000 00000000 00000000 0…

集控中心的调度桌成就事业的重要工具

在集控中心的调度室内,一排排整齐的调度桌构成了一道独特的风景线。其中最引人注目的便是那一张张配备现代化设备,宽敞而舒适的调度桌。就我们嘉德立来说这些调度桌不仅见证了调度员们严谨、细致的工作态度,也是他们成就事业的重要工具。 集控…

C++初阶之入门

零、什么是C C是基于C语言而产生的,它既可以进行C语言的过程化程序设计,又可以进行以抽象数据类型为特点的基于对象的程序设计,还可以进行面向对象的程序设计。 C缺点之一,是相对许多语言复杂,而且难学难精。许多人说学…

13 c++版本的五子棋

前言 呵呵 这大概是 大学里面的 c 五子棋了吧 有一些 面向对象的理解, 但是不多 这里 具体的实现 就不赘述, 仅仅是 发一下代码 以及 具体的使用 然后 貌似 放在 win10 上面执行 还有一些问题, 渲染的, 应该很好调整 五子棋 #include<Windows.h> #include<io…

ChatGPT全方位指导:学术论文写作从零开始,轻松搞定高质量论文!

目录 文末福利 一、论文选题的深度探讨 二、撰写摘要的艺术 三、关键词的精选 四、引言的构建 五、正文的结构设计 六、撰写结论的策略 七、致谢的编写 八、附录的有效利用 九、参考文献的整理 文末有福利哦 撰写一篇高质量的学术论文是一项既复杂又耗时的任务。这个…

c++中的指针

一、指针的基本概念 指针的作用&#xff1a;可以通过指针间接访问内存 内存编号是从0开始记录的&#xff0c;一般采用16进制数字表示。可以利用指针变量保存地址。 二、指针变量的定义和使用 指针变量定义语法&#xff1a; 数据类型 * 变量名 #include<iostream> u…

JAVA实现easyExcel模版导出

easyExcel文档 模板注意&#xff1a; 用 {} 来表示你要用的变量 &#xff0c;如果本来就有"{“,”}" &#xff0c;特殊字符用"{“,”}"代替{} 代表普通变量{.}代表是list的变量 添加pom依赖 <dependency><groupId>com.alibaba</groupId&g…

模块三:二分——LCR. 173.点名

文章目录 题目描述算法原理暴力查找二分查找 代码实现暴力查找二分&#xff1a;CJava 题目描述 题目链接&#xff1a;LCR. 173.点名 关于这道题中&#xff0c;时间复杂度为 O(N) 的解法有很多种&#xff0c;⽽且也是⽐较好想的&#xff0c;这⾥就不再赘述。本题只讲解⼀个最优…

超实用的电脑桌面便签+待办清单app

对于上班族来说&#xff0c;桌面便签加待办清单软件是提升工作效率的得力助手。想象一下&#xff0c;在繁忙的工作中&#xff0c;你能够快速记录重要事项&#xff0c;设置待办任务提醒&#xff0c;一切都能有条不紊地进行。这种便捷性&#xff0c;尤其在处理多项任务和紧急事务…

Unity读书系列《Unity3D游戏开发》——脚本(一)

文章目录 前言一、脚本模版及其拓展1、脚本模版2、拓展脚本模版 二、脚本的生命周期三、脚本的执行顺序四、脚本序列化1、序列化数据2、serializedObject3、监听部分元素修改事件 五、定时器与间隔定时器六、工作线程&#xff08;多线程&#xff09;总结 前言 脚本在Unity的重…

中颖51芯片学习9. PWM(12bit脉冲宽度调制)

中颖51芯片学习9. PWM&#xff08;12bit脉冲宽度调制&#xff09; 一、资源简介二、PWM工作流程三、寄存器介绍1. PWMx控制寄存器PWMxCON2. PWM0周期寄存器PWM0PH/L3. PWM1周期寄存器PWM1PH/L4. PWM0占空比控制寄存器PWM0DH/L5. PWM1占空比控制寄存器 PWM1DH/L6. 占空比寄存器与…

临床常用的8个护理评估量表分享,医护必备!

常笑医学整理了8个常用的护理评估量表&#xff0c;包括Morse跌倒量表、Braden压疮评分、格拉斯哥昏迷评分GCS、深静脉血栓评分DVT、Brathel日常生活活动能力量表等&#xff0c;这些量表在常笑医学网上均支持在线使用和下载&#xff0c;供医护人员学习与使用。 Morse跌倒危险因素…

【北京迅为】《iTOP龙芯2K1000开发指南》-第三部分 迅为龙芯开发板快速体验

龙芯2K1000处理器集成2个64位GS264处理器核&#xff0c;主频1GHz&#xff0c;以及各种系统IO接口&#xff0c;集高性能与高配置于一身。支持4G模块、GPS模块、千兆以太网、16GB固态硬盘、双路UART、四路USB、WIFI蓝牙二合一模块、MiniPCIE等接口、双路CAN总线、RS485总线&#…

webpack热更新原理详解

文章目录 前言基础配置创建项目HMR配置 HMR交互概览HMR流程概述HMR实现细节初始化注册监听编译完成事件启动服务监听文件代码变化服务端发送消息客户端收到消息热更新文件请求热更新代码替换 问题思考 前言 刷新分为两种&#xff1a;一种是页面刷新&#xff0c;不保留页面状态…

LANGUAGE-DRIVEN SEMANTIC SEGMENTATION

环境不易满足&#xff0c;不建议复现

CentOS7利用宝塔面板安装zabbix6.0.x详细安装教程(手把手图文详解版)

最近学习CentOS7安装zabbix6.0.x的版本&#xff0c;尝试了很多教程&#xff0c;很多都比较麻烦且容易出错&#xff0c;最后发现使用宝塔面板最为简单&#xff0c;将具体过程记录下来&#xff0c;一来分享给有需要的人&#xff0c;二来自己也当记录笔记&#xff0c;以免以后遗忘…

Hive中几个非常重要的问题

1、Hive 有哪些方式保存元数据&#xff0c;各有哪些优缺点 (1).DerBy数据库&#xff1a;默认自带 优点&#xff1a;使用简单&#xff0c;不需要额外的配置。 缺点&#xff1a;只有一个客户端&#xff0c;多个客户访问会报错。 (2).使用MySql数据库存储 优点&#xff1a;单独的…

OSPF的LSA详解

一、什么是LSA&#xff1f;LSA作用&#xff1f; 在OSPF协议中&#xff0c;LSA全称链路状态通告&#xff0c;主要由LSA头部信息&#xff08;LSA摘要&#xff09;和链路状态组成。部分LSA只有LSA头部信息&#xff0c;无链路状态信息。使用LSA来传递路由信息和拓扑信息&#xff0c…

linux系统安全

一、账号安全基本措施 1.1 系统账号清理 1.1.1 将用户设置为无法登录-- 改登录shell 登录shell是用户与计算机系统直接交互的接口&#xff0c;使用户能够通过命令行方式进行各种操作和管理。 所以让用户无法登录&#xff0c;其实就是将登录shell改为 /sbin/nologin,可以用us…

移动应用安全

移动应用安全 移动应用安全主要关注Android、iOS、Windows Phone等平台上移动应用软件安全状态。它涉及应用程序在其设计运行的平台上下文中的安全问题、它们使用的框架以及预期的用户集。所有主流的移动平台都提供大量可选的安全控制&#xff0c;旨在帮助软件开发人员构建安全…