零知识证明的最新发展和应用

PrimiHub一款由密码学专家团队打造的开源隐私计算平台,专注于分享数据安全、密码学、联邦学习、同态加密等隐私计算领域的技术和内容。

当企业收集大量客户数据去审查、改进产品和服务以及将数据资产货币化时,他们容易受到网络攻击威胁,造成数据泄露。数据泄露的损失每年都在上升,每次泄露平均造成损失 420 万美元,如下图所示,它们严重损害了企业的声誉和可信度。

数据泄露的成本

数据泄露的成本

零知识证明 (ZKPs) 等隐私增强技术 (PETs) 为企业提供了保护其敏感数据的方法。我们在本文中描述了 ZKP 的功能及其应用示例,以帮助大家认识最新的网络安全态势。

什么是零知识证明(ZKP)?

零知识证明(ZKP),也称为零知识协议,是一种在不泄露信息本身的情况下验证信息真实性的数学技术。该方法最初由麻省理工学院的研究人员在1985年的一篇论文[1]中引入。

零知识证明如何发挥作用?

下面是一个流行的例子来说明 ZKP 背后的基本思想:

假设你(证明者)有一个色盲朋友(验证者),他无法区分绿球和红球(对球是否为不同颜色的了解为零)。你需要证明球的颜色是不同的,但你需要去用证据去说服他,而不是只有你的劝说。解决这个问题的 ZKP 方法如下:

  1. 你的朋友拿走球,且让你看看红球和绿球各在哪只手上;

  2. 然后,你的朋友将球放在背后,可以选择是否交换两个球;

  3. 然后,将球拿出来并询问你是否交换了球。由于你可以区分绿球和红球,因此可以轻松给出正确答案;

  4. 你的朋友不相信。因为你有 50% 的机会正确猜测他们是否交换了球,并且球的颜色仍然相同。

  5. 但是,如果你的朋友多重复几次,最终你每次正确猜测他们是否换球的概率就会非常低。这使你的朋友能够在不知道球的实际颜色的情况下验证球的颜色是否不同。

ZKP 的实际应用中使用了一系列密码算法来验证计算语句。例如,使用 ZKP 方法,付款接收方可以验证付款人的银行帐户中有足够的余额,而无需获取有关付款人余额的任何其他信息。

另一个广泛流传的可以说明交互式证明工作流的示例是有关阿里巴巴的洞穴故事,该故事可以在维基百科文章中找到。

零知识证明有哪些特性?

零知识证明(ZKP)方法必须满足以下标准:

完整性:如果证明者提供的信息是真实的,那么ZKP方法必须使验证者能够验证证明者说的是真话。

可靠性:如果证明者提供的信息是错误的,那么 ZKP 方法必须允许验证者反驳证明者说的是真话。零知识:该方法必须向验证者透露证明者是否说真话以外的任何内容。

零知识证明有哪些不同类型?

零知识证明主要有两种类型:

交互式零知识证明:在这种类型的 ZKP 中,证明者和验证者进行多次交互。验证者向证明者提出挑战,证明者对这些挑战提供答复,直到验证者确信为止。

非交互式零知识证明:在这种类型的 ZKP 中,证明者提供的证明在任何时候只能被验证者验证一次。这种类型的 ZKP 比交互式 ZKP 需要更多的计算能力。

零知识证明有哪些应用和用例?

零知识证明可用于保护各种密码学方案中的数据隐私,例如:

区块链:比特币和以太坊等公共区块链的透明度可以实现交易的公开验证。然而,它也意味着很少的隐私,并可能导致用户去匿名化。零知识证明可以为公共区块链引入更多隐私。例如,加密货币 Zcash 基于零知识简洁非交互式知识论证(zk-SNARK),这是一种零知识加密方法。另一个例子是零知识可扩展透明知识论证(zk-STARK),它用于以太坊区块链并提供隐私和可扩展性。

金融:ING 使用 ZKPs 允许客户证明他们的秘密号码位于已知范围内。例如,抵押贷款申请人可以证明他们的收入在允许的范围内,而无需透露他们的确切工资。

在线投票:ZKPs 可以允许选民匿名投票并验证他们的投票是否包含在最终计票中。

身份验证:ZKP 可用于对用户进行身份验证,而无需交换密码等秘密信息。机器学习:ZKP 可以让机器学习算法的所有者让其他人相信模型的结果,而无需透露有关 ML 模型本身的任何信息。

零知识证明面临哪些挑战?

