首页 > 其他分享 >零知识证明的最新发展和应用

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

时间:2024-01-11 13:48:53浏览次数:27  
标签:验证 知识 证明 最新 隐私 交互式 ZKP

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

标签:验证,知识,证明,最新,隐私,交互式,ZKP
From: https://www.cnblogs.com/primihub/p/17958382

相关文章

  • Elastic 安全相关知识
    Elastic安全相关知识证书相关CA证书docker部署不要使用自动生成的证书,找不到CA私钥,对于后续证书的生成是个很大的问题,建议先自己生成CA,再使用自己的CA生成相应证书。#生成一个压缩包,包含一个crt格式的CA证书文件和私钥elasticsearch-certutilca--pem#输入密码......
  • 最新消息:OpenAI GPT Store 正式上线,GPTs 应用商店来了!
    原文链接https://openaigptguide.com/gpt-store-and-chatgpt-team/OpenAI推出的两款新产品和服务:GPTStore和ChatGPTTeam,提供了许多全新的解决方案和功能,旨在帮助用户更轻松地使用和构建GPT工具,同时也增加了公司的收入来源。GPTStore是一个全新的在线平台,允许用户创建和分享自......
  • 23年最新版pycharm找不到conda可执行文件解决办法
    引言我下载的是2023年最新版本的pycharm,新版的pycharm安装好了之后就会出现一个问题,就是在配置conda虚拟环境找不到conda的可执行文件,出现了以下问题。遇到这个问题有两种解决办法。解决办法1、第一种按照以下步骤,找到condabin文件下面,conda.bat文件,把路径给复制下来......
  • vivo 海量微服务架构最新实践
    作者:来自vivo互联网中间件团队本文根据罗亮老师在“2023vivo开发者大会"现场演讲内容整理而成。公众号回复【2023VDC】获取互联网技术分会场议题相关资料。vivo微服务平台为全球5亿+用户背后的全网十万级机器、万级微服务提供服务,在高效实践过程中,vivo中间件平台团队输出了一套......
  • vivo 海量微服务架构最新实践
    作者:来自vivo互联网中间件团队本文根据罗亮老师在“2023vivo开发者大会"现场演讲内容整理而成。公众号回复【2023VDC】获取互联网技术分会场议题相关资料。vivo微服务平台为全球5亿+用户背后的全网十万级机器、万级微服务提供服务,在高效实践过程中,vivo中间件平台团队输出......
  • 【C/C++】知识点笔记
    1-联合体内嵌结构体初始化赋值union{struct{inti;floatf;char*p;};into;}obj3={1,2.2,"sk",4,9};printf("structinlayunion:%d,%f,%s,%d\n",obj3.i,obj3.f,obj3.p,obj3.o);输出:structin......
  • 知识图谱系统在人工智能领域的应用与前景
    知识图谱(KnowledgeGraph)是一种新型的知识表示、存储和查询的方法,也是人工智能领域中重要的基础技术之一。本文主要介绍了知识图谱的概念、产生背景,以及发展历程,并详细分析了知识图谱人工智能领域中的应用,最后对其未来的发展趋势进行了展望。知识图谱简介知识图谱(KnowledgeGraph)是......
  • 获取直播间的最新评论 - python 取两个list的差集
    python取两个list的差集作用:比如我要获取评论区列表,先获取了一遍,这个时候有人评论了几条,我再获取一遍后,找出多的那几条使用set数据类型来取两个列表的差集。差集表示仅包含在第一个列表中而不在第二个列表中的元素list1=[1,2,3,4,5]list2=[3,4,5,6,7]使用set取......
  • 「云渲染知识」建筑效果图用什么软件制作?
    高品质的建筑效果图需要利用插件来模拟复杂的场景、光线照射和天气变化。然而,许多专业人士可能不清楚有哪些软件可以实现这样的效果。下面将介绍一些常用的软件来帮助实现高品质的建筑效果图。一、建筑效果图必备软件1、三维建模工具Autodesk3dsMax:强大的建模工具,用于创建复......
  • 生活常识-贵金属-黄金知识
    前言全局说明生活常识-贵金属-黄金知识内容来源于网络一、单位Au黄金化学符号g是黄金gold的缩写来源:微信视频号“西安黄金小郭”二、标号AU999或g999是纯黄金AU750或g750代表含金量75%三、没有字母只有数字标号999这种不是黄金规范标号,可能是......