CN116057920A - 连接到区块链网络 - Google Patents
连接到区块链网络 Download PDFInfo
- Publication number
- CN116057920A CN116057920A CN202180057606.7A CN202180057606A CN116057920A CN 116057920 A CN116057920 A CN 116057920A CN 202180057606 A CN202180057606 A CN 202180057606A CN 116057920 A CN116057920 A CN 116057920A
- Authority
- CN
- China
- Prior art keywords
- blockchain
- transaction
- party
- blockchain transaction
- server
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Pending
Links
- 238000000034 method Methods 0.000 claims abstract description 126
- 238000012545 processing Methods 0.000 claims description 20
- 238000012546 transfer Methods 0.000 claims description 15
- 230000005540 biological transmission Effects 0.000 claims description 11
- 230000004044 response Effects 0.000 claims description 6
- 238000004590 computer program Methods 0.000 claims description 3
- 230000001419 dependent effect Effects 0.000 claims 4
- 238000013515 script Methods 0.000 description 65
- 230000006870 function Effects 0.000 description 18
- 238000004891 communication Methods 0.000 description 10
- 230000003287 optical effect Effects 0.000 description 10
- 230000008569 process Effects 0.000 description 10
- 230000009471 action Effects 0.000 description 8
- 230000001902 propagating effect Effects 0.000 description 6
- 238000010586 diagram Methods 0.000 description 5
- 230000000644 propagated effect Effects 0.000 description 4
- 238000013475 authorization Methods 0.000 description 3
- 238000013479 data entry Methods 0.000 description 3
- 238000005065 mining Methods 0.000 description 3
- 238000012795 verification Methods 0.000 description 3
- 238000003491 array Methods 0.000 description 2
- 238000004422 calculation algorithm Methods 0.000 description 2
- 238000005516 engineering process Methods 0.000 description 2
- 230000008520 organization Effects 0.000 description 2
- 239000007787 solid Substances 0.000 description 2
- 238000012360 testing method Methods 0.000 description 2
- 238000010200 validation analysis Methods 0.000 description 2
- 230000004075 alteration Effects 0.000 description 1
- 238000013459 approach Methods 0.000 description 1
- 238000012550 audit Methods 0.000 description 1
- 230000006399 behavior Effects 0.000 description 1
- 230000003139 buffering effect Effects 0.000 description 1
- 238000004364 calculation method Methods 0.000 description 1
- 230000001413 cellular effect Effects 0.000 description 1
- 230000008859 change Effects 0.000 description 1
- 238000009795 derivation Methods 0.000 description 1
- 238000001514 detection method Methods 0.000 description 1
- 230000008571 general function Effects 0.000 description 1
- 230000003993 interaction Effects 0.000 description 1
- 230000002452 interceptive effect Effects 0.000 description 1
- 238000007726 management method Methods 0.000 description 1
- 230000006855 networking Effects 0.000 description 1
- 230000002085 persistent effect Effects 0.000 description 1
- 238000013138 pruning Methods 0.000 description 1
- 230000001105 regulatory effect Effects 0.000 description 1
- 230000000007 visual effect Effects 0.000 description 1
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q20/00—Payment architectures, schemes or protocols
- G06Q20/02—Payment architectures, schemes or protocols involving a neutral party, e.g. certification authority, notary or trusted third party [TTP]
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L9/00—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
- H04L9/06—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols the encryption apparatus using shift registers or memories for block-wise or stream coding, e.g. DES systems or RC4; Hash functions; Pseudorandom sequence generators
- H04L9/0618—Block ciphers, i.e. encrypting groups of characters of a plain text message using fixed encryption transformation
- H04L9/0637—Modes of operation, e.g. cipher block chaining [CBC], electronic codebook [ECB] or Galois/counter mode [GCM]
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/01—Protocols
- H04L67/02—Protocols based on web technology, e.g. hypertext transfer protocol [HTTP]
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/01—Protocols
- H04L67/10—Protocols in which an application is distributed across nodes in the network
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/01—Protocols
- H04L67/10—Protocols in which an application is distributed across nodes in the network
- H04L67/104—Peer-to-peer [P2P] networks
- H04L67/1061—Peer-to-peer [P2P] networks using node-based peer discovery mechanisms
- H04L67/1063—Discovery through centralising entities
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/01—Protocols
- H04L67/10—Protocols in which an application is distributed across nodes in the network
- H04L67/104—Peer-to-peer [P2P] networks
- H04L67/1087—Peer-to-peer [P2P] networks using cross-functional networking aspects
- H04L67/1091—Interfacing with client-server systems or between P2P systems
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q2220/00—Business processing using cryptography
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Computing Systems (AREA)
- Computer Security & Cryptography (AREA)
- Business, Economics & Management (AREA)
- Accounting & Taxation (AREA)
- Strategic Management (AREA)
- Physics & Mathematics (AREA)
- General Business, Economics & Management (AREA)
- General Physics & Mathematics (AREA)
- Theoretical Computer Science (AREA)
- Financial Or Insurance-Related Operations Such As Payment And Settlement (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
- Management, Administration, Business Operations System, And Electronic Commerce (AREA)
Abstract
一种用于将区块链事务传输到区块链网络的计算机实现的方法,其中所述方法由第一方(402a)执行,并且所述方法包括:通过互联网服务器主持的互联网服务将区块链事务的至少一部分传输到互联网服务器(401),其中所述互联网服务器(401)被配置为连接到所述区块链网络(106)的一个或多个节点,并将区块链事务传输到所述一个或多个区块链节点,其中所传输的区块链事务包括所述区块链事务的所述至少一部分。
Description
技术领域
本公开涉及改进用户(或其他实体)到区块链网络的连接性。
背景技术
区块链是指一种分布式数据结构,其中在分布式对等(P2P)网络(以下称为“区块链网络”)中的多个节点中的每个节点处维护区块链的副本,并且广泛公开该副本。区块链包括一系列数据区块,其中每个区块包括一个或多个事务(transaction)。除所谓的“coinbase事务”外,每个事务都指向序列中的先前事务,该序列可以跨越一个或多个区块,回到一个或多个coinbase事务。coinbase事务将在下文进一步讨论。提交给区块链网络的事务包括在新区块中。新区块的创建过程通常称为“挖掘”,该过程涉及多个节点中的每个节点争相执行“工作量证明”,即,基于等待被包括在区块链的新区块中的一组定义的有序且核实有效的未决事务的表示解决加密难题。应当注意的是,区块链可以在一些节点处被修剪(prune),并且区块的发布可以通过仅发布区块头来实现。
区块链中的事务可用于以下目的中的一个或多个:传送数字资产(即,一定数量的数字通证);对虚拟化分类账或注册表中的一组条目进行排序;接收和处理时间戳条目;和/或对索引指针按时间排序。也可利用区块链实现区块链上的层级附加功能。例如,区块链协议可允许在事务中存储附加的用户数据或数据索引。能够存储在单个事务中的最大数据容量没有预先指定的限制,因此可以并入越来越复杂的数据。例如,这可用于在区块链中存储电子文档、音频或视频数据。
区块链网络的节点(通常称为“矿工”)执行分布式事务注册和验证过程,这将后续更详细地描述。总之,在该过程中,节点核实事务并将这些事务插入到区块模板中,这些事务尝试为该区块模板标识有效的工作量证明解。一旦找到有效的解,新区块便会被传播到网络的其它节点,从而使得每个节点能够在区块链上记录新区块。为了将事务记录在区块链中,用户(例如,区块链客户端应用程序)将该事务发送到网络中的节点中的一个节点进行传播。接收该事务的节点可以争相寻找将核实有效的事务并入新区块的工作量证明解。每个节点被配置为执行相同的节点协议,该协议将包括用于确认事务有效的一个或多个条件。无效事务将不会传播或并入到区块中。假定事务已经核实有效,从而在区块链上被接受,则该事务(包括任何用户数据)将因此在区块链网络中的每个节点上作为不可改变的公共记录进行注册和索引。
成功解决工作量证明难题可创建最新区块的节点通常被奖励一个称为“coinbase事务”的新事务,该事务分发数字资产数额,即通证数量。无效事务的检测和拒绝是通过竞争节点的行动来执行的,这些竞争节点充当网络的代理并且通过激励报告和阻止不正当行为。信息的广泛发布使得用户可以连续地审计节点的性能。仅发布区块头使得参与者可以确保区块链具有持续完整性。
在“基于输出的”模型(有时称为基于UTXO的模型)中,给定事务的数据结构包括一个或多个输入和一个或多个输出。任何可花费输出包括指定数字资产数额的元素,该元素可从进行中的事务序列导出。可花费输出有时称为UTXO(“未花费事务输出”)。输出还可以包括锁定脚本,该锁定脚本指定输出的未来赎回条件。锁定脚本是限定核实和传送数字通证或资产所必需的条件的谓词。事务(除coinbase事务之外)的每个输入包括指向先前事务中的此类输出的指针(即引用),并且还可以包括解锁脚本,用于解锁指向输出的锁定脚本。因此,考虑一对事务,将其称为第一事务和第二事务(或“目标”事务)。第一事务包括指定数字资产数额的至少一个输出,并且包括定义解锁该输出的一个或多个条件的锁定脚本。第二目标事务包括至少一个输入和解锁脚本,该至少一个输入包括指向第一事务的输出的指针;该解锁脚本用于解锁第一事务的输出。
在此类模型中,当第二目标事务被发送到区块链网络以在区块链中传播和记录时,在每个节点处应用的有效性条件之一将是解锁脚本满足在第一事务的锁定脚本中定义的一个或多个条件中的所有条件。另一条件将是第一事务的输出尚未被另一早期有效事务赎回。根据这些条件中的任何一个条件发现目标事务无效的任何节点都不会传播该事务(作为有效事务,但可能注册无效事务),也不将该事务包括在要记录在区块链中的新区块中。
另一种事务模型是基于账户的模型。在这种情况下,每个事务均不通过参考过去事务序列中先前事务的UTXO来定义转移的数额,而是通过参考绝对账户余额进行定义。所有账户的当前状态由节点单独存储到区块链中,并不断更新。
发明内容
用户(以及其他类型的参与方,例如组织、自主实体等)通常直接与区块链网络的一个或多个区块链节点连接。也就是说,操作客户端应用程序的用户可以与区块链节点连接,例如以便向所述网络提交事务、从区块链获取事务、查询是否存在特定未花费事务输出(UTXO)等。为了执行这些操作,需要所述用户与所述一个或多个节点之间的可靠连接。因此,需要提高用户与节点之间的连接性,以确保保持到所述区块链网络的可靠连接。
例如,考虑以下场景,即操作轻量级客户端应用程序的用户(例如,爱丽丝)试图向所述区块链网络提交事务,或者查询是否存在另一用户(例如,鲍勃)正在试图分配给爱丽丝的一个或多个UTXO,例如以换取商品或服务。如果爱丽丝无法连接到所述区块链网络,她就无法发送所述事务,或者她可能无法验证鲍勃并未试图重复花费已由已核实事务引用的UTXO。当然,这取决于具体情况,因为存在其他方式来验证UTXO,具体取决于是否有附加信息可用(例如,UTXO的默克尔路径)。爱丽丝可能无法连接到区块链节点,原因可能是到所述节点本身的连接存在问题,或者爱丽丝通常连接的节点不再充当所述网络上的节点。
根据本文公开的一个方面,提供了一种用于将区块链事务传输到区块链网络的计算机实现的方法,其中所述方法由第一方执行,并且所述方法包括:通过互联网服务器主持(host)的互联网服务将区块链事务的至少一部分传输到所述互联网服务器,其中所述互联网服务器被配置为连接到所述区块链网络的一个或多个节点,并将区块链事务传输到所述一个或多个区块链节点,其中所传输的区块链事务包括所述区块链事务的所述至少一部分。
根据本文公开的另一方面,提供了一种用于将区块链事务传输到区块链网络的计算机实现的方法,其中所述方法由互联网服务器执行,所述互联网服务器被配置为连接到一个或多个区块链节点,并且所述方法包括:通过所述互联网服务器主持的互联网服务从第一方接收区块链事务的至少一部分;以及,将区块链事务传输到所述一个或多个区块链节点,其中所述区块链事务包括所述区块链事务的所述至少一部分。
所述第一方(例如,爱丽丝)形成到互联网服务器(例如,Web服务器或邮件服务器)的连接,所述互联网服务器连接到一个或多个区块链节点。因此,爱丽丝不需要直接连接到所述区块链网络,而是可以利用可能具有到一个或多个节点的永久连接的所述互联网服务器。所述互联网服务器充当爱丽丝与所述区块链网络之间的网关。爱丽丝不需要依赖其到所述网络的一个或多个连接,而是可以利用所述互联网服务器,所述互联网服务器可以保持到不同节点的许多相应连接。如果所述服务器遇到一个或多个特定连接问题,或者所述节点中的一个或多个节点已从所述区块链网络中断开,则所述服务器可以转而通过一个或多个不同节点将爱丽丝的事务路由到所述网络。
在一些实例中,所述互联网服务器可以通过至少一个节点来保持到所述区块链网络的永久连接,例如通过在给定时间段内保持到同一节点的连接,或者通过在所述时间段内的不同时间点处保持到不同节点的连接。
在一些实施例中,所述互联网服务可以是社交媒体网站等Web页面。所述Web页面可以具有嵌入式功能,其被配置为接收或生成事务的一个或多个组件,例如使用爱丽丝的私钥生成的签名。所述一个或多个事务组件或完整的事务然后被发送到主持所述Web页面的所述服务器,所述服务器然后将所述事务转发到所述区块链网络。根据特定设置,所述服务器可以通过使用提供给所述Web页面或由所述Web页面生成的组件填充事务模板等来生成所述事务本身。
在其他实施例中,所述互联网服务可以是邮件服务,即电子邮件应用程序。所述电子邮件应用程序也可以具有嵌入式功能,所述功能使用户能够从所述应用程序内部与所述区块链网络交互。如下所述,主持所述电子邮件应用程序的所述邮件服务器可以维护与爱丽丝链接或通过其他方式对爱丽丝已知的对等体(联系者)列表,所述对等体(联系者)也操作区块链客户端应用程序。相应的公钥或区块链地址(例如,公钥哈希)可以与爱丽丝的联系者相关联地存储。这可以用于向爱丽丝指示其可以将数字资产分配给她的哪些联系者,以及为了这样做而使用其联系者的哪个区块链地址。应当注意的是,这些示例类似地应用于上述Web页面实现方式。
根据本文公开的另一方面,提供了一种用于发现区块链网络的一个或多个区块链节点的计算机实现的方法,其中互联网服务器维护标识符列表,每个标识符与相应的区块链节点相关联,并且其中所述方法包括:从所述互联网服务器获取一个或多个标识符,每个标识符与相应的区块链节点相关联;以及使用所述获取的一个或多个标识符连接到所述相关联的一个或多个区块链节点。
附图说明
为了帮助理解本公开的实施例并示出如何实施此类实施例,现将仅通过举例的方式参考附图进行说明,其中:
图1是一种用于实现区块链的系统的示意性框图;
图2示意性地示出了可记录在区块链中的事务的一些示例;
图3A示出了客户端应用程序的示意性框图;
图3B示出了可由图3A的客户端应用程序表示的示例性用户界面的示意性模型;
图4示出了用于实现本发明实施例的示例性系统的示意性框图;
图5示意性地示出了根据本发明实施例的从用户到区块链网络的区块链事务的流程;
图6示出了本发明的示例性实施例的序列图;以及
图7示出了本发明的不同示例性实施例的序列图。
具体实施方式
示例性系统概述
图1示出了一种用于实现区块链150的示例性系统100。系统100可以包括分组交换网络101,通常是诸如互联网的广域互联网。分组交换网络101包括多个区块链节点104,该多个区块链节点可以被设置成在分组交换网络101内形成对等(P2P)网络106。虽然未示出,但是区块链节点104可以被设置为近完全图。因此,每个区块链节点104高度连接到其它区块链节点104。
每个区块链节点104包括对等体的计算机设备,不同的节点104属于不同的对等体。每个区块链节点104包括处理装置,该处理装置包括一个或多个处理器,例如一个或多个中央处理单元(CPU)、加速器处理器、专用处理器和/或现场可编程门阵列(FPGA),以及其它设备,例如专用集成电路(ASIC)。每个节点还包括存储器,即采用非暂时性计算机可读介质形式的计算机可读存储器。存储器可包括一个或多个存储器单元,其采用一个或多个存储器介质,例如诸如硬盘等磁介质、诸如固态硬盘(SSD)、闪存或电可擦可编程只读存储器(EEPROM)等电子媒介和/或诸如光盘驱动器等光学介质。
区块链150包括一系列数据区块151,其中在分布式或区块链网络106中的多个区块链节点104中的每个节点处维护区块链150的相应副本。如上所述,维护区块链150的副本不一定意味着完全存储区块链150。相反,只要每个区块链节点150存储每个区块151的区块头(下面讨论),区块链150就可以进行数据修剪。区块链中的每个区块151均包括一个或多个事务152,其中该上下文中的事务是指一种数据结构。数据结构的性质将取决于用作事务模型或计划的一部分的事务协议类型。给定的区块链全程使用一个特定的事务协议。在一种常见的事务协议中,每个事务152的数据结构至少包括一个输入和至少一个输出。每个输出指定将数字资产的数量表示为财产的数额,其一个示例是输出被密码锁定到的用户103(需要该用户的签名或其它解进行解锁,从而进行赎回或花费)。每个输入指向先前事务152的输出,从而链接这些事务。
每个区块151还包括区块指针155,其指向区块链中先前创建的区块151,以定义区块151的顺序。每个事务152(除coinbase事务之外)包括指向上一事务的指针,以定义事务序列的顺序(注:事务152的序列可进行分支)。区块151的区块链一直追溯到创始区块(Gb)153,该创始区块是区块链中的第一区块。区块链150中早期的一个或多个原始事务152指向创始区块153,而非先前事务。
每个区块链节点104被配置为将事务152转发到其它区块链节点104,从而使得事务152在整个网络106中传播。每个区块链节点104被配置为创建区块151,并将相同区块链150的相应副本存储在其相应的存储器中。每个区块链节点104还维护等待并入到区块151中的事务152的有序集(或“池”)154。有序池154通常称为“内存池”。在本文中,该术语并不意在限制于任何特定的区块链、协议或模型。该术语是指节点104已接受为有效的有序事务集,并且对于该有序事务集,强制节点104不接受试图花费相同输出的任何其它事务。
在给定的当前事务152j中,输入(或每个输入)包括指针,该指针引用事务序列中先前事务152i的输出,指定该输出将在当前事务152j中被赎回或“花费”。通常,先前事务可以是有序集154或任何区块151中的任何事务。尽管为了确保当前事务有效,将需要存在先前事务152i并核实其有效,但是在创建当前事务152j甚至向网络106发送当前事务152j时,不必存在先前事务152i。因此,在本文中,“先前”是指由指针链接的逻辑序列中的前任,而不一定是时间序列中的创建时间或发送时间,因此,不一定排除无序创建或发送事务152i、152j的情况(参见下面关于孤立事务的讨论)。先前事务152i同样可以称为先行事务或前任事务。
当前事务152j的输入还包括输入授权,例如先前事务152i的输出被锁定到的用户103a的签名。反过来,当前事务152j的输出可以加密锁定到新用户或实体103b。因此,当前事务152j可将先前事务152i的输入中定义的数额转移到当前事务152j的输出中定义的新用户或实体103b。在某些情况下,事务152可具有多个输出,以在多个用户或实体间分割输入数额(其中一个可以是原始用户或实体103a,以便进行变更)。在某些情况下,事务还可以具有多个输入,将一个或多个先前事务的多个输出中的数额汇总在一起,并重新分配到当前事务的一个或多个输出。
根据基于输出的事务协议,例如比特币,当诸如个体用户或组织这类的一方103希望颁布新的事务152j时(由该方采用的自动程序或人为地),该颁布方将该新事务从其计算机终端102发送到接收者。颁布方或接收者将最终向网络106的一个或多个区块链节点104(现在通常是服务器或数据中心,但原则上也可以是其它用户终端)发送该事务。另外还不排除颁布新事务152j的一方103可以将事务直接发送到一个或多个区块链节点104,并且在一些示例中,可以不将事务发送到接收者。接收事务的区块链节点104根据在每个区块链节点104处应用的区块链节点协议来检查事务是否有效。区块链节点协议通常要求区块链节点104检查新事务152j中的加密签名是否与预期签名相匹配,这取决于事务152的有序序列中的上一事务152i。在这种基于输出的事务协议中,这可以包括检查新事务152j的输入中包括的一方103的密码签名或其它授权是否与新事务分配的先前事务152i的输出中定义的条件匹配,其中该条件通常包括至少检查新事务152j的输入中的密码签名或其它授权是否解锁新事务的输入所链接到的上一事务152i的输出。条件可以至少部分地由包括在先前事务152i的输出中的脚本来定义。或者,这可仅由区块链节点协议单独确定,或可通过其组合确定。无论采用哪种方式,如果新事务152j有效,区块链节点104会将其转发到区块链网络106中的一个或多个其它区块链节点104。这些其它区块链节点104根据相同的区块链节点协议应用相同的测试,并因此将新事务152j转发到一个或多个其它节点104等等。通过这种方式,新事务在区块链节点104的整个网络中进行传播。
在基于输出的模型中,给定输出(例如,UTXO)是否分配(例如,花费)的定义是,根据区块链节点协议,其是否通过另一个随后事务152j的输入有效赎回。事务有效的另一个条件是其试图赎回的先前事务152i的输出尚未被另一个事务赎回。同样,如果无效,则事务152j将不会在区块链150中传播(除非被标记为无效并且被传播用于提醒)或记录。这可防止重复花费,即事务处理者对同一个事务的输出分配超过一次。另一方面,基于账户的模型通过保持账户余额防止重复花费。因为同样存在定义的事务顺序,账户余额在任何时候均具有单一定义的状态。
除了核实事务有效之外,区块链节点104还争相成为在通常称为挖矿的过程中创建事务区块的第一个节点,而该过程由“工作量证明”支持。在区块链节点104处,新事务被添加到尚未出现在记录在区块链150上的区块151中的有效事务的有序池154。然后,区块链节点争相通过尝试解决加密难题以组装有序事务集154中事务152的新有效事务区块151。通常情况下,这包括搜索“随机数”值,从而当随机数与未决事务有序池154的表示并置且进行哈希处理时,哈希值的输出满足预定条件。例如,预定条件可以是哈希值的输出具有某个预定义的前导零数。注意,这仅仅是一种特定类型的工作量证明难题,并且不排除其它类型。哈希函数的特性是,相对于其输入,其具有不可预测的输出。因此,该搜索只能通过强力执行,从而在试图解决难题的每个区块链节点104处消耗大量的处理资源。
解决难题的第一区块链节点104在网络106上宣布难题解决,提供解决方案作为证明,然后网络中的其它区块链节点104则可以轻松检查该解决方案(一旦给出哈希值的解决方案,就可以直接检查该解决方案是否使哈希值的输出满足条件)。第一区块链节点104将一个区块传播到接受该区块的其它节点达成阈值共识,从而执行协议规则。然后,有序事务集154被每个区块链节点104记录为区块链150中的新区块151。区块指针155还分配给指向该区块链中先前创建的区块151n-1的新区块151n。创建工作量证明解所需的大量工作(例如采用哈希的形式)发出信号通知第一节点104的意图以遵循区块链协议。这些规则包括如果它分配与先前核实有效的事务相同的输出,则不接受事务为有效,否则称之为重复花费。一旦创建,区块151就不能修改,因为它在区块链网络106中的每个区块链节点104处进行标识和维护。区块指针155还向区块151施加顺序。由于事务152记录在网络106中每个区块链节点104处的有序区块中,因此提供了事务的不可改变公共分类账。
应当注意的是,在任何给定时间争相解决难题的不同区块链节点104可以基于在任何给定时间尚未发布的事务的池154的不同快照来这样做,具体取决于它们何时开始搜索解或接收事务的顺序。解决相应难题的人员首先定义新区块151n中包括的事务152及其顺序,并且更新当前的未发布事务池154。然后,区块链节点104继续争相从新定义的未发布事务有序池154中创建区块,等等。此外,还存在解决可能出现的任何“分叉”的协议,其中两个区块链节点104彼此在很短的时间内解决难题,从而在节点104之间传播区块链的冲突视图。简言之,分叉方向最长的成为最终区块链150。应当注意的是,这不会影响网络的用户或代理,因为同一事务将出现在两个分叉中。
根据比特币区块链(和大多数其它区块链),成功构造新区块104的节点被授予在分配附加限定数量数字资产的新特殊类型事务中新分配附加的、接受的数额的数字资产的能力(与代理间或用户间事务相反,该事务将一定数量的数字资产从一个代理或用户转移到另一个代理或用户)。这种特殊类型的事务通常称为“coinbase事务”,但是也可以称为“启动事务”或“产生事务”。它通常形成新区块151n的第一事务。工作量证明发出信号通知构造新区块的节点的意图以遵循协议规则,从而允许稍后赎回该特定事务。在可以赎回该特殊事务之前,区块链协议规则可能需要成熟期,例如100个区块。通常,常规(非生成)事务152还将在其输出中的一个输出中指定附加事务费用,以进一步奖励创建其中发布该事务的区块151n的区块链节点104。该费用通常称为“挖掘费用”,并在下文中讨论。
由于事务核实和发布中涉及的资源,通常至少每个区块链节点104采用包括一个或多个物理服务器单元的服务器的形式,或者甚至整个数据中心。但是,原则上来说,任何给定区块链节点104均可采用一个用户终端或联网在一起的一组用户终端的形式。
每个区块链节点104的存储器均存储被配置为在区块链节点104的处理装置上运行的软件,以根据区块链节点协议执行其相应的角色并处理事务152。应当理解的是,在本文中归因于区块链节点104的任何动作均可通过在相应计算机设备的处理装置上运行的软件执行。节点软件可以在应用层或诸如操作系统层或协议层的较低层或这些层任意组合的一个或多个应用中实现。
扮演消费用户角色的多方103中的每一方的计算机设备102也连接到网络101。这些用户可以与区块链网络106交互,但不参与核实事务或构造区块。其中一些用户或代理103可以充当事务中的发送者和接收者。其它用户可以与区块链150交互,而不必充当发送者或接收者。例如,一些当事方可以充当存储区块链150的副本(例如,已经从区块链节点104获得区块链的副本)的存储实体。
各方103中的一些或所有当事方可以作为不同网络的一部分连接,例如覆盖在区块链网络106之上的网络。区块链网络的用户(经常称为“客户端”)可以被称为是包含区块链网络106的系统的一部分;然而,这些用户不是区块链节点104,因为它们不执行区块链节点所需的角色。相反,每一方103可以与区块链网络106交互,从而通过连接到区块链节点106(即,与区块链节点106通信)来利用区块链150。出于说明目的,示出了双方103及其相应的设备102:第一方103a及其相应的计算机设备102a,以及第二方103b及其相应的计算机设备102b。应当理解的是,更多此类当事方103及其相应的计算机设备102可能存在并参与系统100,但为了方便起见,未进行说明。每一方103均可以是个人或组织。仅出于说明目的,在本文中,第一方103a称为爱丽丝,第二方103b称为鲍勃,但应当理解的是,这并不仅限于爱丽丝或鲍勃,且本文对爱丽丝或鲍勃的任何引用均可分别用“第一方”和“第二方”替换。
每一方103的计算机设备102包括相应的处理装置,其包括一个或更多个处理器,例如一个或更多个CPU、图形处理单元(GPU)、其他加速器处理器、特定应用程序处理器和/或FPGA。每一方103的计算机设备102还包括存储器,即采用非暂时性计算机可读介质形式的计算机可读存储器。该存储器可包括一个或更多个存储器单元,其采用一个或更多个存储器介质,例如诸如硬盘等磁介质、诸如SSD、闪存或EEPROM等电子媒介和/或诸如光盘驱动器等的光学介质。每一方103的计算机设备102上的存储器存储软件,其包括被设置为在处理装置上运行的至少一个客户端应用程序105的相应实例。应当理解的是,在本文中归因于给定方103的任何行动均可通过在相应计算机设备102的处理装置上运行的软件执行。每一方103的计算机设备102包括至少一个用户终端,例如台式或笔记本电脑、平板电脑、智能手机或诸如智能手表等的可穿戴设备。给定方103的计算机设备102还可包括一个或更多个其他网络资源,诸如通过用户终端访问的云计算资源。
客户端应用程序105最初可通过例如从服务器下载的适当计算机可读存储介质,或通过诸如可移动SSD、闪存密钥、可移动EEPROM、可移动磁盘驱动器、软盘或磁带等的可移动存储设备、诸如CD或DVD ROM等的光盘或可移动光驱等提供至任何给定方103的计算机设备102。
客户端应用程序105至少包括“钱包”功能。这有两个主要功能。其中一个功能是使相应方103能够创建、授权(例如签名)事务152并将其发送到一个或多个位比特币节点104,然后在区块链节点104的网络中传播,从而包括在区块链150中。另一个功能是向相应方汇报其目前拥有的数字资产数额。在基于输出的系统中,该第二功能包括整理分散在区块链150中属于相关方的各种事务152的输出中定义的数额。
注意:虽然各种客户端功能可以描述为集成到给定客户端应用程序105中,但这不一定是限制性的,相反,在本文中所描述的任何客户端功能可以在由两个或更多个不同应用程序组成的套件中实现,例如经由API进行接口连接或一个应用程序作为另一个应用程序的插件。更通俗地说,客户端功能可以在应用层或诸如操作系统的较低层或这些层的任意组合实现。下面将根据客户端应用程序105进行描述,但应当理解的是,这不是限制性的。
每个计算机设备102上的客户端应用程序或软件105的实例可操作地耦合到网络106的区块链节点104中的至少一个。这可以启用客户端105的钱包功能,以将事务152发送至网络106。客户端105还可联络区块链节点104,以在区块链150中查询相应方103作为接收者的任何事务(或实际上在区块链150中检查其它方的事务,因为在实施例中,区块链150是在某种程度上通过其公开可见性提供事务信任的公共设施)。每个计算机设备102上的钱包功能被配置为根据事务协议制定和发送事务152。如上所述,每个区块链节点104运行软件,该软件被配置为根据区块链节点协议核实事务152并转发事务152以便在区块链网络106中传播。事务协议和节点协议相互对应,给定事务协议和给定节点协议一起实现给定的事务模型。相同的事务协议用于区块链150中的所有事务152。网络106中的所有节点104使用相同的节点协议。
当给定方103(比方说爱丽丝)希望发送拟包含在区块链150中的新事务152j时,她将根据相关事务协议(使用其客户端应用程序105中的钱包功能)制定新事务。然后,她将事务152从客户端应用程序105发送到她所连接的一个或多个区块链节点104。例如,这可能是与爱丽丝的计算机102最佳连接的区块链节点104。当任何给定区块链节点104接收新事务152j时,其将根据区块链节点协议及其相应的角色进行处理。这包括首先检查新接收的事务152j是否满足变为“有效”的特定条件,具体示例稍后将详细讨论。在一些事务协议中,有效条件可通过事务152中包含的脚本在每个事务的基础上进行配置。或者,条件可仅仅是节点协议的内置功能,或通过组合脚本和节点协议进行定义。
如果新接收的事务152j通过有效性测试(即:“有效”的条件下),接收事务152j的任何区块链节点104将向在区块链节点104处维护的有序事务集154中添加新的核实有效事务152。进一步地,接收事务152j的任何区块链节点104随后将核实有效事务152传播至网络106中的一个或多个其它区块链节点104。由于每个区块链节点104应用相同的协议,因此假定事务152j有效,这意味着事务很快将在整个网络106中传播。
一旦进入在给定区块链节点104处维护的未决事务有序池154,该区块链节点104将开始争相解决其各自的包含新事务152的池154的最新版本上的工作量证明难题(请记住,其它区块链节点104可以尝试基于不同的事务池154来解决难题。但是,首先解决难题的人将定义包括在最新区块151中的事务集合。最终,区块链节点104将解决有序池154的一部分的难题,该有序集154包括爱丽丝的事务152j)。一旦包括新事务152j的池154完成工作量证明,其将不可变地成为区块链150中区块151中的一个区块的一部分。每个事务152包括指向早前事务的指针,因此事务的顺序也被不可变地记录下来。
不同的区块链节点104可以首先接收给定事务的不同实例,并且因此在一个实例被发布到新区块151中之前具有关于哪个实例“有效”的冲突视图,此时所有区块链节点104同意所发布的实例是唯一的有效实例。如果区块链节点104将一个实例接受为有效实例,然后发现第二实例已记录在区块链150中,则区块链节点104必须接受这一点,并将丢弃(即,视为无效)其最初接受的实例(即,在区块151中尚未公布的实例)。
作为基于账户的事务模型的一部分,由一些区块链网络操作的另一种类型的事务协议可称为“基于账户的”协议。在基于账户的情况下,每个事务均不通过参考过去事务序列中先前事务的UTXO来定义转移的数额,而是通过参考绝对账户余额进行定义。所有账户的当前状态由网络的节点单独存储到区块链中,并不断更新。在此类系统中,事务使用账户的运行事务记录(也称为“头寸”)进行排序。该值由发送者签名作为其加密签名的一部分,并作为事务引用计算的一部分进行哈希处理。此外,可选的数据字段也可以在事务中签名。例如,如果数据字段中包含上一事务的ID,该数据字段可指向上一事务。
基于UTXO的模型
图2示出了示例性事务协议。这是基于UTXO的协议的示例。事务152(简称“Tx”)是区块链150的基本数据结构(每个区块151包括一个或多个事务152)。下面将通过参考基于输出或基于“UTXO”的协议进行描述。但这并不限于所有可能的实施例。应当注意的是,虽然参考比特币描述了示例性基于UTXO的协议,但是它同样可以在其它示例区块链网络上实现。
在基于UTXO的模型中,每个事务(“Tx”)152包括数据结构,其包括一个或多个输入202和一个或多个输出203。每个输出203可包括未花费事务输出(UTXO),其可用作另一新事务的输入202的来源(如果UTXO尚未赎回)。UTXO包括指定数字资产数额的值。这表示分布式分类账上的一组通证。UTXO还可包含其来源事务的事务ID以及其它信息。事务数据结构还可包括标头201,其可包括输入字段202和输出字段203的大小指示符。标头201还可包括事务的ID。在实施例中,事务ID是事务数据(不含事务ID本身)的哈希值,且存储在提交至节点104的原始事务152的标头201中。
比方说爱丽丝103a希望创建转移相关数字资产数额至鲍勃103b的事务152j。在图2中,爱丽丝的新事务152j标记为“Tx1”。该新事务获取在序列中先前事务152i的输出203中锁定至爱丽丝的数字资产数额,并至少将此类数额中的一部分转移至鲍勃。在图2中,先前事务152i标记为“Tx0”。Tx0和Tx1只是任意的标记,其不一定意味着Tx0指区块链151中的第一事务且Tx1指池154中的下一事务。Tx1可指向仍具有锁定至爱丽丝的未花费输出203的任何先前(即先行)事务。
当爱丽丝创建其新事务Tx1时,或至少在她将该新事务发送至网络106时,先前事务Tx0可能已经有效并包括在区块链150的区块151中。该事务此时可能已包括在区块151中的一个区块中,或者可能仍在有序集154中等待,在这种情况下,该事务将很快包括在新区块151中。或者,Tx0和Tx1可以创建并一起发送至网络106;或者,如果节点协议允许缓冲“孤立”事务,Tx0甚至可以在Tx1之后发送。本文事务序列上下文中使用的“先前”和“后续”一词是指由事务中指定的事务指针定义的序列中的事务顺序(哪个事务指向哪个其他事务等等)。它们同样可以替换为“前任”和“继任”、“先行”和“后代”或“父项”和“子项”等。这不一定指其创建、发送至网络106或到达任何给定区块链节点104的顺序。然而,指向先前事务(先行事务或“父事务”)的后续事务(后代事务或“子事务”)不会有效除非父事务有效。在父事务之前到达区块链节点104的子事务被视为孤立事务。根据节点协议和/或节点行为,其可被丢弃或缓冲一段时间,以等待父事务。
先前事务Tx0的一个或更多个输出203中的一个包括特定的UTXO,标记为UTXO0。每个UTXO包括指定UTXO表示的数字资产数额的值以及锁定脚本,该锁定脚本定义后续事务的输入202中的解锁脚本必须满足的条件,以使后续事务有效,从而成功赎回UTXO。通常情况下,锁定脚本将数额锁定至特定方(该数额的事务的受益人)。即,锁定脚本定义解锁条件,该解锁条件通常包括以下条件:后续事务的输入中的解锁脚本包括先前事务被锁定到的一方的加密签名。
锁定脚本(亦称scriptPubKey)是节点协议识别的域特定语言中写入的一段代码。此类语言的特定示例称为“脚本(Script)”(S大写),其可由区块链网络所使用。锁定脚本指定花费事务输出203所需的信息,例如爱丽丝签名的要求。解锁脚本出现在事务的输出中。解锁脚本(亦称scriptSig)是提供满足锁定脚本标准所需信息的域特定语言中写入的一段代码。例如,其可包含鲍勃的签名。解锁脚本出现在事务的输入202中。
因此在示出的示例中,Tx0的输出203中的UTXO0包括锁定脚本[Checksig PA],该锁定脚本需要爱丽丝的签名Sig PA,以赎回UTXO0(严格来说,是为了使试图赎回UTXO0的后续事务有效)。[Checksig PA]包含爱丽丝的公私密钥对中的公钥PA的表示(即哈希)。Tx1的输入202包括指向Tx1的指针(例如,通过其事务ID(TxID0),其在实施例中是整个事务Tx0的哈希值)。Tx1的输入202包括在Tx0中标识UTXO0的索引,以在Tx0的任何其他可能输出中对其进行标识。Tx1的输入202进一步包括解锁脚本<Sig PA>,该解锁脚本包括爱丽丝的加密签名,该签名由爱丽丝通过将其密钥对中的私钥应用于预定的部分数据(有时在密码学中称为“消息”)创建。爱丽丝需要签名以提供有效签名的数据(或“消息”)可通过锁定脚本、节点协议或其组合进行定义。
当新事务Tx1到达区块链节点104时,该节点应用节点协议。这包括一起运行锁定脚本和解锁脚本,以检查解锁脚本是否满足锁定脚本中定义的条件(其中该条件可包括一个或更多个标准)。在实施例中,这涉及并置两个脚本:
<Sig PA><PA>||[Checksig PA]
其中“||”表示并置,“<…>”表示将数据放在堆栈上,“[…]”表示由锁定脚本组成的函数(在该示例中指基于堆栈的语言)。同样,脚本可以使用公共堆栈一个接一个地运行,而不是并置脚本。无论采用哪种方式,当一起运行时,脚本使用爱丽丝的公钥PA(包括在Tx0的输出的锁定脚本中),以认证Tx1的输入中的解锁脚本是否包含爱丽丝签名预期部分的数据时的签名。也需要包括预期的部分数据本身(“消息”),以便执行此认证。在实施例中,签名的数据包括整个Tx1(因此不需要包括一个单独的元素来明文指定签名的部分数据,因为其本身便已存在)。
本领域技术人员将熟悉通过公私密码进行验证的细节。基本上而言,如果爱丽丝已使用其私钥加密签署消息,则给定爱丽丝的公钥和明文中的消息,诸如节点104等其它实体可验证消息必须已经由爱丽丝签名。签署通常包括对消息进行哈希,签署哈希值和将此标记到消息作为签名,从而使公钥的任何持有者能够验证签名。因此,应当注意的是,在实施例中,在本文中对签名特定数据片段或事务部分等的任何引用可以意味着对该数据片段或事务部分的哈希值进行签名。
如果Tx1中的解锁脚本满足Tx0的锁定脚本中指定的一个或多个条件(因此,在所示示例中,如果在Tx1中提供了爱丽丝的签名并进行验证),则区块链节点104认为Tx1有效。这意味着区块链节点104会将Tx1添加到待定事务有序池154。区块链节点104还会将事务Tx1转发到网络106中的一个或多个其它区块链节点104,以便其会在整个网络106中传播。一旦Tx1有效并包括在区块链150中,这会将UTXO0从Tx0定义为已花费。应当注意的是,Tx1仅在花费未花费事务输出203时才有效。如果其试图花费另一事务152已经花费的输出,则即使满足所有其它条件,Tx1也将无效。因此,区块链节点104还需要检查先前事务Tx0中引用的UTXO是否已经花费(即,其是否已经形成另一有效事务的有效输入)。这是为何区块链150对事务152施加定义的顺序很重要的原因之一。在实践中,给定区块链节点104可维护单独的数据库,标记已花费事务152的UTXO 203,但最终定义UTXO是否已花费取决于是否在区块链150中形成了另一有效事务的有效输入。
如果给定事务152的所有输出203中指定的总数额大于其所有输入202所指向的总数额,则这是大多数事务模型中的另一失效依据。因此,此类事务不会传播或包括在区块151中。
请注意,在基于UTXO的事务模型中,给定UTXO需要作为一个整体使用。不能“留下”UTXO中定义为已花费的一部分数额,而同时又花费另一部分。但UTXO的数额可以在下一事务的多个输出之间分割。例如,Tx0的UTXO0中定义的数额可以在Tx1中的多个UTXO之间分割。因此,如果爱丽丝不想将UTXO0中定义的所有数额都给鲍勃,她可以使用剩余部分在Tx1的第二输出中自己找零,或者支付给另一方。
在实践中,爱丽丝通常还需要包括用于比特币节点104的费用,该比特币节点104在区块151中成功包含爱丽丝的事务104。如果爱丽丝未包括此类费用,则Tx0可能会被区块链节点104拒绝,并且因此尽管在技术上有效,但可能不会传播并且包括在区块链150中(如果区块链节点104不希望接受事务152,节点协议不强迫区块链节点104接受)。在一些协议中,事务费用不需要其自身的单独输出203(即不需要单独的UTXO)。相反,输入202指向的总数额与给定事务152的输出203指定的总数额之间的任何差额都将自动提供给发布事务的区块链节点104。例如,假设指向UTXO0的指针是Tx1的唯一输入,并且Tx1仅具有一个输出UTXO1。如果在UTXO0中指定的数字资产数额大于在UTXO1中指定的数额,则可以由赢得工作量证明竞赛以创建包含UTXO1的区块的节点104分配该差值。替代地或附加地,这不一定排除可以在其自身事务152的其中一个UTXO 203中明确指定事务费用。
爱丽丝和鲍勃的数字资产由区块链150中任何位置的任何事务152中的锁定至他们的UTXO组成。因此,通常情况下,给定方103的资产分散在整个区块链150的各种事务152的UTXO中。区块链150中的任何位置均未存储定义给定方103的总余额的一个数字。客户端应用程序105的钱包功能的作用是将锁定至相应方且在其它随后事务中尚未花费的各种UTXO值整理在一起。为实现这一点,其可以查询存储在任何一个位比特币节点104处的区块链150的副本。
应当注意的是,脚本代码通常用示意图表示(即使用非精确语言)。例如,可以使用操作码(opcode)来表示特定功能。“OP_...”是指脚本语言的特定操作码。举例来说,OP_RETURN是脚本语言操作码,当在锁定脚本的开始处在操作码前加上OP_FALSE时,操作码创建事务的不可花费输出,该输出可以在事务内存储数据,从而将数据不可改变地记录在区块链150中。例如,数据可包括需存储在区块链中的文件。
通常,事务的输入包含对应于公钥PA的数字签名。在实施例中,这基于使用椭圆曲线secp256k1的ECDSA。数字签名对特定的数据段进行签名。在实施例中,对于给定事务,签名将对部分事务输入以及部分或全部事务输出进行签名。对输出的特定部分进行签名取决于SIGHASH标志。SIGHASH标志通常是包含在签名末尾的4字节代码,用于选择签名的输出(并因此在签名时固定)。
锁定脚本有时称为“scriptPubKey”,指其通常包括相应事务被锁定到的当事方的公钥。解锁脚本有时称为“scriptSig”,指其通常提供相应的签名。但是更通俗地说,在区块链150的所有应用中,UTXO赎回的条件并不一定包括对签名进行验证。更通俗地说,脚本语言可用于定义任何一个或多个条件。因此,可以优选更为通用的术语“锁定脚本”和“解锁脚本”。
如图1所示,爱丽丝和鲍勃的计算机设备102a、120b中的每个计算机设备上的客户端应用程序都可以包括附加通信功能。此附加功能可使爱丽丝103a建立与鲍勃103b的单独侧信道301(在任何一方或第三方的鼓动下)。侧信道301使得能够脱离区块链网络交换数据。此类通信有时称为“链下”通信。例如,这可用于在爱丽丝与鲍勃之间交换事务152,而不将该事务(尚未)注册到区块链网络106上或将其发布到链150上,直到其中一方选择将其广播到网络106上。以这种方式共享事务有时称为共享“事务模板”。事务模板可能缺少形成完整事务所需的一个或多个输入和/或输出。替代地或附加地,侧信道301可用于交换任何其它事务相关数据,例如密钥、议付数额或条款、数据内容等。
通过与区块链网络106相同的分组交换网络101可建立侧信道301。替代地或附加地,侧信道301可以经由诸如移动蜂窝网络的不同网络或者诸如无线局域网络的局域网建立,甚至经由爱丽丝和鲍勃的设备102a、102b之间的直接有线或无线链路建立。通常,在本文中任何地方所指的侧信道301可以包括经由一项或多项联网技术或通信介质的任何一条或多条链路,这些链路用于“链下”交换数据,即脱离区块链网络106交换数据。在使用多条链路的情况下,链下链路束或集合整体上可以称为侧信道301。因此,应当注意的是,如果说爱丽丝和鲍勃通过侧信道301交换某些信息或数据等,则这不一定意味着所有这些数据都必须通过完全相同的链路或甚至相同类型的网络发送。
客户端软件
图3A示出了用于实现本公开方案的实施例的客户端应用程序105的示例性实施方式。客户端应用程序105包括事务引擎301和用户界面(UI)层302。根据上文讨论的方案以及稍后将进一步详细讨论的内容,事务引擎301被配置为实现客户端105的基础事务相关功能,诸如制定事务152,通过侧信道107接收和/或发送事务和/或其他数据,和/或发送事务至一个或更多个节点104以通过区块链网络106传播。
该UI层302被配置为通过相应用户的计算机设备102的用户输入/输出(I/O)方式呈现用户界面,包括通过设备102的用户输出方式向相应用户103输出信息,和通过设备102的用户输入方式接收来自相应用户103的输入。例如,用户输出方式可包括提供视觉输出的一个或显示多个屏(触摸或非触摸屏)、提供音频输出的一个或更多个扬声器、和/或提供触觉输出的一个或更多个触觉输出设备等。用户输入方式可包括例如一个或更多个触摸屏的输入阵列(可与用于输出方式的那个/那些相同或不同);一个或更多个基于光标的设备,诸如鼠标、轨迹板或轨迹球;一个或更多个麦克风和语音或声音识别算法,用于接收语音或声音输入;一个或更多个基于手势的输入设备,用于接收手动或身体手势形式的输入;或者一个或更多个机械按钮、开关或控制杆等。
注:虽然本文中的各种功能可以被描述为集成到同一客户端应用程序105中,但这并不一定构成限制,相反,它们可以在两个或更多个不同应用程序组成的一套程序中实现,例如一个应用程序作为另一个应用程序的插件或经由API(应用程序编程接口)进行接口。比如,事务引擎301的功能可以在单独的应用程序中实现,而不是在UI层302中实现,或者诸如事务引擎301的给定模块的功能可以在多个应用程序之间分割。同时,也不排除部分或全部描述的功能可以在比如操作系统层实现。在本文任何位置引用单个或给定应用程序105或诸如此类的情况下,应当理解的是这只是作为示例,并且更通俗地说,所描述的功能可以在任何形式的软件中实现。
图3B给出了用户界面(UI)300的示例的模型,该UI可由客户端应用程序105a的UI层302在爱丽丝的设备102a上呈现。应当理解的是,类似的UI可以由客户端105b在鲍勃的设备102b或任何其他方的设备上呈现。
通过图示的方式,图3B从爱丽丝的角度示出了UI 300。该UI 500可包括一个或更多个UI元素304、305、306,该一个或更多个UI元素通过用户输出方式呈现为不同的UI元素。
例如,UI元素可包括一个或更多个用户可选择的元素304,这些元素可以是屏幕上的不同按钮、菜单中的不同选项或者诸如此类。用户输入方式被设置成使用户103(在这种情况下为爱丽丝103a)能够选择或以其它方式操作其中一个选项,诸如通过点击或触摸屏幕上的UI元素,或者说出所需选项的名称(注:本文使用的“手动”一词仅用于与自动进行对比,而不一定限于用手执行操作)。这些选项使得用户(例如,爱丽丝)能够传递数据至互联网服务器(例如一些或全部的区块链事务)或生成签名。
此外/或者,UI元素可包括一个或更多个数据输入字段305,用户通过该字段能够进入诸如签名或区块链地址等数据。这些数据输入字段通过用户输出方式呈现,例如屏幕上,并且数据可通过用户输入方式输入到字段中,例如键盘或触摸屏。或者,数据可以例如基于语音识别口头地接收。
此外/或者,UI元素可包括向用户输出信息的一个或更多个信息元素306。例如,这/这些可以在屏幕上呈现或可听见。
应当理解的是,呈现各种UI元素、选择选项和输入数据的特定方式并不重要。这些UI元素的功能稍后将进行更详细地讨论。还应当理解的是,图3B中示出的UI 300只是一个图示模型,在实践中,它可包括一个或更多个进一步的UI元素,为了简洁起见,未对其进行说明。
连接到区块链网络
图4示出了用于实现本发明的实施例的示例性系统400。该系统包括互联网服务器401、第一方402a和区块链网络106,或者区块链网络106的至少一个或多个节点104。该系统还可以包括第二方402b。如结合图1所述,第一方402a和第二方402b中的每一个可以充当爱丽丝103a或鲍勃103b的角色。也就是说,第一方402a可以包括相应的计算设备102a并操作客户端应用程序105a,客户端应用程序105a被配置为执行与爱丽丝103a相关联的部分或全部动作。类似地,第二方402b可以包括相应的计算设备102b并操作客户端应用程序105b,客户端应用程序105b被配置为执行与鲍勃103b相关联的部分或全部动作。应当注意的是,第一方402a可以执行与鲍勃103b相关联的部分动作,反之亦然。
互联网服务器401包括处理装置,该处理装置包括一个或多个处理器,例如一个或多个中央处理单元(CPU)、加速器处理器、专用处理器和/或现场可编程门阵列(FPGA),以及其它设备,例如专用集成电路(ASIC)。互联网服务器401还包括存储器,即采用非暂时性计算机可读介质形式的计算机可读存储器。该存储器可包括一个或多个存储器单元,其采用一个或多个存储器介质,例如诸如硬盘等磁介质、诸如固态硬盘(SSD)、闪存或电可擦可编程只读存储器(EEPROM)等电子媒介和/或诸如光盘驱动器等光学介质。互联网服务器401上的存储器可以存储被设置为在处理装置上运行的软件。该软件最初可通过(例如,从服务器下载的)适当计算机可读存储介质,或通过诸如可移动SSD、闪存密钥、可移动EEPROM、可移动磁盘驱动器、软盘或磁带等可移动存储设备、诸如CD或DVD ROM等光盘或可移动光驱等提供至互联网服务器401。
互联网服务器本身是众所周知的,因此本文不再详细描述它们的一般功能。通常,互联网服务器401可以采用以下形式中的任何一种:数据库服务器、邮件服务器、Web服务器、游戏服务器或应用程序服务器。互联网服务器401可以采用不同的形式。数据库服务器是使用数据库应用程序的服务器,该数据库应用程序向其他计算机程序或计算机提供数据库服务。Web服务器是被配置为满足万维网上的客户端请求的服务器。Web服务器通常主持(host)一个或多个网站,并处理通过HTTP和若干其他相关协议传入的网络请求。应用程序服务器通常提供创建Web应用程序的设施和运行这些Web应用程序的服务器环境。游戏服务器(有时也称为主机)是作为多人视频游戏中事件的权威来源的服务器。服务器传输关于其内部状态的充足数据,以允许其连接的客户端维护其自己的游戏世界的准确版本,以向玩家显示。所连接的客户端还接收和处理每个玩家的输入。
互联网服务器401被配置为向其连接的客户端主持(即,服务)互联网服务。互联网服务器401主持的互联网服务的类型将取决于互联网服务器401的形式。如果互联网服务器401是Web服务器,则互联网服务将是网站,而如果互联网服务器401是邮件服务器,则互联网服务器将是邮箱。类似地,游戏服务器将主持在线视频游戏形式的互联网服务,数据库服务器将主持在线数据库形式的互联网服务,而应用程序服务器将主持通过互联网运行的应用程序形式的互联网服务。
为了向区块链网络提交区块链事务,第一方402a(即,第一方402a操作的客户端应用程序105a)被配置为通过互联网服务器401主持的互联网服务连接到互联网服务器401,而不是直接连接到一个或多个区块链节点104。第一方402a再次通过互联网服务向互联网服务器提供区块链事务的一个或多个组件。也就是说,第一方402a通过互联网服务将区块链事务的至少一部分传输到互联网服务器401。在一些示例中,第一方402a提供完整的区块链事务。在其他示例中,第一方402a传输区块链事务的一个或多个输入和/或一个或多个输出以填写事务模板。应当注意的是,传输输入或输出是指传输输入数据(例如,解锁脚本或解锁脚本的一部分)或输出数据(例如,锁定脚本或锁定脚本的一部分)。例如,第一方402a可以将使用第一方402a拥有的私钥生成的签名传输到互联网服务器401。又如,第一方402a可以提供公钥或公钥哈希,其可以与第一方402a或第二方402b链接。
互联网服务器401主持的互联网服务可以包括用于输入数据的一个或多个数据输入字段(即,输入字段)。第一方402a可以使用数据输入字段来输入事务数据,例如签名、公钥、事务标识符、事务输出点等。类似地,互联网服务可以包括用于生成事务数据的一个或多个功能,例如签名或公钥哈希。
应当注意的是,优选地,第一方402a具有与互联网服务器401的安全通信信道,和/或第一方402a使用一种或多种加密技术来维护安全和/或隐私。这些将在下面进行讨论。
互联网服务器401被配置为获取一个或多个事务组件,并将包括这些组件的事务传输到一个或多个区块链节点104。如果第一方402a提供了完整的事务,则互联网服务器401将该事务转发到区块链节点104。或者,互联网服务器401可以基于一个或多个事务组件来生成事务,例如通过将一个或多个组件(即,数据)输入到事务模板中。
图5示出了通过互联网服务器401从第一方402a到区块链网络的事务的示例性流程。如图所示,实际上可能存在由多个互联网服务器401提供服务的许多不同方402(例如,用户)。任何给定的互联网服务器401可以服务于单方402或多方402。类似地,互联网服务器401可以仅连接到一个区块链节点104,也可以连接到多个区块链节点104。
互联网服务器401可以通过到相应区块链节点104的一个或多个相应连接来维持到区块链网络106的永久连接。或者,互联网服务器401可以周期性地连接到一个或多个区块链节点104,或者互联网服务器401可以临时连接。
互联网服务器401可以维持到最小数量的区块链节点的连接。例如,如果连接数量降至预定义的最小值以下,则互联网服务器401可以连接到一个或多个附加节点,以将连接的数量至少恢复到预定义的最小值。
相反,第一方402a不需要具有到互联网服务器401的永久连接,而是可以(例如,在使用互联网服务时)通过互联网服务临时连接到互联网服务器401。然而,也不排除第一方402a可以通过互联网服务永久连接到互联网服务器401。
在系统400包括第二方402b的实施例中,第二方402b可以向第一方402a传输请求消息。该请求消息可以通过侧信道107等直接传输到第一方402a。或者,该请求消息可以通过互联网服务器401传输。也就是说,第二方402a可以使用互联网服务器401主持的互联网服务向互联网服务器401传输请求消息,然后互联网服务器401使用互联网服务将请求消息呈现给第一方402a。作为说明性示例,可以使用Web服务器401主持的网站(例如,社交媒体网站)来输入和呈现请求消息。
该请求消息可以包括将第一方402a拥有的多个数字资产分配给第二方402b的请求,例如以换取商品或服务。附加地或替代地,该请求消息可以包括区块链事务的一个或多个组件。例如,该请求消息可以包括锁定脚本,该锁定脚本包括链接到第二方402b的公钥(或其哈希)。
响应于接收到该请求消息,第一方402a可以将区块链事务(或区块链事务的至少一个或多个组件)传输到互联网服务器401。例如,第二方402b可以向第一方402a发送区块链地址(例如,通过互联网服务器401),并且第一方402a可以向互联网服务器401发送用于解锁UTXO的签名。然后,互联网服务器401可以基于这些组件制定事务以发送到区块链网络106。
应当注意的是,第一方402a可以执行已被描述为由第二方402b执行的与该请求消息相关联的任何动作,并进行任何必要的调整。也就是说,第一方402a可以向第二方402b发送请求消息,例如以向链接到第一方402a的区块链地址分配一定数额的数字资产。
在一些实施例中,在第一方402a向互联网服务器401发送区块链事务(或其一个或多个组件)之后,以及在互联网服务器401随后向区块链网络106提交区块链事务之后,互联网服务器401可以向第一方402a传输更新消息。该更新消息通过互联网服务呈现给第一方402a。
通常,该更新消息包括关于已提交到区块链网络106的事务的信息。该更新消息可以包括事务本身,即包括第一方402a提供并提交到网络106的一个或多个组件的事务的副本。作为附加或替代选项,该更新消息可以包括关于事务已成功发布在区块链150上的指示。该指示可以包括其中已包括该事务的区块151的区块头。在一些示例中,该更新消息可以包括用于验证事务已包括在区块151中的默克尔路径。默克尔路径包括一组哈希,该组哈希与事务的哈希一起用于计算默克尔树的默克尔根。如果使用事务的默克尔路径和哈希生成的默克尔根对应于区块链150的区块151的区块头,则第一方402a可以确定该事务包括在该区块151中。
作为另一可选特征,互联网服务器401可以被配置为维护与第一方402a相关联的联系者(即,其他方402)列表。对于每个联系者,互联网服务器401还可以记录与该联系者链接的(即,该联系者拥有的)一个或多个区块链地址(例如,公钥和/或公钥哈希)。互联网服务器401可以通过互联网服务将联系者列表和/或区块链地址传输到第一方402a。第一方402a可以使用该信息与第一方的联系者联系。从这个意义上来说,与联系者联系可以包括将第一方402a拥有的数字资产分配给其中一个联系者,例如第二方402b。
如上所述,互联网服务器401可以是主持Web服务的Web服务器,例如网站。也就是说,Web服务器401可以向第一方402a提供一个或多个Web页面。优选地,第一方402a(即,第一方402a操作的客户端应用程序)和Web服务器401使用超文本传输协议(HTTP)进行通信。例如,可以使用HTTP将事务(或其组件)传输到Web服务器401。类似地,可以使用HTTP将请求消息发送到Web服务器401/从Web服务器401发送请求消息。此外,还可以使用HTTP将更新消息从Web服务器401发送到第一方402a。虽然HTTP是优选的,但不排除可以使用替代协议在第一方402a与Web服务器之间发送数据,例如简单邮件传输协议(SMTP)或文件传输协议(FTP)。
或者,互联网服务器401可以是主持邮件服务的邮件服务器,例如电子邮件应用程序。从第一方402a的角度来看,邮件服务器可以是接收邮件服务器和/或发送邮件服务器。第一方402a和邮件服务器可以使用用于传出消息的一种简单邮件传输协议(SMTP)以及用于传入消息的邮局协议(POP)(例如,POP3)或互联网消息接入协议(IMAP)中的一种进行通信。
网站或电子邮件应用程序可以包括嵌入式功能,其被配置为将区块链事务或其组件分别提交给Web服务器或邮件服务器。例如,可以修改现有电子邮件应用程序,以包括被配置为接收和/或生成事务数据的数据输入字段或“按钮”。网站(例如,社交媒体网站或其他类型的Web页面)还可以包括采用类似方式配置的功能。
下面提供关于被配置为实现本发明实施例的Web服务器和邮件服务器的更多细节。
互联网服务器401可以是Web 2.0服务器。Web 2.0是指第二代万维网。Web 2.0为用户通过社交媒体、博客和其他基于Web的社区在线共享信息提供了交互式和动态的Web体验。虽然Web的后端基础设施保持不变,但是前端已通过AJAX和JavaScript框架等支持的Web浏览器技术进行丰富,以支持新的用户信息流和响应于用户输入的动态内容。
Web 2.0服务器(以及一般的Web服务器)可以用于将事务传播到区块链网络106上的区块链节点104。用户402a可以操作基于浏览器的客户端应用程序,该客户端应用程序可以操作简单支付验证(SPV)方法。该应用程序可以作为浏览器扩展出现在Web 2.0平台上,例如出现在社交媒体网站上。用户可以使用应用程序API创建事务。然后,该应用程序通过一个或多个Web 2.0服务器将事务传播到一个或多个区块链节点104。然后,这些区块链节点核实该事务,并且可以通过Web 2.0服务器等将更新发送回客户端应用程序。图5示意性地示出了该过程。
SPV客户端应用程序需要高级别的连接,因此可以利用本发明。由于敏感数据包括在将在区块链150上发布的事务中,因此这些应用程序有时还需要高度的安全性。因此,提交到Web服务器的数据可以由用户402a或由Web服务等加密。
使用Web服务器连接到区块链网络106还可以用于在网络发现期间引导新用户。基于URL Flux的命令与控制(UFCC)是使用Web 2.0服务进行通信的集中式架构。UFCC通过指向活动对等体的Web链接来管理网络中的对等体列表。这些链接通常上传到常见的Web 2.0服务,这些服务承诺24小时在线。对于SPV客户端应用程序,可以实现UFCC通信系统以在引导过程中与其他在线对等体连接(即,操作SPV客户端应用程序的相应实例)。
当加入区块链网络106时,区块链节点104可以使用类似的引导过程来发现其他区块链节点104。例如,区块链节点104可以下载其他区块链节点104的列表(例如,社交媒体账户上的联系人列表)以查看区块链网络106中的哪些区块链节点104处于活动状态(例如,“在线”),以便将事务广播到在线节点104。该列表由互联网服务器401维护,该互联网服务器401可以(例如,在请求时)将该列表传输到节点104。该列表可以包含标识符列表(例如,网络地址、公钥等)。每个标识符与不同的节点104相关联。
互联网服务器可以是邮件服务器。该邮件服务器可以用于以类似于电子邮件账户的方式服务客户端应用程序。该邮件服务器监控用户402(账户持有人)的地址(例如,公钥或公钥哈希),以合并UTXO并将账户信息存储在该邮件服务器上。当用户访问其账户时,可以向用户呈现该信息。
该邮件服务器可以是非监管的(non-custodial),即服务器不代表第一方402a存储数字密钥。服务器401可以将证明账户持有人(第一方402a)身份的了解客户(KYC)信息存档。该信息可以存储在链上或链下。例如,服务器401可以存储指向嵌入区块链事务中的数字身份证书的位置的指针。服务器401监控UTXO集中的相关事务ID,以确保用户的一个或多个认证密钥是最新的,即数字证书未过期。如果用户的认证密钥尚未过期,则服务器401可以仅将事务提交给区块链150。应当注意的是,这也可以应用于其他类型的互联网服务器401。
如上所述,当在互联网服务器401上传播事务时,可以使用加密技术来确保用户的安全和/或隐私。例如,第一方402a可以实现数字密钥管理,以在用于对各个事务进行签名的唯一数字密钥对之间循环,例如,同一密钥不会被多次用于对事务进行签名。类似地,第二方402b(例如,商家)可以通过请求第一方402a使用认证密钥对该事务进行签名来确保了解客户(KYC)和/或反洗钱(AML)的监管合规性。由于数字密钥对优选地仅使用一次,因此用户的数字密钥对可以使用从经认证的根密钥中导出的分层确定性密钥来加密地链接到他们的经认证身份,参见GB1913704.1等。应当注意的是,该方法还可以与秘密值分配方法相结合,以将共享秘密嵌入到密钥导出路径中,从而在发送者与接收者之间创建私有链接,参见WO/2017/145016等。又如,可以采取额外的措施来保护链接到较大资金的用户的私钥。用户可以部分地使用从私钥共享中导出的数字签名来对该事务进行签名。必须达到阈值数量的签名才能广播该完成事务。应当注意的是,完整的私钥(所有密钥份额的组合)永远不存在,这意味着它永远不会被恶意代理从用户的Web钱包中窃取。技术人员将熟悉阈值签名方案。最后,第一方402a可以使用加密的浏览器,由此可以根据HTTPS通信协议使用TLS客户端/服务器密钥加密对流量进行加密。这可以是用于Web钱包发行者的SSL服务器证书以及基于用户和服务器的椭圆曲线数字签名算法(ECDSA)密钥的SSL客户端证书。
图6和图7示出了本发明的示例性用例。图6示出了商家(第二方402b)使用区块链150向用户(第一方402a)销售产品。图7示出了商家使用区块链150接收用户对产品的退还(refund)请求。应当理解的是,该示例仅用于说明性目的,并且该技术可以更一般地应用于其他用例。也就是说,本发明实施例并不限于客户-商家类型的交互。
图6所示的序列如下所示。应当理解的是,其中一些步骤是可选的。在步骤1中,商家402b向互联网服务器401发送支付请求。该支付请求可以包括对一定数额的数字资产的请求。该支付请求可以包括锁定脚本或锁定脚本的一部分,用于将该一定数额的数字资产锁定到与商家402b相关联的区块链地址。应当注意的是,优选地,如果互联网服务器401由可信的第三方操作和/或使用安全通信信道,则该支付请求仅包括锁定脚本的一部分,而不是完整的锁定脚本。在步骤2中,互联网服务器401保存该请求,以便在客户上线(例如,访问Web服务或电子邮件应用程序)时发送给客户402a。在步骤3中,客户402a上线,并且互联网服务器401将该请求发送给客户402a。在步骤4中,客户402a响应该请求。客户402a可以拒绝该请求,并且因此将拒绝消息发送回互联网服务器401,然后该互联网服务器401将转发给商家402b。或者,如图6所示,客户402a可以接受该请求。这可以涉及客户将签名发送回互联网服务器401,例如用于解锁先前事务的UTXO的签名。
然后,互联网服务器401可以采用若干选项中的一个,其中两个选项被示出。在一个示例中,在步骤5a中,互联网服务器401将已签名事务直接发送到区块链网络106。例如,互联网服务器401可以使用包含在该支付请求中的数据和来自客户402a的签名以完善事务模板。在步骤6a和步骤7a中,互联网服务器401分别向商家402b和客户402a发送更新。该更新可以包括用于验证事务已包括在区块151中的默克尔路径,也可以包括与事务相关的其他数据。
在另一示例中,在步骤5b中,互联网服务器401将已签名事务发送给商家402b。在步骤6b中,商家可以在发送到互联网服务器401之前检查并最终确定事务,例如对事务进行签名。或者,如果商家具有到节点104的直接连接,则商家可以将事务提交到区块链网络106。在步骤7b中,互联网服务器401将事务发送到区块链网络106。在步骤8b和步骤9b中,互联网服务器401分别向商家402b和客户402a发送更新。
图7所示的序列如下所示。应当理解的是,其中一些步骤是可选的。图7的步骤与图6的步骤类似。在步骤1中,客户402a向互联网服务器401发送退还请求。该退还请求可以包括对一定数额的数字资产的请求。该退还请求可以包括锁定脚本或锁定脚本的一部分,用于将该一定数额的数字资产锁定到与客户402a相关联的区块链地址。对于该支付请求,优选地,如果互联网服务器401由可信的第三方操作和/或使用安全通信信道,则该退还请求仅包括锁定脚本的一部分,而不是完整的锁定脚本。在步骤2中,互联网服务器401保存该请求,以便在商家上线(例如,访问Web服务或电子邮件应用程序)时发送给商家402a。在步骤3中,商家402b上线,并且互联网服务器401将该请求发送给商家402b。互联网服务器401可以发送客户的认证密钥作为商家402b接受该请求的证明。在步骤4中,商家402b响应该请求。商家402b可以拒绝该请求,并且因此将拒绝消息发送回互联网服务器401,然后该互联网服务器401将转发给客户402a。或者,如图7所示,商家402a可以接受该请求。这可以涉及商家402b将签名发送回互联网服务器401,例如用于解锁先前事务的UTXO的签名。如果由商家402b发送,则互联网服务器401可以保存完整的事务和默克尔路径。或者,商家402b可以下载输入事务并查找默克尔路径。在步骤5中,互联网服务器401将已签名事务直接发送到区块链网络106。例如,互联网服务器401可以使用包含在该退还请求中的数据和来自商家402b的签名来填写事务模板。在步骤6和步骤7中,互联网服务器401分别向商家402b和客户402a发送更新。该更新可以包括用于验证事务已包括在区块151中的默克尔路径,也可以包括与事务相关的其他数据。
总而言之,现有的Web和邮件服务器基础设施可以用于提高用户(和其他方)402到区块链网络106的连接性。区块链事务可以通过Web服务器(例如,Web 2.0服务器)广播到区块链节点104。在将新用户引导到同样连接到Web或电子邮件服务的活动对等体的过程中,可以改进网络发现。本发明对于使用SPV方法(其中需要高度的网络连接性)的轻量级客户端应用程序尤其有利。由于轻量级客户端不需要访问整个区块链,因此事务可以通过Web或邮件服务传播。由于其典型的庞大用户群和24小时在线可用性,Web2.0服务(和其他互联网服务)在促进区块链客户端应用程序的事务传播方面非常有效。除基于HTTP的应用程序之外,SMTP和IMAP/POP协议也可以用于使用邮件服务器传播事务,类似于电子邮件账户。
结论
一旦给出本文的公开内容,所公开技术的其它变体或用例对于本领域技术人员可能变得显而易见。本公开的范围不受所描述的实施例限制,而仅受随附权利要求限制。
例如,上面的一些实施例已经根据比特币网络106、比特币区块链150和比特币节点104进行了描述。然而,应当理解的是,比特币区块链是区块链150的一个特定示例,并且上述描述通常可以应用于任何区块链。也就是说,本发明决不限于比特币区块链。更一般地,以上对比特币网络106、比特币区块链150和比特币节点104的任何引用可以分别参考区块链网络106、区块链150和区块链节点104来替换。区块链、区块链网络和/或区块链节点可以共享如上所述的比特币区块链150、比特币网络106和比特币节点104的部分或全部所述特性。
在本发明的优选实施例中,区块链网络106是比特币网络,并且比特币节点104至少执行对区块链150的区块151进行创建、发布、传播和存储中的所有所述功能。不排除可能存在仅执行这些功能中的一个或部分功能但不是全部功能的其它网络实体(或网络元件)。也就是说,网络实体可以执行传播和/或存储区块的功能,而不创建和发布区块(请记住,这些实体不被认为是优选的比特币网络106的节点)。
在本发明的非优选实施例中,区块链网络106可以不是比特币网络。在这些实施例中,不排除节点可以执行对区块链150的区块151进行创建、发布、传播和存储中的至少一个或部分功能但不是所有功能。例如,在这些其它区块链网络上,“节点”可用于指被配置为创建和发布区块151但不存储和/或传播这些区块151到其它节点的网络实体。
甚至更通俗地说,上面对术语“比特币节点”104的任何引用可以用术语“网络实体”或“网络元件”代替,其中这样的实体/元件被配置为执行对区块进行创建、发布、传播和存储中的一些或全部角色。这种网络实体/元件的功能可以在硬件中实现,方法与上面参照区块链节点104所述的方式相同。
应当理解的是,上述实施例仅通过示例的方式进行描述。更通俗地说,可根据下述任何一个或多个语句提供一种方法、装置或程序。
语句1.一种用于将区块链事务传输到区块链网络的计算机实现的方法,其中所述方法由第一方执行,并且所述方法包括:
通过互联网服务器主持(host)的互联网服务,将区块链事务的至少一部分传输到所述互联网服务器,其中所述互联网服务器被配置为连接到所述区块链网络的一个或多个节点,并将区块链事务传输到所述一个或多个区块链节点,其中所传输的区块链事务包括所述区块链事务的所述至少一部分。
语句2.根据语句1所述的方法,其中所述互联网服务器是Web服务器,并且其中所述互联网服务是Web服务。
语句3.根据语句2所述的方法,其中,所述区块链事务的所述至少一部分是使用超文本传输协议HTTP传输到所述Web服务器的。
语句4.根据语句1所述的方法,其中所述互联网服务器是邮件服务器,并且其中所述互联网服务是邮件服务。
语句5.根据语句4所述的方法,其中,所述区块链事务的所述至少一部分是使用简单邮件传输协议SMTP传输到所述邮件服务器的。
语句6.根据前述任一项语句所述的方法,其中所述互联网服务包括用于输入数据的输入字段,并且其中所述方法包括:通过所述输入字段输入所述区块链事务的所述至少一部分。
语句7.根据前述任一项语句所述的方法,所述方法包括:生成所述区块链事务的所述至少一部分。
语句8.根据语句1至6中任一项所述的方法,其中所述区块链事务的所述至少一部分由第二方生成。
语句9.根据前述任一项语句所述的方法,其中所述区块链事务的所述至少一部分包括由所述第一方和/或所述第二方生成的相应数字签名。
语句10.根据前述任一项语句所述的方法,其中所述区块链事务的所述至少一部分是完整的区块链事务。
语句11.根据前述任一项语句所述的方法,所述方法包括:通过所述互联网服务从所述互联网服务器接收请求消息,其中所述区块链事务的所述至少一部分的所述传输响应于所述请求消息的所述接收,并且其中所述请求消息包括:
将先前区块链事务的未花费事务输出分配给所述第二方的请求,所述请求源自所述第二方;和/或
所述第二方生成的所述区块链事务的所述至少一部分。
语句12.根据语句1至10中任一项所述的方法,所述方法包括:通过所述互联网服务向所述互联网服务器传输请求消息,其中所述区块链事务的所述至少一部分的所述传输响应于接收到对所述请求消息的响应,并且其中所述请求消息包括:
将先前区块链事务的未花费事务输出分配给所述第一方的请求,所述请求源自所述第一方;和/或
所述第一方生成的所述区块链事务的所述至少一部分。
语句13.根据前述任一项语句所述的方法,所述方法包括:通过所述互联网服务从所述互联网服务器接收更新消息,其中所述更新消息包括以下各项中的至少一项:
所述区块链事务;
一指示,其是关于所述区块链事务已在所述区块链的区块中发布;和/或
一默克尔路径,其用于验证所述区块链事务已包含在所述区块链的所述区块中。
所述请求消息可以使用HTTP发送和/或接收。所述更新消息可以使用HTTP接收。所述请求消息或所述更新消息可以使用邮局协议(POP)或因特网消息接入协议(IMAP)中的一种接收。所述请求消息可以使用SMTP发送。
语句14.根据前述任一项语句所述的方法,所述方法包括:通过所述互联网服务从所述互联网服务器接收与所述第一方相关联的联系者(contact)列表,其中对于所述列表中的每个联系者,所述列表包括与所述联系者相关联的相应一个或多个区块链地址。
语句15.根据语句14所述的方法,其中所述区块链事务的输出锁定到与所述联系者中的一个联系者相关联的区块链地址。
语句16.一种用于将区块链事务传输到区块链网络的计算机实现的方法,其中所述方法由互联网服务器执行,所述互联网服务器被配置为连接到一个或多个区块链节点,并且所述方法包括:
通过所述互联网服务器主持的互联网服务从第一方,接收区块链事务的至少一部分;以及
将区块链事务传输到所述一个或多个区块链节点,其中所述区块链事务包括所述区块链事务的所述至少一部分。
语句17.根据语句16所述的方法,其中所述互联网服务器是Web服务器,并且其中所述互联网服务是Web服务。
语句18.根据语句17所述的方法,其中所述区块链事务的所述至少一部分是使用超文本传输协议HTTP从所述第一方接收的。
语句19.根据语句16所述的方法,其中所述互联网服务器是邮件服务器,并且其中所述互联网服务是邮件服务。
语句20.根据语句19所述的方法,其中所述区块链事务的所述至少一部分是使用简单邮件传输协议SMTP从所述第一方接收的。
语句21.根据语句16至20中任一项所述的方法,所述方法包括:使用所述区块链事务的所述至少一部分来生成所述区块链事务。
语句22.根据前述任一项语句所述的方法,所述方法包括:
通过所述互联网服务从第二方接收请求消息;以及
通过所述互联网服务向所述第一方传输所述请求消息,其中所述请求消息包括:
将先前区块链事务的未花费事务输出分配给所述第二方的请求;和/
或
所述区块链事务的所述至少一部分,所述区块链事务的所述至少一部分由所述第二方生成。
语句23.根据前述任一项语句所述的方法,所述方法包括:通过所述互联网服务向所述第一方传输更新消息,其中所述更新消息包括以下各项中的至少一项:
所述区块链事务;
关于所述区块链事务已在区块链的区块中发布的指示;和/或
用于验证所述区块链事务已包含在所述区块链的所述区块中的默克尔路径。
语句24.根据从属于语句17的语句22所述的方法,其中所述请求消息是使用HTTP传输的。
语句25.根据从属于语句17的语句23所述的方法,其中所述更新消息是使用HTTP传输的。
语句26.根据从属于语句19的语句22所述的方法,其中所述请求消息是使用SMTP传输的。
语句27.根据从属于语句19的语句23所述的方法,其中所述更新消息是使用SMTP传输的。
语句28.根据语句16至27中任一项所述的方法,所述方法包括:
维护与所述第一方相关联的联系者列表,其中,对于每个联系者,所述联系者列表包括与所述联系者相关联的一个或多个区块链地址;以及将所述联系者列表传输给所述第一方。
语句29.一种用于发现区块链网络的一个或多个区块链节点的计算机实现的方法,其中互联网服务器维护标识符列表,每个标识符与相应的区块链节点相关联,并且其中所述方法包括:
从所述互联网服务器获取一个或多个标识符,每个标识符与相应的区块链节点相关联;以及
使用所述获取的一个或多个标识符连接到所述相关联的一个或多个区块链节点。
语句30.根据语句29所述的方法,其中所述方法由所述一个或多个区块链节点之外的不同区块链节点执行。
语句31.一种计算机设备,所述计算机设备包括:
存储器,所述存储器包括一个或多个存储器单元;以及
处理装置,所述处理装置包括一个或多个处理单元,其中所述存储器存储被设置在所述处理装置上运行的代码,所述代码被配置为当在所述处理装置上运行时,执行根据语句1至30中任一项所述的方法。
语句32.一种计算机程序,所述计算机程序包含在计算机可读存储器上并且被配置为当在计算机设备上运行时,执行根据语句1至30中任一项所述的方法。
根据本文公开的另一方面,可以提供一种方法,所述方法包括所述第一方和所述互联网服务器的动作。
根据本文公开的另一方面,可以提供一种系统,所述系统包括所述第一方和所述互联网服务器的计算机设备。
Claims (32)
1.一种用于将区块链事务传输到区块链网络的计算机实现的方法,其中所述方法由第一方执行,并且所述方法包括:
通过互联网服务器主持的互联网服务,将区块链事务的至少一部分传输到所述互联网服务器,其中所述互联网服务器被配置为连接到所述区块链网络的一个或多个节点,并将区块链事务传输到所述一个或多个区块链节点,其中所传输的区块链事务包括所述区块链事务的所述至少一部分。
2.根据权利要求1所述的方法,其中所述互联网服务器是Web服务器,并且其中所述互联网服务是Web服务。
3.根据权利要求2所述的方法,其中,所述区块链事务的所述至少一部分是使用超文本传输协议HTTP传输到所述Web服务器的。
4.根据权利要求1所述的方法,其中所述互联网服务器是邮件服务器,并且其中所述互联网服务是邮件服务。
5.根据权利要求4所述的方法,其中,所述区块链事务的所述至少一部分是使用简单邮件传输协议SMTP传输到所述邮件服务器的。
6.根据前述任一项权利要求所述的方法,其中所述互联网服务包括用于输入数据的输入字段,并且其中所述方法包括:通过所述输入字段输入所述区块链事务的所述至少一部分。
7.根据前述任一项权利要求所述的方法,所述方法包括:生成所述区块链事务的所述至少一部分。
8.根据权利要求1至6中任一项所述的方法,其中所述区块链事务的所述至少一部分由第二方生成。
9.根据前述任一项权利要求所述的方法,其中所述区块链事务的所述至少一部分包括由所述第一方和/或所述第二方生成的相应数字签名。
10.根据前述任一项权利要求所述的方法,其中所述区块链事务的所述至少一部分是完整的区块链事务。
11.根据前述任一项权利要求所述的方法,所述方法包括:通过所述互联网服务从所述互联网服务器接收请求消息,其中所述区块链事务的所述至少一部分的所述传输响应于所述请求消息的所述接收,并且其中所述请求消息包括:
将先前区块链事务的未花费事务输出分配给所述第二方的请求,所述请求源自所述第二方;和/或
所述第二方生成的所述区块链事务的所述至少一部分。
12.根据权利要求1至10中任一项所述的方法,所述方法包括:通过所述互联网服务向所述互联网服务器传输请求消息,其中所述区块链事务的所述至少一部分的所述传输响应于接收到对所述请求消息的响应,并且其中所述请求消息包括:
将先前区块链事务的未花费事务输出分配给所述第一方的请求,所述请求源自所述第一方;和/或
所述第一方生成的所述区块链事务的所述至少一部分。
13.根据前述任一项权利要求所述的方法,所述方法包括:通过所述互联网服务从所述互联网服务器接收更新消息,其中所述更新消息包括以下各项中的至少一项:
所述区块链事务;
关于所述区块链事务已在所述区块链的区块中发布的指示;和/或
用于验证所述区块链事务已包含在所述区块链的所述区块中的默克尔路径。
14.根据前述任一项权利要求所述的方法,所述方法包括:通过所述互联网服务从所述互联网服务器接收与所述第一方相关联的联系者列表,其中对于所述列表中的每个联系者,所述列表包括与所述联系者相关联的相应一个或多个区块链地址。
15.根据权利要求14所述的方法,其中所述区块链事务的输出锁定到与所述联系者中的一个联系者相关联的区块链地址。
16.一种用于将区块链事务传输到区块链网络的计算机实现的方法,其中所述方法由互联网服务器执行,所述互联网服务器被配置为连接到一个或多个区块链节点,并且所述方法包括:
通过所述互联网服务器主持的互联网服务从第一方,接收区块链事务的至少一部分;以及
将区块链事务传输到所述一个或多个区块链节点,其中所述区块链事务包括所述区块链事务的所述至少一部分。
17.根据权利要求16所述的方法,其中所述互联网服务器是Web服务器,并且其中所述互联网服务是Web服务。
18.根据权利要求17所述的方法,其中所述区块链事务的所述至少一部分是使用超文本传输协议HTTP从所述第一方接收的。
19.根据权利要求16所述的方法,其中所述互联网服务器是邮件服务器,并且其中所述互联网服务是邮件服务。
20.根据权利要求19所述的方法,其中所述区块链事务的所述至少一部分是使用简单邮件传输协议SMTP从所述第一方接收的。
21.根据权利要求16至20中任一项所述的方法,所述方法包括:使用所述区块链事务的所述至少一部分来生成所述区块链事务。
22.根据前述任一项权利要求所述的方法,所述方法包括:
通过所述互联网服务从第二方接收请求消息;以及
通过所述互联网服务向所述第一方传输所述请求消息,其中所述请求消息包括:
将先前区块链事务的未花费事务输出分配给所述第二方的请求;和/或
所述区块链事务的所述至少一部分,所述区块链事务的所述至少一部分由所述第二方生成。
23.根据前述任一项权利要求所述的方法,所述方法包括:通过所述互联网服务向所述第一方传输更新消息,其中所述更新消息包括以下各项中的至少一项:
所述区块链事务;
关于所述区块链事务已在区块链的区块中发布的指示;和/或
用于验证所述区块链事务已包含在所述区块链的所述区块中的默克尔路径。
24.根据从属于权利要求17的权利要求22所述的方法,其中所述请求消息是使用HTTP传输的。
25.根据从属于权利要求17的权利要求23所述的方法,其中所述更新消息是使用HTTP传输的。
26.根据从属于权利要求19的权利要求22所述的方法,其中所述请求消息是使用SMTP传输的。
27.根据从属于权利要求19的权利要求23所述的方法,其中所述更新消息是使用SMTP传输的。
28.根据权利要求16至27中任一项所述的方法,所述方法包括:
维护与所述第一方相关联的联系者列表,其中,对于每个联系者,所述联系者列表包括与所述联系者相关联的一个或多个区块链地址;以及
将所述联系者列表传输给所述第一方。
29.一种用于发现区块链网络的一个或多个区块链节点的计算机实现的方法,其中互联网服务器维护标识符列表,每个标识符与相应的区块链节点相关联,并且其中所述方法包括:
从所述互联网服务器获取一个或多个标识符,每个标识符与相应的区块链节点相关联;以及
使用所述获取的一个或多个标识符连接到所述相关联的一个或多个区块链节点。
30.根据权利要求29所述的方法,其中所述方法由所述一个或多个区块链节点之外的不同区块链节点执行。
31.一种计算机设备,所述计算机设备包括:
存储器,所述存储器包括一个或多个存储器单元;以及
处理装置,所述处理装置包括一个或多个处理单元,其中所述存储器存储被设置在所述处理装置上运行的代码,所述代码被配置为当在所述处理装置上运行时,执行根据权利要求1至30中任一项所述的方法。
32.一种计算机程序,所述计算机程序包含在计算机可读存储器上并且被配置为当在根据权利要求31所述的计算机设备上运行时,执行根据权利要求1至30中任一项所述的方法。
Applications Claiming Priority (3)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
GB2012134.9 | 2020-08-05 | ||
GB2012134.9A GB2597927A (en) | 2020-08-05 | 2020-08-05 | Connecting to the blockchain network |
PCT/EP2021/068457 WO2022028791A1 (en) | 2020-08-05 | 2021-07-05 | Connecting to the blockchain network |
Publications (2)
Publication Number | Publication Date |
---|---|
CN116057920A true CN116057920A (zh) | 2023-05-02 |
CN116057920A8 CN116057920A8 (zh) | 2024-05-24 |
Family
ID=72425190
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202180057606.7A Pending CN116057920A (zh) | 2020-08-05 | 2021-07-05 | 连接到区块链网络 |
Country Status (6)
Country | Link |
---|---|
US (1) | US20230300191A1 (zh) |
EP (1) | EP4144002A1 (zh) |
JP (1) | JP2023537698A (zh) |
CN (1) | CN116057920A (zh) |
GB (1) | GB2597927A (zh) |
WO (1) | WO2022028791A1 (zh) |
Families Citing this family (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2024040512A1 (zh) * | 2022-08-25 | 2024-02-29 | 华为技术有限公司 | 区块链的创建方法及相关装置 |
Family Cites Families (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
ZA201502969B (en) * | 2014-05-09 | 2016-01-27 | Univ Stellenbosch | Enabling a user to transact using cryptocurrency |
US20220327525A1 (en) * | 2015-07-14 | 2022-10-13 | Fmr Llc | Address Verification, Seed Splitting and Firmware Extension for Secure Cryptocurrency Key Backup, Restore, and Transaction Signing Platform Apparatuses, Methods and Systems |
AU2017223133B2 (en) | 2016-02-23 | 2022-09-08 | nChain Holdings Limited | Determining a common secret for the secure exchange of information and hierarchical, deterministic cryptographic keys |
US11606190B2 (en) * | 2017-12-26 | 2023-03-14 | Akamai Technologies, Inc. | High performance distributed system of record with cryptographic service support |
WO2020006138A1 (en) * | 2018-06-29 | 2020-01-02 | Arcblock, Inc. | Blockchain adapter, protocol, and access layer |
KR102012757B1 (ko) * | 2019-04-05 | 2019-08-21 | (주)이지팜 | 웹 세션 기반의 블록체인 연동 서비스 제공 시스템 및 그 방법 |
-
2020
- 2020-08-05 GB GB2012134.9A patent/GB2597927A/en active Pending
-
2021
- 2021-07-05 JP JP2023506523A patent/JP2023537698A/ja active Pending
- 2021-07-05 EP EP21740483.9A patent/EP4144002A1/en active Pending
- 2021-07-05 WO PCT/EP2021/068457 patent/WO2022028791A1/en unknown
- 2021-07-05 CN CN202180057606.7A patent/CN116057920A/zh active Pending
- 2021-07-05 US US18/017,831 patent/US20230300191A1/en active Pending
Also Published As
Publication number | Publication date |
---|---|
JP2023537698A (ja) | 2023-09-05 |
GB202012134D0 (en) | 2020-09-16 |
GB2597927A (en) | 2022-02-16 |
EP4144002A1 (en) | 2023-03-08 |
WO2022028791A1 (en) | 2022-02-10 |
US20230300191A1 (en) | 2023-09-21 |
CN116057920A8 (zh) | 2024-05-24 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN115997369A (zh) | 用于在区块链网络中验证数据的方法和装置 | |
CN114008969A (zh) | 包含在区块链中的交易的延展性 | |
CN113994628A (zh) | 通过侧信道流式传输部分数据 | |
JP2023515368A (ja) | ブロックチェーンネットワークと共に使用される証明サービス | |
CN116508291A (zh) | 默克尔证明实体 | |
CN115997229A (zh) | 区块链上的协议 | |
CN116210016A (zh) | 共生通证系统 | |
JP2022532889A (ja) | 複数インプットトランザクション | |
CN117480758A (zh) | 用于验证区块链上的通证的计算机实现的方法和系统 | |
CN116157796A (zh) | 警报账户 | |
CN116057920A (zh) | 连接到区块链网络 | |
CN114531941A (zh) | 多标准区块链协议 | |
CN117280653A (zh) | 多方区块链地址方案 | |
CN117751550A (zh) | 分层共识 | |
CN117836771A (zh) | 使用区块链协调对等数据传输 | |
CN117795516A (zh) | 一种计算机实现的方法和系统 | |
CN116671061A (zh) | 节点版本控制 | |
CN118044151A (zh) | 传播锁定脚本 | |
US20230125507A1 (en) | Blockchain transaction double spend proof | |
TW202220411A (zh) | 默克爾證明實體 | |
CN115699676A (zh) | 自定义事务脚本 | |
CN117337436A (zh) | 多方区块链地址方案 | |
CN117280349A (zh) | 多方区块链地址方案 | |
GB2608840A (en) | Message exchange system | |
CN117693926A (zh) | 区块链区块和存在证明 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
CI02 | Correction of invention patent application | ||
CI02 | Correction of invention patent application |
Correction item: PCT international application to national stage day Correct: 2023.02.03 False: 2023.02.02 Number: 18-01 Page: The title page Volume: 39 Correction item: PCT international application to national stage day Correct: 2023.02.03 False: 2023.02.02 Number: 18-01 Volume: 39 |