热门标签 | 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 从业者建立内部链接,了解「重构研究院」

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


推荐阅读
  • Asynchronous JavaScript and XML (AJAX) 的流行很大程度上得益于 Google 在其产品如 Google Suggest 和 Google Maps 中的应用。本文将深入探讨 AJAX 在 .NET 环境下的工作原理及其实现方法。 ... [详细]
  • 尽管在WPF中工作了一段时间,但在菜单控件的样式设置上遇到了一些基础问题,特别是关于如何正确配置前景色和背景色。 ... [详细]
  • 本文探讨了Python类型注解使用率低下的原因,主要归结于历史背景和投资回报率(ROI)的考量。文章不仅分析了类型注解的实际效用,还回顾了Python类型注解的发展历程。 ... [详细]
  • H5技术实现经典游戏《贪吃蛇》
    本文将分享一个使用HTML5技术实现的经典小游戏——《贪吃蛇》。通过H5技术,我们将探讨如何构建这款游戏的两种主要玩法:积分闯关和无尽模式。 ... [详细]
  • Uniswap 与 MoonPay 合作,引入法币交易功能。本文探讨这一合作对用户进入加密货币领域的安全性及便利性的影响。 ... [详细]
  • 黑客松获奖名单出炉、NFT艺术周圆满落幕 |Oasis周报 ... [详细]
  • Hibernate全自动全映射ORM框架,旨在消除sql,是一个持久层的ORM框架1)、基础概念DAO(DataAccessorOb ... [详细]
  • 本文探讨了异步编程的发展历程,从最初的AJAX异步回调到现代的Promise、Generator+Co以及Async/Await等技术。文章详细分析了Promise的工作原理及其源码实现,帮助开发者更好地理解和使用这一重要工具。 ... [详细]
  • 想把一组chara[4096]的数组拷贝到shortb[6][256]中,尝试过用循环移位的方式,还用中间变量shortc[2048]的方式。得出的结论:1.移位方式效率最低2. ... [详细]
  • 本文详细介绍如何在 Apache 中设置虚拟主机,包括基本配置和高级设置,帮助用户更好地理解和使用虚拟主机功能。 ... [详细]
  • Vue CLI 基础入门指南
    本文详细介绍了 Vue CLI 的基础使用方法,包括环境搭建、项目创建、常见配置及路由管理等内容,适合初学者快速掌握 Vue 开发环境。 ... [详细]
  • 本文探讨了如何在 Spring MVC 框架下,通过自定义注解和拦截器机制来实现细粒度的权限管理功能。 ... [详细]
  • 在测试软件或进行系统维护时,有时会遇到电脑蓝屏的情况,即便使用了沙盒环境也无法完全避免。本文将详细介绍常见的蓝屏错误代码及其解决方案,帮助用户快速定位并解决问题。 ... [详细]
  • 本文将详细探讨 Python 编程语言中 sys.argv 的使用方法及其重要性。通过实际案例,我们将了解如何在命令行环境中传递参数给 Python 脚本,并分析这些参数是如何被处理和使用的。 ... [详细]
  • 深入解析C语言中的关键字及其分类
    本文将全面介绍C语言中的关键字,并按照功能将其分为数据类型关键字、控制结构关键字、存储类别关键字和其他关键字四大类,旨在帮助读者更好地理解和运用这些基本元素。C语言中共有32个关键字。 ... [详细]
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社区 版权所有