比特币钱包开发:钱包项目整体架构设计

栏目: 后端 · 发布时间: 6年前

内容简介:搭建NodeJS后端框架 搭建前端web框架 前后端交互本课程是比特币钱包开发,后端使用的NodeJS搭建,客户端使用的web前端,VSCode开发工具,Ubuntu16.04系统(当然,Mac、windows系统也可以),node v8.11.3,npm v5.6.0。咱们的开发重点是在后端实现上,因此为了让大家快速上手,web客户端没有使用其它流行的框架,这里只使用了jQuery框架简化代码,另外还有个jQuery Validate 插件简化了表单验证。

目标

搭建NodeJS后端框架 搭建前端web框架 前后端交互

前言

本课程是比特币钱包开发,后端使用的NodeJS搭建,客户端使用的web前端,VSCode开发工具,Ubuntu16.04系统(当然,Mac、windows系统也可以),node v8.11.3,npm v5.6.0。

一、前端架构

咱们的开发重点是在后端实现上,因此为了让大家快速上手,web客户端没有使用其它流行的框架,这里只使用了jQuery框架简化代码,另外还有个jQuery Validate 插件简化了表单验证。

web前端整体技术:

html + css + javascript + jQuery。

web前端功能:

钱包模块 创建钱包 助记词导入钱包 钱包列表 导出钱包助记词 账号模块 查询余额 创建子账号 查询子账号:地址、路径、私钥 比特币转账 交易记录

比特币钱包开发:钱包项目整体架构设计

二、后端架构

这个钱包应用程序与比特币区块链交互,我们使用了Bitpay开发的bitcore-wallet-client库,使用它便于我们的开发,封装了比较全面的API给我们使用。

另外,后端Http框架使用的是强大的express,里面封装了很多功能,因为bitcore-wallet-client库中提供的API会通过异步callback返回数据,所以就不用koa。

在这个项目中使用了第三方库较少,如下:

bitcore-wallet-client:是bitcore-wallet-service的客户端库,使用REST API 与BWS bitcore-wallet-service进行通信,所有REST端点都包装为简单的异步方法。bitcore-wallet-service库实现了多重签名的比特币HD钱包服务,使用该服务的有Copay、Bitpay钱包。 express:是一个web框架,提供的HTTP服务器 工具 非常强大,且集成与使用简单,与koa类似。 ejs:是一种JavaScript模版引擎,可以动态的设置变量值到html。需要与模板渲染中间件koa-views配合使用。 整体架构使用了成熟的MVC架构。项目的入口是index.js文件,对项目做了配置,将后端服务绑定到了3000端口并处于简体状态,当前端访问服务时,router.js路由文件根据URL将任务分配到controllers文件夹下的业务文件中。

这里为了让快速上手开发比特币钱包项目,前后端都在一个项目上同时开发,将前端的页面文件放在了static与views文件夹中,当然,同时支持移动端(iOS、安卓)的调用。若是需要前后端分离,可直接将static与views文件夹分离出来即可。

三、项目初始化

新建项目跟文件夹BTCWallet,然后按照如下步骤执行

新建项目跟文件夹BTCWallet,然后按照如下步骤执行

lixu@ubuntu:~$ cd '/home/lixu/Desktop/demo/BTCWallet/' lixu@ubuntu:~/Desktop/demo/BTCWallet$ npm init

然后不断回车初始化项目。然后后自动生成package.json文件,是项目包的配置文件,下面我们引入项目中需要用到的库,拷贝下面json到package.json文件的最后一个字段。

, "dependencies": { "bitcore-wallet-client": "^6.7.5", "ejs": "^2.6.1", "express": "^4.16.4" }

项目的界面如下: 比特币钱包开发:钱包项目整体架构设计

然后运行以下命令按照上面的依赖库。

npm install

下载完成后会将所有的依赖库下载到项目根目录自动新建的node_modules文件夹。

四、项目源码

按照如下结构搭建项目。

比特币钱包开发:钱包项目整体架构设计
1A0B838E-50E6-44FC-AB9B-3D95C6A467C7

index.js

项目的入口文件。首先实例化express对象,然后将express.urlencoded、ejs、views、static路由注册到中间件,服务绑定到3000端口。

比特币钱包开发:钱包项目整体架构设计

各字断含有:

BWS_URL: bitcore-wallet服务端地址,我们使用的是bitpay的地址,你也可以自己搭建一个钱包服务端。

networkType: 钱包连接的网络类型,支持正式网络和测试网络,分别表示为:livenet、testnet。

coinType: 币种类型,支持比特币和比特币现金,分别表示为:btc、bch。

copayerName: 钱包的拥有者,创建钱包的一个必填字断,这里我就指定为常量“lixu”。

walletFilePath: 创建钱包后导出的文件的存放位置。

Models/walletClient.js

出来wallet的model文件,这里只有一个方法,实例化bitcore-wallet客户端。

let config = require("../config/config")

module.exports = {

getWalletClient: () => {

var Client = require('bitcore-wallet-client');

var client = new Client({

baseUrl: config.BWS_URL,

verbose: false,

});

return client

},

}

router/router.js

路由文件。

let router = require('express').Router();

router.get("/wallet.html", (req, res) => {

res.render("wallet.html");

})

module.exports = router

utils/myUtils.js

项目工具类,提供返回给前端成功与失败的基本数据结构、判断字符串是否以某个字符串结尾。

比特币钱包开发:钱包项目整体架构设计

比特币钱包开发:钱包项目整体架构设计

比特币钱包开发:钱包项目整体架构设计

比特币钱包开发:钱包项目整体架构设计

比特币钱包开发:钱包项目整体架构设计

参考资料

express的github:https://github.com/expressjs/express

ejs的github:https://github.com/tj/ejs

bitcore-wallet-client的github:https://github.com/bitpay/bitcore-wallet-client

项目源码Github地址

版权声明:博客中的文章版权归博主所有,未经授权禁止转载,转载请联系作者取得同意并注明出处。

未经授权禁止转载、改编,转载请注明出处!


以上所述就是小编给大家介绍的《比特币钱包开发:钱包项目整体架构设计》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

ECMAScript6入门

ECMAScript6入门

阮一峰 / 电子工业出版社 / 2014-8 / 49.00元

《ECMAScript6入门》全面介绍了ECMAScript6新引入的语法特性,覆盖了ECMAScript6与ECMAScript5的所有不同之处,对涉及的语法知识给予了详细介绍,并给出了大量简洁易懂的示例代码。 《ECMAScript6入门》为中级难度,适合已有一定JavaScript语言基础的读者,用来了解这门语言的最新发展;也可当作参考手册,查寻新增的语法点。一起来看看 《ECMAScript6入门》 这本书的介绍吧!

SHA 加密
SHA 加密

SHA 加密工具

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具