伟大的事情都很简单,而且大多数都可以被凝结成几个词:自由,正义,荣誉,责任,仁慈,希望。——温斯顿·丘吉尔
在本文中,我将用代码示例来描述我所知道的最简单的区块链应用程序。这对于那些以区块链为起点的人来说是十分有用的,也可以为经验更为丰富的架构师们提供一个设计模型。
让我们想象一下下面这个用例:你收到了一份经了好几手的文档,而且你想要确保它的真实性。这份文件可能是你要购买的汽车的服务手册,也可能是证明你要购买的房屋的房产证明,它可能是任何东西。
Optimism开发者karl.floersch.eth将接任OP Labs CEO一职:金色财经报道,OP Labs发推表示,Optimism Collective开发者karl.floersch.eth将接任OP Labs的首席执行官一职,liam.eth将不再担任该职。[2023/4/29 14:34:27]
对文档进行数字签名以确保其不被篡改并不是什么新鲜事了,你可以获取文档内容并生成一个加密签名,该签名会与文档本身一起被发送出去。
文档接受者可以再次生成签名,并验证其与提供的签名是否匹配。若匹配一致,则证明文档没有被更改过。这就是MD5checksums可以提供的功能,使用起来非常方便。但它的缺点是你需要通过接收签名来验证文档的真实性。如果有人在中间同时修改了文件和签名,那你便无从查证了。
知情人士:Kraken已同意关闭加密质押业务来解决SEC的指控:金色财经报道,据一位了解情况的业内人士称,Kraken 已同意关闭其加密货币质押业务,以解决与美国证券交易委员会 (SEC) 的指控。[2023/3/16 13:08:08]
由于从个人那里获取数据并不十分可信,因此有时会有第三方介入,提供有偿的记录保存服务。这种获利动机是促使记录保管者保持诚实的根本原因。
第三方的介入确实是一个可行的方案,但远不是最完美的方案。记录保管者会将自己放在权力顶端的位置,并且在没有竞争压力的情况下榨取高额酬金。更糟糕的是,如果经济激励机制发生变化,那么记录保管者可能会变腐败。又由谁来看守这些守门人呢?
Bybit推出跨链平台Bybit Web3:10月25日消息,加密货币交易所Bybit宣布推出一站式跨链平台Bybit Web3,可帮助用户通过Bybit钱包探索Web3并管理加密货币资产和NFT。
根据其路线图,10月推出Bybit Web3 App和网页版、Bybit钱包Chrome扩展程序,11月将推出APEX集成、Swap功能,12月推出IDO功能、空投管理、NFT资产展示以及跨链兼容等功能,2023年Q1将推出去中心化身份管理。[2022/10/25 16:38:21]
区块链能为你做什么?
区块链数据储存是去中心化的、稳定的、不可变的。
“去中心化的”意味着数据储存在不同人员的硬件上共同运行。“稳定的”意味着即使一些参与者离开或者终止合作,数据储存也仍将继续运行。“不可变的”意味着一旦数据被储存在区块链中,它将无法被更改。
Yuga Labs为“MetaRPG”申请商标:9月17日消息,据知识产权律师Eliana在社交媒体上透露,BAYC母公司Yuga Labs已为“MetaRPG”申请了商标,涉及游戏、服装、音频、NFT、各种Token、市场、创作者工具、硬件(包括控制器、手持设备和耳机、掌机等)。MetaRPG是Yuga Labs今年三月推出的游戏,该游戏已与更多NFT项目兼容,并开启生态内应用商店来交易代币及NFT资产。[2022/9/17 7:02:46]
区块链以一种优雅的方式解决了文档注册表问题。一旦我们在区块链注册表中签了名,我们就不必担心文档和签名会被篡改。要想做到这一点,大多数参与者必须就这一变化达成一致意见,那这就不能算是什么秘密了。
与此同时,没有任何人有权以提供此服务的方式收取酬金,参与者们可以自己提供这项服务。
ADOGE发布可达鸭联名款NFT:据官方消息,AmazingDoge发布可达鸭联名款NFT,总量10个,可以通过其NFT市场,打开\"金礼包\"获得。
AmazingDoge是一个BSC链上的MeMe代币,NFT市场于今日进行公测。
NFT市场可以通过质押ADOGE NFT产出\"大礼包\",获得代币及其他NFT奖励,所有道具均可交易。[2022/5/31 3:52:59]
在这种情况下,文档可以是任何数据集。同样的模型也适用于验证任何商业交易、IoT数据集或用户身份等数据的真实性。
还是那句话:区块链以一种优雅的方式解决了文档注册表问题。一旦我们记录了签名,它就无法被篡改了。
如果我是在2016年写这篇文章的话,我可以执行大约一百行代码,然后给出一份二十多页的白皮书,并为一个项目筹集数百万美元。这一模型的应用是无穷无尽的,也的确有很多人抓住了这个机会。
如今,了解如何构建区块来设计更为复杂的解决方案是十分有用的。所有的区块链解决方案都依赖于储存用户生成的数据,并且要保证这些数据在不依赖于任何人的情况下仍是可信的。
执行
这次我没有从头开始编写合约代码。因为我一般不会做重复的工作,而区块链注册表已经被创建过十几次了。谷歌一键搜索就能找到GitHubrepo,我将用它来展示该模型是如何运作的。即使它使用的是老版的solidity,它仍然可以很好的工作,而且你可以自己测试一下。
这个合约非常简单,只有一个相关的合约变量和两个函数。
文档映射表把为文档计算的hash散列与添加它的区块链接起来。一个添加方法需要一个hash散列,并且将其储存在映射表中。一个验证方法返还一个hash散列的时间戳。
前端允许你上传带有合约的文档,添加签名并利用sha256算法计算文档内容的哈希值。
前端依然让你上传带有合约的文档,此时需要验证一下之前是否上传过该文档,如果之前上传过,则会返回上传的大概时间。
这就是实现去中心化文档注册表的全部内容,该注册表做了两件事情:
签署文档;
验证文档自上次记录签名后是否发生过改变;
这种方法之所以有效,是因为两个不同的文档具有相同签名的概率几乎为零。如果你能得到时间戳,那么你就可以确定你提供的文档是在哪个时间被导入到注册表中的。
当然,合约代码是可以被更新和改进的,但这17行核心代码仍然是正确的。
总结
文档注册表是具有商业价值的区块链应用程序中最容易实现的一个应用程序。在2016年,本文中的几行代码就足以助力一个百万美元的项目。如今,它们仍然能在更复杂的解决方案中反复使用。
文档注册表有效地利用了区块链的去中心化性和不变性这两个属性,从而不需要依赖其他人来证明数据的真实性。这个想法非常简单,但却是具有革命意义的。
来源|Hackernoon编译|火火酱责编|Carol出品|区块链大本营
郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。