区块链研习社以太坊区块链开发区块链大学

以太坊开发DApp实战教程——用区块链、星际文件系统(IPFS)

2018-08-21  本文已影响9人  编程狂魔

第一节 简介

欢迎和我们一起来用以太坊实战开发构建一个去中心化电商DApp!我们将会构建一个类似淘宝的在线电子商务应用,我将使用区块链、星际文件系统(IPFS)、Node.js和MongoDB来构建电商平台,卖家可以自由地出售商品,买家可以自由地购物:

ebay dapp

去中心化: 和淘宝或eBay不同,我们把所有的商业逻辑和核心数据都放在以太坊区块链上,这使 得它成为一个完全去中心化的应用。和淘宝这样中心化的电商平台相比,一个去中心化 的P2P电商应用显然有其独特的价值 —— 至少你不用担心被平台封账户了。

IPFS: 在以太坊上存储用于商品展示的图片和描述超文本十分昂贵,由于以太坊虚拟机的限制, 有时甚至是不可行的。为了解决这个问题,我们将会把商品图片和商品描述信息存储在 同样去中心化的星际文件系统(IPFS)中,而仅仅在链上保存这些数据的ID

商品拍卖: 对于卖家而言,拍卖显然是一种非常好的提升商品利润空间的销售手段。因此我们 在课程项目中将实现去中心化环境下的维科瑞(Vickery)拍卖 —— 这非常类似于eBay 的自动竞价系统,而不是简单地对商品进行固定标价。

资金托管: 中心化的平台有一个优点在于它天然提供了买卖双方之间的信任中介。在去中心化的 环境中,我们将使用一个多方托管合约来应对买卖双方可能的风险,托管合约采用投票机制 来决定买家货款的最终流向。

链下数据存储: 不要被去中心化限制我们的思维,传统的技术依然有其强大之处。我们将使用MongoDB在 链下做一个同步的数据备份,以便实现单纯用区块链很难实现的功能:灵活的商品查询。

课程地址:http://xc.hubwiz.com/course/5abbb7acc02e6b6a59171dd6

第二节 去中心化,why?

在开始构建我们的应用之前,非常值得花一分钟时间,来理解为什么要在像以太坊这样的 去中心化平台上搭建在线卖场。

eBay或淘宝这样的C2C电商平台已经获得了巨大成功,因为它使得买卖双方都相当便利:

c2c platform

在互联网成为主流之前,人们只能在小范围内、或者在邻里之间买卖商品。当越来越多的人使用互联网, 出现了像eBay这样的平台,无论来自世界的任何一个地方,你都可以在网上买卖商品。无论是商家还 是消费者,这样的平台都有其价值。

尽管eBay这样的平台方便了大家,也改善了贸易和经济,但它也存在一些缺点:

  1. 被平台束缚。参与的商家受制于拥有平台的企业。在任何时候,平台拥有者可以自行决定在是否对某个 商家进行封号处理,而如果商家严重依赖于平台,那么账号被封就是一个巨大的打击。
  2. 商家费用高。商家上架商品要交费,售出商品也要交佣金。收费本身并没有错,毕竟eBay这样的平台 提供了服务。但是,上架费有时太高了,这导致商家最后盈利很少,或是将成本转嫁到消费者身上。
  3. 数据失控。商家或消费者都无法拥有本应属于自己的数据。评论、购买历史等等所有数据都为平台拥有者所有。 比如,如果一个商家想要换一个提供商,或者想要导出商品评论或是其他数据都非常不容易,甚至不可能。

在以太坊上构建的去中心化电商平台就解决了这些问题:商家的账户不会被封;数据也是公开的,所以很容易导出数据; 相对于中心化的平台,交易佣金也会低得多。

第三节 初步的功能特性

现在你应该已经理解了为什么要构建去中心化的电商应用,也了解了我们要构建的应用是什么, 现在让我们来大致看一下,在这个项目中将要实现的主要功能特性:

ebay user case

为了便于查询,我们会将商品数据同时存在链上和链下(数据库);同时,为了避免图片等数据占用 昂贵的链上存储,我们将把图片和商品描述信息上传到同样去中心化的IPFS网络。

课程地址:http://xc.hubwiz.com/course/5abbb7acc02e6b6a59171dd6

第四节 基础知识要求

为了顺利地完成本课程的学习,你应该对以下语言/技术有一些了解:

第五节 系统架构

在开始着手具体的实现之前,先来看一下在本课程我们将要构建的去中心化电商DApp的架构。

ebay dapp architecture

第六节 理解架构的作用

为了帮助理解上一节谈到的那些组件的作用,让我们来看看一下卖家上架一个商品的流程:

ebay list item

(1)前端使用一个HTML表单来采集用户输入的商品细节,例如起拍价、商品图片、描述信息等。

(2)(3) 前端将商品图片和介绍文本上传到IPFS,并返回所上传内容对应的链接(哈希)。

(4)(5) 然后,web前端会调用电商合约将商品信息和IPFS链接存储到链上。当合约成功地将商品存入区块链后, 就会触发一个事件,该事件中包含了商品所有的信息。

(6)(7)(8) NodeJS服务器监听区块链事件,当事件被电商合约触发时,服务器读取事件内容并将商品信息插入到 MongoDB数据库中。

当开始具体实现商品上架这一特性时,我们将重温这一流程。

第七节 敏捷开发

我们将采用敏捷开发的思想来实现去中心化电商DApp:

scrum way

我们将全部的产品特性分别列入8个迭代周期,通过每一次的冲刺(sprint),我们都将得到一个 可以发布的版本:

前两个冲刺主要集中在使用soliditytruffle框架实现电商合约方面,这包括合约的设计、开发 、编译、部署与测试:

在电商合约基本实现之后,接下来的三个冲刺主要集中在前端用户界面的构建方面,这包括使用web3 与合约的交互,以及通过ipfs的开发接口上传图片等数据交互,当然,还有必不可少的DOM操作:

在接下来的两个冲刺里,我们将首先实现资金托管合约,用来管理竞价结束后胜出买家的资金; 然后实现相应的用户操作界面:

最后,为了便于商品的查询检索,我们将使用MongoDB来实现商品数据的链下存储:

课程地址:http://xc.hubwiz.com/course/5abbb7acc02e6b6a59171dd6

如果想加入以太坊技术开发群可以加微信:13910002724,拉你入群。

上一篇 下一篇

猜你喜欢

热点阅读