区块链笔记:DAPP的运行结构,环境准备,模板文件的选用,演示项目示例的运行

本文主要是介绍区块链笔记:DAPP的运行结构,环境准备,模板文件的选用,演示项目示例的运行,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

概述

只有智能合约不足以构成一个应用,还需要配合前端,后端才能成为应用本身

DAPP的运行结构

  • DAPP是一个分布式应用,以下是它的简要组成结构
    • 以太坊节点 + 智能合约 + 调用端 + 界面
    • 以太坊节点 + 智能合约 是p2p网络结构的,没有明确的固定的服务端
    • 调用端和界面也就是所谓的前端,通常采用web框架结构
  • 我们需要在这个基础之上的增设一个后端服务
  • 专门用来跟节点通信,以及汇总一些数据,和那些不适合放在合约中的一些业务逻辑
  • 也就是这么一个结构:以太坊节点(智能合约) ---> 后端服务 ---> 前端程序

环境准备

  • 1.我们需要一个节点,可以使用ganache模拟节点或部署一个以太坊私有链,正式部署需要连接到以太坊的主网的节点
  • 2.一般推荐 vscode 做代码编辑
  • 3.使用Truffle来下载应用模板和编译部署
    • 如果我们需要开发一个基于web前端的DAPP可以使用它来下载官网支持的应用模板
    • 官方有一个box页面,有各种类型工程的模板
    • 基于一套工程框架来进行开发,不用从零开始

模板文件的选用

  • 这里开发一个基于web前端的DAPP的例子
  • 既然可以使用工程模板来快速创建目录文件,我们先建一个自己的一个工作目录dapptest
  • 进入这个目录里面,我们就开始下载一个项目模板: $truffle unbox webpack
  • 这个项目模板的名字是webpack, 下面是基于web前端的dapp的工程目录
  • 这里app的目录其实就是nodejs工程的一个目录结构
    • node_modules是node的一些依赖库
    • src中的html是前端页面,js是业务逻辑(和以太坊以及前端页面交互)是Dapp的中间层也叫应用后端
  • 当然这里是使用nodejs来开发的目录,其他语言开发会有相对应文件
  • contracts是我们自己编写的合约
  • 其他文件是与Truffle相关的一些文件
  • 我们可以看到nodejs工程被集成到了truffle目录中去了

