如果你熟悉比特币,你可能知道怎么创建一个用来接收支付的地址(以及相应的 QR 码)。而且这样的地址也是可以重复使用的,虽然重复使用相同的地址不是一种值得推荐的习惯但这是一种人们习惯的用户体验,也有特定的用途。
一个网络中的计算机依据协议跟彼此交流。在这里,“协议” 指的是一套规则系统,指定了消息应该如何传输和解读。闪电网络协议中的支付消息传输部分由 BOLT4 描述,也叫 “洋葱路由协议(Onion Rounting Protocol)”。
本文详细介绍了闪电网络中洋葱路由的工作原理,包括其在保护支付隐私方面的作用,以及如何通过分层加密和密钥交换来确保中间节点只能获取必要的信息。文章还涵盖了构建和转发洋葱消息的具体步骤,以及错误处理机制。
在本文中,我们会讲解 HTLC 工作的方式,并使用一个例子来展示多跳支付是如何在闪电网络中实现的。
闪电网络是一种去中心化的链下技术方案,可支持每秒上万笔交易并发,接近于 Visa 系统能做到的程度(举个例子)。
现在,他们想要在通道中放入一个哈希时间锁合约(HTLC),以确保 Bob 在用 1btc 交换 Carol 手中的秘密值后,Bob 可以从 Alice 那里取回 1btc。
在上一篇文章中,Alice 和 Bob 建立了一个双向的支付通道。现在,Alice 想要给一个第三方 Carol 支付 1 btc。
本系列的第一篇文章将列举必要的模块并展示这些模块如何能组合起来创建 “智能合约”;这个概念可以用来理解闪电网络的第一个前提:双向的支付通道。
在本篇中,我们将学习闪电支付通道和闪电网络是如何实现的,并在此基础上了解其它的以脚本实现的特性。
“哈希锁” 也称 “哈希原像检查”,也就是检查某个传入的数据的哈希值是否为某一值。