没有 100% 的保证:即使在证明者撒谎时验证者进行验证的概率可能非常低,ZKPs 也不能保证声明 100% 有效。如上所述,证明者说谎的概率在选球过程的每次迭代中都会降低,但永远不会达到零。因此,零知识证明并不是数学意义上的实际证明。

计算强度:所使用的算法计算强度大,因为它们需要验证者和证明者之间的大量交互(在交互式 ZKP 中),或者需要大量的计算能力(在非交互式 ZKP 中)。这使得 ZKP 不适合慢速或移动设备。

原文地址:Zero-Knowledge Proofs: How it Works & Use Cases in 2024
原文作者:Cem Dilmegani
翻译 & 整理:开放隐私计算 & PrimiHub

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

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

相关文章

RC4加解密源码

本文介绍RC4加解密源码。 RC4(来自Rivest Cipher 4的缩写)是一种流加密算法,密钥长度可变。它加解密使用相同的密钥,因此也属于对称加密算法。RC4具有加解密速度快,算法简单等优点,在算力不高场合&#xf…

C++输入与输出

C 中的输入与输出主要通过标准输入输出流实现。以下是一些基本示例代码&#xff0c;演示了如何使用 cin 来输入变量的值&#xff0c;并使用 cout 来输出变量的值。 输入变量的值 #include <iostream> using namespace std;int main() {int number;cout << "…

用重建大师时,在主服务器建了一个快捷方式,给局域网其他电脑开了权限,其他电脑能正常访问主服务器数据吗?

答&#xff1a;可以的&#xff0c;重建大师支持集群方式。数据放在服务器文件夹das&#xff0c;在主服务器读取数据建立了一个快捷方式&#xff0c;这个快捷方式给局域网其他电脑开了权限&#xff0c;其他电脑是可以通过快捷方式正常访问主服务器数据的。 重建大师是一款专为超…

昇腾910b部署Chatglm3-6b进行流式输出【pytorch框架】NPU推理

文章目录 准备阶段避坑阶段添加代码结果展示 准备阶段 配套软件包Ascend-cann-toolkit和Ascend-cann-nnae适配昇腾的Pytorch适配昇腾的Torchvision Adapter下载ChatGLM3代码下载chatglm3-6b模型&#xff0c;或在modelscope里下载 避坑阶段 每个人的服务器都不一样&#xff0…

Pixart PAR2861 蓝牙 keyboard 开发笔记

Pixart PAR2861 是一款采用32 bits ARM Cortex-M0 低功耗、高效能 2.4GHz RF 的 SoC。 该 SoC 整合了高效能的 2.4GHz RF 收发器、硬体Keyscan、硬体按键防弹跳、SPI、I2C、PWM LED、ADC、UART等。内建 DC/DC 转换器和 LDO 为独立 HID 应用提供完整的低功耗 SoC 解决方案。 1.…

2023年网络安全事件处罚盘点,文件销毁 硬盘销毁 物料销毁

《中华人民共和国网络安全法》是我国第一部全面规范网络空间安全管理方面问题的基础性法律&#xff0c;是我国网络空间法治建设的重要里程碑&#xff0c;《中华人民共和国网络安全法》从2013年下半年提上日程&#xff0c;到2016年年底颁布&#xff0c;自2017年6月1日起施行&…

已解决java.lang.ReflectiveOperationException异常的正确解决方法,亲测有效!!!

已解决java.lang.ReflectiveOperationException异常的正确解决方法&#xff0c;亲测有效&#xff01;&#xff01;&#xff01; 文章目录 问题分析 报错原因 解决思路 解决方法 总结 问题分析 ReflectiveOperationException是Java反射操作中可能抛出的多种异常的父类。 …

滑动登陆注册同页面

这是一个登陆注册在同一个页面滑动选择的页面 技术&#xff1a;html、css、javascript 简单页面实现&#xff08;为了方便&#xff0c;已将代码放在同一文件引用&#xff09;&#xff1a; 1.1、效果图 1.2、完整代码&#xff1a; <!DOCTYPE html> <html lang"…

代码进阶-代码注意事项总结

前言:敲了很多代码了&#xff0c;简单总结一下&#xff0c;代码中让代码运行更好的技巧 多写日志信息&#xff0c;检测到参数和可能出现的异常 多写校验&#xff0c;防止出现一些不可控的输入 不可控的输入包括 模糊查询 的关键字 例如 % _ 或者其他的sql相关的关键字和符号…

