热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

众目睽睽能隐身的区块链黑科技,zkSNARK背后原理解析

本文由尘埃科技整理编辑发布,

本文由尘埃科技整理编辑发布,请拖动至文章底部查看更多精彩内容

编辑|RR

zk-SNARK 最近多次出现在了我们的视线中,很多人还没搞清楚 zk-SNARK 到底是什么,到底有什么原理,能解决什么问题,今天我们就跟大家全面解读 zk-SNARK 相关的一切。


尽管加密货币交易与任何人的身份无关,但由于被公开记录在区块链上,它们通常是可追踪的。如果你想避免这种情况,你需要一种被称为隐私币的特定类型的加密货币。隐私币用来保持交易匿名的方法之一是一种叫做 zk-SNARK 的技术。



对于那些正在考虑将隐私币用于个人用途或作为加密货币投资的人来说,了解其背后的技术非常重要。虽然 zk-SNARK 有些复杂,但我们将在本指南中详细介绍它的作用。

 

zk-SNARK 是什么?


zk-SNARK 是一种零知识证明协议,在这种协议中,人们可以证明自己拥有某些信息,而无需披露这些信息,也不需要各方之间进行任何交互来证明和验证这些信息。

 

术语“zk-SNARK”是“Zero-Knowledge Succinct Non-Interactive Argument of Knowledge”的缩写。这个名字的每一部分都指代了 zk-SNARK 的一个特征,因此单独查看每一个组成部分会有所帮助:

 

  • Zero-Knowledge:证明方可以向验证方表明他们拥有某项信息,而不需要提供信息本身。

  • Succinct:由于证明的长度最多只有几百个字节,所以证明可以在几毫秒内得到验证。

  • Non-Interactive:证明包括从证明者到验证者的单一信息。

  • Argument:Argument 是这些证明的术语,因为它们不完全符合证明的传统定义,但有效地服务于相同的目的。

  • Knowledge:指证明者所拥有的信息。

 

在加密货币中,zk-SNARK 是一种在区块链上对交易进行私有和完全加密的同时,仍然使用网络的共识规则进行验证的方式。zk-SNARK 可以表明发送者拥有他们想要转移的资金数额,而不需要公开该信息。



zk-SNARK 解释

 

zk-SNARK 来自零知识证明的概念,该概念是 Shafi Goldwasser、Silvio Micali 和 Charles Rackoff 在 1985 年的一篇论文中首次提出的。正如前面所解释的,零知识证明是一种方法,它允许一方只表明他们拥有一条信息,而不透露信息本身或任何其他信息。

 

早期的零知识协议要求证明方和验证方来回发送消息。Nir Bitansky、Ran Canetti、Alessandro Chiesa 和 Eran Tromer 在 2012 年的一篇论文中创造了术语“zk-SNARK”来描述一种新的零知识协议。与之前的方法不同,它不需要证明方和验证方在单一信息之外进行交互。

 

合著者 Chiesa 后来帮助创立了 Zcash ,这是一种 2016 年推出的隐私币。它使用 zk-SNARK 技术来支持私人交易。


zk-SNARK 如何工作

 

大多数类型的加密货币通过网络检查交易是否满足某些条件来进行验证。具体来说,其条件是发送方拥有可用的资金,并且他们提供了正确的私钥来表明资金属于他们。

 

zk-SNARK 允许交易的发送方在不透露任何涉及的地址或金额的情况下证明这一切。为了做到这一点,区块链网络在 zk-SNARK 中编码了一些共识规则。

 

在交易过程中,zk-SNARK 将需要证明的信息转化为方程。这些方程可以在不透露信息本身的情况下计算和求解。

 

zk-SNARK 的优缺点

 

zk-SNARK 的主要好处是其提供的隐私和效率。它们屏蔽了敏感信息,只需几毫秒即可验证,而且不需要相关各方之间的长期交互。所需要的只是从证明者到验证者的一条消息。

 

尽管 zk-SNARK 没有任何明显的缺点,但如果有人拥有用于建立协议的私钥,他们就能够创建虚假证明并伪造资金。使用 zk-SNARK 的隐私币必须采取措施,确保没有任何一方能够获得该私钥。

 


zk-SNARK vs. zk-Rollup


zk-SNARK 远非加密货币使用的唯一类型的零知识证明。另一种常见的技术是 zk-Rollup,这是一种帮助以太坊更有效地处理交易的扩展解决方案。

 

Rollup 将一大群交易捆绑在一起,并在链下验证它们,这意味着所有的计算都在主以太坊区块链之外处理。然后它们被打包成一个单独的交易,发送到以太坊的执行层。

 

有不同类型的 Rollup 可供选择。例如,Optimistic rollup 假设交易有效,直到它们被证明为错误。另一方面,zk- rollup 可以即时验证交易并生成加密的有效性证明。证明可以使用 zk-SNARK 或另一种类型的零知识证明技术 zk-STARK 生成。

 

zk-SNARK 用例

 

zk-SNARK 最著名的用例是屏蔽加密货币交易。Zcash 是 zk-SNARK 的第一个广泛应用。该隐私币允许用户在私有地址和透明地址之间进行选择。当用户选择私有地址时,zk-SNARK 会屏蔽交易数据。

 

其他区块链项目也在使用 zk-SNARK。以太坊在 2017 年开始致力于整合 Zcash 和 zk-SNARK。同年,Zcash 与摩根大通合作,用 zk-STARK 构建了一个基于区块链的支付系统。

 

虽然 zk-SNARK 目前被用于私有化金融交易,但这并不是它们的唯一应用。在未来,我们可以看到它们被用来保护人们在网上活动时的数据。

 

