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

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


推荐阅读
  • BreederDAO 一周年:回顾历程,庆祝成就,展望未来
    10月标志着BreederDAO踏入Web3.0领域的起点,开启了元宇宙工厂的建设。自成立以来,BreederDAO始终致力于构建多样化的数字资产工厂。 ... [详细]
  • 2018年3月31日,CSDN、火星财经联合中关村区块链产业联盟等机构举办的2018区块链技术及应用峰会(BTA)核心分会场圆满举行。多位业内顶尖专家深入探讨了区块链的核心技术原理及其在实际业务中的应用。 ... [详细]
  • 智慧城市建设现状及未来趋势
    随着新基建政策的推进及‘十四五’规划的实施,我国正步入以5G、人工智能等先进技术引领的智慧经济新时代。规划强调加速数字化转型,促进数字政府建设,新基建政策亦倡导城市基础设施的全面数字化。本文探讨了智慧城市的发展背景、全球及国内进展、市场规模、架构设计,以及百度、阿里、腾讯、华为等领军企业在该领域的布局策略。 ... [详细]
  • 本文探讨了当前技术发展趋势,特别是大数据和人工智能如何推动工业互联网的发展。文章分析了全球主要国家在工业互联网领域的进展,并展望了未来工业互联网技术的发展方向。 ... [详细]
  • a16z 宣布成立全新的加密研究实验室,旨在推动加密技术和 Web3 领域的科学发展。 ... [详细]
  • 本文介绍如何解决在 IIS 环境下 PHP 页面无法找到的问题。主要步骤包括配置 Internet 信息服务管理器中的 ISAPI 扩展和 Active Server Pages 设置,确保 PHP 脚本能够正常运行。 ... [详细]
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • 本文介绍如何在QT框架中使用QWebSocket和QTcpSocket实现SSL加密通信,涵盖单向认证设置。单向认证常见于Web通信场景,其中客户端验证服务端证书,而服务端不验证客户端证书。 ... [详细]
  • 从 .NET 转 Java 的自学之路:IO 流基础篇
    本文详细介绍了 Java 中的 IO 流,包括字节流和字符流的基本概念及其操作方式。探讨了如何处理不同类型的文件数据,并结合编码机制确保字符数据的正确读写。同时,文中还涵盖了装饰设计模式的应用,以及多种常见的 IO 操作实例。 ... [详细]
  • 深入解析 Apache Shiro 安全框架架构
    本文详细介绍了 Apache Shiro,一个强大且灵活的开源安全框架。Shiro 专注于简化身份验证、授权、会话管理和加密等复杂的安全操作,使开发者能够更轻松地保护应用程序。其核心目标是提供易于使用和理解的API,同时确保高度的安全性和灵活性。 ... [详细]
  • 本文详细介绍了Java中的输入输出(IO)流,包括其基本概念、分类及应用。IO流是用于在程序和外部资源之间传输数据的一套API。根据数据流动的方向,可以分为输入流(从外部流向程序)和输出流(从程序流向外部)。此外,还涵盖了字节流和字符流的区别及其具体实现。 ... [详细]
  • 算法稳定币:构建去中心化加密货币体系的新希望
    本文探讨了算法稳定币在加密经济中的潜力,分析其与传统稳定币及比特币等早期加密资产的区别,并展望其未来发展方向。随着DeFi的兴起,算法稳定币正逐渐成为实现中本聪最初愿景的关键角色。 ... [详细]
  • NFT入门指南:了解非同质化代币及其与Web3的关系
    本文旨在为初学者提供全面的NFT介绍,涵盖其历史发展、特性、应用领域及与Web3技术的关联。 ... [详细]
  • 优化联通光猫DNS服务器设置
    本文详细介绍了如何为联通光猫配置DNS服务器地址,以提高网络解析效率和访问体验。通过智能线路解析功能,域名解析可以根据访问者的IP来源和类型进行差异化处理,从而实现更优的网络性能。 ... [详细]
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社区 版权所有