区块链:干货 | 几行代码就能撸一个文档注册以太坊Dapp

伟大的事情都很简单,而且大多数都可以被凝结成几个词:自由,正义,荣誉,责任,仁慈,希望。——温斯顿·丘吉尔

在本文中,我将用代码示例来描述我所知道的最简单的区块链应用程序。这对于那些以区块链为起点的人来说是十分有用的,也可以为经验更为丰富的架构师们提供一个设计模型。

让我们想象一下下面这个用例:你收到了一份经了好几手的文档,而且你想要确保它的真实性。这份文件可能是你要购买的汽车的服务手册,也可能是证明你要购买的房屋的房产证明,它可能是任何东西。

对文档进行数字签名以确保其不被篡改并不是什么新鲜事了,你可以获取文档内容并生成一个加密签名,该签名会与文档本身一起被发送出去。

Telefónica与微软VR平台合作,计划在元宇宙中开启虚拟体验:金色财经报道,西班牙电信公司Telefónica与微软的Altspace VR平台合作,创建了其MWC展台的数字复制品。Telefónica计划在今年巴塞罗那世界移动通信大会期间开启虚拟之旅。数字复制品将允许世界各地的人们体验和详细发现该公司将在展会上展示的产品演示。

根据公告,人们还可以在体验中与任何人/化身互动。Telefónica还与游戏软件开发商Unity合作,后者将作为其开发元宇宙体验的战略合作伙伴,而与Niantic的合作则为创建增强现实体验提供支持。[2023/2/27 12:30:44]

文档接受者可以再次生成签名,并验证其与提供的签名是否匹配。若匹配一致,则证明文档没有被更改过。这就是MD5checksums可以提供的功能,使用起来非常方便。但它的缺点是你需要通过接收签名来验证文档的真实性。如果有人在中间同时修改了文件和签名,那你便无从查证了。

Stellar开发者提供针对用户忘记填写备忘录ID的支付解决方案:Stellar基金会认为,交易所的备忘录(memo)数据条款是一个主要问题,当用户忘记其备忘录ID时,会妨碍他们执行交易,因此,他们为交易所提供一个支付解决方案。据悉,备忘录可在Stellar网络上使用,以支持交易所的Stellar账户。CoinBene、Coinbase和币安等交易所为每个用户提供唯一的备忘录ID。当在Stellar网络上的账户中付款时,需要此备忘录ID才能成功记入账户。而用户经常忘记在存款交易中填写备忘录。缺少备忘录的交易有可能会导致资金损失,并需要托管支持人员手动操作。Stellar开发者表示,现在有一个简单的解决“我忘记我的备忘录”问题的方法:交易所和钱包可以通过在他们的账户上设置一个标志来要求收到Stellar付款的备忘录,通过几次点击或几行代码就能完成。SEP-29引入一个基本约定,允许在账户级别定义备忘录要求。“使用数据输入,交易所可以通过简单的操作将其账户标记为需要备忘录。升级到最新的Stellar SDK的钱包将拒绝用户向这些地址发送无备忘录的支付。”(Newslogical)[2020/4/8]

由于从个人那里获取数据并不十分可信,因此有时会有第三方介入,提供有偿的记录保存服务。这种获利动机是促使记录保管者保持诚实的根本原因。

声音 | Allen Piscitello:Liquid Network专注于广泛的应用:据ambcrypto报道,Blockstream产品管理总监Allen Piscitello阐述了闪电网络和比特币侧链Liquid Network之间的区别,他表示,闪电网络和Liquid Network在某些方面彼此相似,并且通过使用支付渠道更快地发送付款。在使用闪电网络甚至不需要等待两分钟,而且它正在使用更具反应性的安全模型。如果有人试图窃取您的资金,您有时间收回渠道中的所有资金,这是一个不同的安全模型。对于他们的性质,闪电网络更加面向“微支付”,而Liquid Network则专注于广泛的应用。[2018/11/1]

第三方的介入确实是一个可行的方案,但远不是最完美的方案。记录保管者会将自己放在权力顶端的位置,并且在没有竞争压力的情况下榨取高额酬金。更糟糕的是,如果经济激励机制发生变化,那么记录保管者可能会变腐败。又由谁来看守这些守门人呢?

区块链能为你做什么?

区块链数据储存是去中心化的、稳定的、不可变的。

“去中心化的”意味着数据储存在不同人员的硬件上共同运行。“稳定的”意味着即使一些参与者离开或者终止合作,数据储存也仍将继续运行。“不可变的”意味着一旦数据被储存在区块链中,它将无法被更改。

区块链以一种优雅的方式解决了文档注册表问题。一旦我们在区块链注册表中签了名,我们就不必担心文档和签名会被篡改。要想做到这一点,大多数参与者必须就这一变化达成一致意见,那这就不能算是什么秘密了。

与此同时,没有任何人有权以提供此服务的方式收取酬金,参与者们可以自己提供这项服务。

在这种情况下,文档可以是任何数据集。同样的模型也适用于验证任何商业交易、IoT数据集或用户身份等数据的真实性。

还是那句话:区块链以一种优雅的方式解决了文档注册表问题。一旦我们记录了签名,它就无法被篡改了。

如果我是在2016年写这篇文章的话,我可以执行大约一百行代码,然后给出一份二十多页的白皮书,并为一个项目筹集数百万美元。这一模型的应用是无穷无尽的,也的确有很多人抓住了这个机会。

如今,了解如何构建区块来设计更为复杂的解决方案是十分有用的。所有的区块链解决方案都依赖于储存用户生成的数据,并且要保证这些数据在不依赖于任何人的情况下仍是可信的。

执行

这次我没有从头开始编写合约代码。因为我一般不会做重复的工作,而区块链注册表已经被创建过十几次了。谷歌一键搜索就能找到GitHubrepo,我将用它来展示该模型是如何运作的。即使它使用的是老版的solidity,它仍然可以很好的工作,而且你可以自己测试一下。

这个合约非常简单,只有一个相关的合约变量和两个函数。

文档映射表把为文档计算的hash散列与添加它的区块链接起来。一个添加方法需要一个hash散列,并且将其储存在映射表中。一个验证方法返还一个hash散列的时间戳。

前端允许你上传带有合约的文档,添加签名并利用sha256算法计算文档内容的哈希值。

前端依然让你上传带有合约的文档,此时需要验证一下之前是否上传过该文档,如果之前上传过,则会返回上传的大概时间。

这就是实现去中心化文档注册表的全部内容,该注册表做了两件事情:

签署文档;

验证文档自上次记录签名后是否发生过改变;

这种方法之所以有效,是因为两个不同的文档具有相同签名的概率几乎为零。如果你能得到时间戳,那么你就可以确定你提供的文档是在哪个时间被导入到注册表中的。

当然,合约代码是可以被更新和改进的,但这17行核心代码仍然是正确的。

总结

文档注册表是具有商业价值的区块链应用程序中最容易实现的一个应用程序。在2016年,本文中的几行代码就足以助力一个百万美元的项目。如今,它们仍然能在更复杂的解决方案中反复使用。

文档注册表有效地利用了区块链的去中心化性和不变性这两个属性,从而不需要依赖其他人来证明数据的真实性。这个想法非常简单,但却是具有革命意义的。

来源|Hackernoon编译|火火酱责编|Carol出品|区块链大本营

郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。

链链资讯

[0:15ms0-10:912ms