如何应用 zk-SNARK

 

zk-SNARK 通过将需要证明的信息转化为数学方程来进行应用。交易的发送方会构建一个证明来证明:

 

  • 传输的输入和输出值匹配。

  • 发送方拥有输入的私有支出密钥。

  • 这些私钥以加密方式与交易的数字签名进行链接,以确保它不能被没有私钥的人修改。

 

zk-SNARK 是一项有用的技术,结合了这项技术的加密货币已经成为了热门投资。虽然隐私币有明确的效用,但请记住,它们并不稳定,其提供的隐私水平可能会导致未来的监管问题。如果你决定投资某种隐私币,请采取保守的方法,避免投入超出你承受能力的资金。

信息来源自 The Motley Fool,略有修改,作者Lyle Daly 

尘埃科技


更多 DAO、Web3、NFT、Metaverse

专业研究请关注尘埃科技旗下「老雅痞」

Web3 知识点、干货类内容

请关注尘埃科技旗下「Allrecode 重构」


为 Web3 从业者建立内部链接,了解「重构研究院」

“商务合作”、“内容转载”请直接在后台回复关键字


推荐阅读
  • 深入解析 Apache Shiro 安全框架架构
    本文详细介绍了 Apache Shiro,一个强大且灵活的开源安全框架。Shiro 专注于简化身份验证、授权、会话管理和加密等复杂的安全操作,使开发者能够更轻松地保护应用程序。其核心目标是提供易于使用和理解的API,同时确保高度的安全性和灵活性。 ... [详细]
  • 深入剖析 DEX 赛道:从 60 大头部项目看五大趋势
    本文通过分析 60 大头部去中心化交易平台(DEX),揭示了当前 DEX 赛道的五大发展趋势,包括市场集中度、跨链协议、AMM+NFT 结合、新公链崛起以及稳定币和衍生品交易的增长潜力。 ... [详细]
  • 本文介绍了多个适用于用户界面设计的Canvas框架,帮助开发者选择最适合的工具。 ... [详细]
  • 基于KVM的SRIOV直通配置及性能测试
    SRIOV介绍、VF直通配置,以及包转发率性能测试小慢哥的原创文章,欢迎转载目录?1.SRIOV介绍?2.环境说明?3.开启SRIOV?4.生成VF?5.VF ... [详细]
  • Codeforces Round #566 (Div. 2) A~F个人题解
    Dashboard-CodeforcesRound#566(Div.2)-CodeforcesA.FillingShapes题意:给你一个的表格,你 ... [详细]
  • 深入解析 Spring Security 用户认证机制
    本文将详细介绍 Spring Security 中用户登录认证的核心流程,重点分析 AbstractAuthenticationProcessingFilter 和 AuthenticationManager 的工作原理。通过理解这些组件的实现,读者可以更好地掌握 Spring Security 的认证机制。 ... [详细]
  • 探讨如何真正掌握Java EE,包括所需技能、工具和实践经验。资深软件教学总监李刚分享了对毕业生简历中常见问题的看法,并提供了详尽的标准。 ... [详细]
  • 本文介绍如何在现有网络中部署基于Linux系统的透明防火墙(网桥模式),以实现灵活的时间段控制、流量限制等功能。通过详细的步骤和配置说明,确保内部网络的安全性和稳定性。 ... [详细]
  • 深入理解Redis的数据结构与对象系统
    本文详细探讨了Redis中的数据结构和对象系统的实现,包括字符串、列表、集合、哈希表和有序集合等五种核心对象类型,以及它们所使用的底层数据结构。通过分析源码和相关文献,帮助读者更好地理解Redis的设计原理。 ... [详细]
  • 本文详细介绍了Java中的输入输出(IO)流,包括其基本概念、分类及应用。IO流是用于在程序和外部资源之间传输数据的一套API。根据数据流动的方向,可以分为输入流(从外部流向程序)和输出流(从程序流向外部)。此外,还涵盖了字节流和字符流的区别及其具体实现。 ... [详细]
  • Python入门:第一天准备与安装
    本文详细介绍了Python编程语言的基础知识和安装步骤,帮助初学者快速上手。涵盖Python的特点、应用场景以及Windows环境下Python和PyCharm的安装方法。 ... [详细]
  • MySQL DateTime 类型数据处理及.0 尾数去除方法
    本文介绍如何在 MySQL 中处理 DateTime 类型的数据,并解决获取数据时出现的.0尾数问题。同时,探讨了不同场景下的解决方案,确保数据格式的一致性和准确性。 ... [详细]
  • 通过Web界面管理Linux日志的解决方案
    本指南介绍了一种利用rsyslog、MariaDB和LogAnalyzer搭建集中式日志管理平台的方法,使用户可以通过Web界面查看和分析Linux系统的日志记录。此方案不仅适用于服务器环境,还提供了详细的步骤来确保系统的稳定性和安全性。 ... [详细]
  • 本题探讨了在一个有向图中,如何根据特定规则将城市划分为若干个区域,使得每个区域内的城市之间能够相互到达,并且划分的区域数量最少。题目提供了时间限制和内存限制,要求在给定的城市和道路信息下,计算出最少需要划分的区域数量。 ... [详细]
  • 本题探讨了在大数据结构背景下,如何通过整体二分和CDQ分治等高级算法优化处理复杂的时间序列问题。题目设定包括节点数量、查询次数和权重限制,并详细分析了解决方案中的关键步骤。 ... [详细]
author-avatar
love灬贪恋猫
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有