项目的运行

  • 我们下载的这个工程模板文件,其实已经内置的一些合约

  • 可以来直接运行这个例子来看一下: $ truffle develop

    • 这里只是想运行一下这个测试程序
    • 我们就不需要去专门启动节点了
    • 当然我们也可以启动一个以太的私有节点或者ganache模拟节点
    • 这里为了方便,通过这个命令启动了truffle内置的一个节点环境
    • 可以看到它同样的监听了本机的8545端口,然后默认了就创建了10个账户地址
  • 由于我们进入了truffle本身的环境,所以可以直接来做合约的编译和部署, 在console控制台输入一下命令:

    • $ compile
    • $ migrate
  • 编译,部署完毕之后,就可以进入到app这个目录里面,来启动我们的示例的合约程序

    • $ cd app
    • $ npm run dev
      > app@1.0.0 dev /Users/johnny/Code/github/block-chain/dapptest/app
      > webpack-dev-serverℹ 「wds」: Project is running at http://localhost:8080/
      ℹ 「wds」: webpack output is served from /
      ℹ 「wds」: Content not from webpack is served from /Users/johnny/Code/github/block-chain/dapptest/app/dist
      ℹ 「wdm」: Hash: 0e531130c456b36c9abe
      Version: webpack 4.42.0
      Time: 1306ms
      Built at: 2020-03-22 10:44:38Asset       Size  Chunks             Chunk Names
      index.html  879 bytes          [emitted]  index.js   2.42 MiB    main  [emitted]  main
      Entrypoint main = index.js
      [0] multi (webpack)-dev-server/client?http://localhost:8080 ./src/index.js 40 bytes {main} [built]
      [../build/contracts/MetaCoin.json] 101 KiB {main} [built]
      [./node_modules/ansi-html/index.js] 4.16 KiB {main} [built]
      [./node_modules/ansi-regex/index.js] 135 bytes {main} [built]
      [./node_modules/strip-ansi/index.js] 161 bytes {main} [built]
      [./node_modules/web3/src/index.js] 2.01 KiB {main} [built]
      [./node_modules/webpack-dev-server/client/index.js?http://localhost:8080] (webpack)-dev-server/client?http://localhost:8080 4.29 KiB {main} [built]
      [./node_modules/webpack-dev-server/client/overlay.js] (webpack)-dev-server/client/overlay.js 3.51 KiB {main} [built]
      [./node_modules/webpack-dev-server/client/socket.js] (webpack)-dev-server/client/socket.js 1.53 KiB {main} [built]
      [./node_modules/webpack-dev-server/client/utils/createSocketUrl.js] (webpack)-dev-server/client/utils/createSocketUrl.js 2.91 KiB {main} [built]
      [./node_modules/webpack-dev-server/client/utils/log.js] (webpack)-dev-server/client/utils/log.js 964 bytes {main} [built]
      [./node_modules/webpack-dev-server/client/utils/reloadApp.js] (webpack)-dev-server/client/utils/reloadApp.js 1.59 KiB {main} [built]
      [./node_modules/webpack-dev-server/client/utils/sendMessage.js] (webpack)-dev-server/client/utils/sendMessage.js 402 bytes {main} [built]
      [./node_modules/webpack/hot sync ^\.\/log$] (webpack)/hot sync nonrecursive ^\.\/log$ 170 bytes {main} [built]
      [./src/index.js] 2.08 KiB {main} [built]+ 349 hidden modules
      ℹ 「wdm」: Compiled successfully.
      
  • 可以看到启动以后,创建的一个服务端,8080端口,我们可以打开来看一下: http://localhost:8080/

  • 这个页面就是工程模板自带的一个示例程序

  • 可以看到,这个页面就相当于就是前端,nodejs就相当于服务后端,节点就相当于以太节点
  • 这个例子是演示发送代币的功能 MetaCoin, 给一个地址发送指定数量的代币

这篇关于区块链笔记:DAPP的运行结构,环境准备,模板文件的选用,演示项目示例的运行的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/950962

相关文章

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

如何用Docker运行Django项目

本章教程,介绍如何用Docker创建一个Django,并运行能够访问。 一、拉取镜像 这里我们使用python3.11版本的docker镜像 docker pull python:3.11 二、运行容器 这里我们将容器内部的8080端口,映射到宿主机的80端口上。 docker run -itd --name python311 -p

poj3468(线段树成段更新模板题)

题意:包括两个操作:1、将[a.b]上的数字加上v;2、查询区间[a,b]上的和 下面的介绍是下解题思路: 首先介绍  lazy-tag思想:用一个变量记录每一个线段树节点的变化值,当这部分线段的一致性被破坏我们就将这个变化值传递给子区间,大大增加了线段树的效率。 比如现在需要对[a,b]区间值进行加c操作,那么就从根节点[1,n]开始调用update函数进行操作,如果刚好执行到一个子节点,

C++11第三弹:lambda表达式 | 新的类功能 | 模板的可变参数

🌈个人主页: 南桥几晴秋 🌈C++专栏: 南桥谈C++ 🌈C语言专栏: C语言学习系列 🌈Linux学习专栏: 南桥谈Linux 🌈数据结构学习专栏: 数据结构杂谈 🌈数据库学习专栏: 南桥谈MySQL 🌈Qt学习专栏: 南桥谈Qt 🌈菜鸡代码练习: 练习随想记录 🌈git学习: 南桥谈Git 🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈�

阿里开源语音识别SenseVoiceWindows环境部署

SenseVoice介绍 SenseVoice 专注于高精度多语言语音识别、情感辨识和音频事件检测多语言识别: 采用超过 40 万小时数据训练,支持超过 50 种语言,识别效果上优于 Whisper 模型。富文本识别:具备优秀的情感识别,能够在测试数据上达到和超过目前最佳情感识别模型的效果。支持声音事件检测能力,支持音乐、掌声、笑声、哭声、咳嗽、喷嚏等多种常见人机交互事件进行检测。高效推

usaco 1.3 Mixing Milk (结构体排序 qsort) and hdu 2020(sort)

到了这题学会了结构体排序 于是回去修改了 1.2 milking cows 的算法~ 结构体排序核心: 1.结构体定义 struct Milk{int price;int milks;}milk[5000]; 2.自定义的比较函数,若返回值为正,qsort 函数判定a>b ;为负,a<b;为0,a==b; int milkcmp(const void *va,c

poj 1258 Agri-Net(最小生成树模板代码)

感觉用这题来当模板更适合。 题意就是给你邻接矩阵求最小生成树啦。~ prim代码:效率很高。172k...0ms。 #include<stdio.h>#include<algorithm>using namespace std;const int MaxN = 101;const int INF = 0x3f3f3f3f;int g[MaxN][MaxN];int n

【区块链 + 人才服务】可信教育区块链治理系统 | FISCO BCOS应用案例

伴随着区块链技术的不断完善,其在教育信息化中的应用也在持续发展。利用区块链数据共识、不可篡改的特性, 将与教育相关的数据要素在区块链上进行存证确权,在确保数据可信的前提下,促进教育的公平、透明、开放,为教育教学质量提升赋能,实现教育数据的安全共享、高等教育体系的智慧治理。 可信教育区块链治理系统的顶层治理架构由教育部、高校、企业、学生等多方角色共同参与建设、维护,支撑教育资源共享、教学质量评估、

在cscode中通过maven创建java项目

在cscode中创建java项目 可以通过博客完成maven的导入 建立maven项目 使用快捷键 Ctrl + Shift + P 建立一个 Maven 项目 1 Ctrl + Shift + P 打开输入框2 输入 "> java create"3 选择 maven4 选择 No Archetype5 输入 域名6 输入项目名称7 建立一个文件目录存放项目,文件名一般为项目名8 确定

安装nodejs环境

本文介绍了如何通过nvm(NodeVersionManager)安装和管理Node.js及npm的不同版本,包括下载安装脚本、检查版本并安装特定版本的方法。 1、安装nvm curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.0/install.sh | bash 2、查看nvm版本 nvm --version 3、安装