virtualbox Ubuntu 网络连接

一、网络连接需求1—— 上网&#xff1a; 虚拟机默认的NAT连接方式&#xff0c;几乎不需要怎么配置&#xff0c;即可实现上网。 enp0s17以太网必须要开启&#xff0c;才能上网&#xff1b; 但是主机ping不通虚拟机&#xff0c;貌似可以ping 127.0.0.1; 二、主机和虚拟机相互p…

《Vite 基础知识》使用 Glob 动态加载 .vue 文件

前言 开发基于 Vite Vue3 的组件库&#xff0c;多个 .vue 文件需要动态加载&#xff01; 注意 import.meta.globEager 已经弃用&#xff0c;请使用 import.meta.glob 来代替&#xff01; 使用 Glob 异步方式 代码第 1 行&#xff0c;注意使用两个 **&#xff0c;匹配当前目…

语境化语言表示模型-ELMO、BERT、GPT、XLnet

一.语境化语言表示模型介绍 语境化语言表示模型&#xff08;Contextualized Language Representation Models&#xff09;是一类在自然语言处理领域中取得显著成功的模型&#xff0c;其主要特点是能够根据上下文动态地学习词汇和短语的表示。这些模型利用了上下文信息&#xf…

医院患者满意度调查方法有哪些?

医院患者满意度调查可以使用多种方法来收集患者的反馈和意见。以下是一些常见的医院患者满意度调查方法&#xff1a; 在线调查问卷&#xff1a;这是一种常见的调查方法&#xff0c;患者可以在电脑、平板电脑或智能手机上填写问卷。在线问卷通常易于分发和收集&#xff0c;可以…

DrGraph原理示教 - OpenCV 4 功能 - 形态操作

形态类型 从OpenCV图像处理基本知识来看&#xff0c;膨胀腐蚀操作后&#xff0c;还有形态操作&#xff0c;如开运算、闭运算、梯度、礼帽与黑帽&#xff0c;感觉很多&#xff0c;其实&#xff0c;本质上就是批处理操作&#xff0c;如 开运算&#xff1a;先腐蚀&#xff0c;再膨…

大模型LLM Agent在 Text2SQL 应用上的实践

1.前言 在上篇文章中「如何通过Prompt优化Text2SQL的效果」介绍了基于Prompt Engineering来优化Text2SQL效果的实践&#xff0c;除此之外我们还可以使用Agent来优化大模型应用的效果。 本文将从以下4个方面探讨通过AI Agent来优化LLM的Text2SQL转换效果。 1 Agent概述2 Lang…

deepseed 单机多卡程序报错:exits with return code -7

现象&#xff1a;exits with return code -7原因&#xff1a;Setting the shm-size to a large number instead of default 64MB when creating docker container solves the problem in my case. It appears that multi-gpu training relies on the shared memory. ref 排查是…

肯尼斯·里科《C和指针》第6章 指针(3)

肯尼斯里科《C和指针》第6章 指针&#xff08;1&#xff09;-CSDN博客 肯尼斯里科《C和指针》第6章 指针&#xff08;2&#xff09;-CSDN博客 前置知识&#xff1a;左值右值 为了理解有些操作符存在的限制&#xff0c;必须理解左值(L-value)和右值(R-value)之间的区别。这两个…

2024年百场进校公益安全培训开启

自2023年年底&#xff0c;上海风暴救援队积极策划并推动了2024年的“百场进校传安全”培训项目。经过在东方锦绣于2023年12月14日、上钢新村幼儿园于2023年12月28日的先期测试&#xff0c;项目于2024年1月5日在齐河路幼儿园正式启动。随后&#xff0c;于2024年1月11日在浦南幼儿…

顺序表和链表基础

定义动态的顺序表 typedef int SLDataType; typedef struct Seqlist {SLDataType* array;size_t size;size_t capacity; }Seqlist; 在顺序表中插入数据 bool ListInsert(Seqlist* l, int i, SLDataType e) {if (i < 1 || i > l->capacity)return false;int j;for (…

【大数据进阶第三阶段之Hue学习笔记】Hue的安装和使用

1、 Hue的安装 1.1 上传解压安装包 Hue的安装支持多种方式&#xff0c;包括rpm包的方式进行安装、tar.gz包的方式进行安装以及cloudera manager的方式来进行安装等&#xff0c;我们这里使用tar.gz包的方式来进行安装 Hue的压缩包的下载地址&#xff1a; http://archive.cloude…