如何使用ENS自定义的以太坊地址管理
这篇文章给大家分享的是有关如何使用ENS自定义的以太坊地址管理的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。
创新互联坚持“要么做到,要么别承诺”的工作理念,服务领域包括:成都网站制作、网站设计、企业官网、英文网站、手机端网站、网站推广等服务,满足客户于互联网时代的广丰网站设计、移动媒体设计的需求,帮助企业找到有效的互联网解决方案。努力成为您成熟可靠的网络建设合作伙伴!
我们的目标是支持以太坊钱包和信用卡支付,以减少技术娴熟的客户的依赖。如果客户决定使用信用卡付款,我们必须使用我们的钱包并代他付款。
为此,我们决定在Ruby中构建后端,并在React中使用两个分散的前端客户端(dApp)。我们还利用了web3,这是最成熟的库,允许连接到以太坊节点。由于它是用JavaScript编写的,因此我们决定在Node.js中实现AWS Lambda函数,并通过我们的后端调用它们。
地址问题
一旦我们想要在所有环境(开发,测试,登录,生产)中保持地址同步,就会出现问题。任何合约的新版本的每次部署都要求我们在FE客户端和AWS Lambda函数中设置新地址,并要求我们通知所有开发人员他们应该在本地计算机上更新版本。从长远来看,这非常令人烦恼和耗时。我们决定花一些时间来解决这个问题。
以太坊名称服务
我们想到的第一个解决方案是使用公共ENS(以太坊名称服务),这是智能合约的“DNS”。与DNS类似,此服务将唯一的域名指向复杂,冗长且难以记忆的地址。一切都存储在我们智能合约所在的同一区块链中。此外,你可以随时更改地址,因此我们不必在应用程序的许多配置中执行此操作,而只需在ENS中执行此操作。非常棒!
但是,ENS中的域名注册需要一些时间,你需要锁定以太网才能拥有它,或者注册一个在28天后过期的.test域名。此外,你的域名不会直接指向你的地址;它指向你必须部署的解析器合约(用于自行管理所有子域)。在快速开发阶段,我们希望绕过这个过程并进行某种标记和版本控制。
我们的解析器
我们决定准备一个简化版本的解析器合约和一组帮助程序,简化管理地址的最低限度,而不必依赖ENS。我们还提出了标记地址的可能性,例如v1,v2,test,latest,default,production等。
我们还准备了一个脚本,你可以在geth控制台中加载该脚本,并使用方便的函数来配置指向地址的名称。这些帮助程序也可以在JS代码中导入。你可以在此处找到开源代码,完整文档和示例。
合约与官方ENS标准兼容,因此,最终可以注册你的真实域并指向此解析器。
用法示例
假设我们想在Express.js中编写一个简单的Web服务器,它将有两个用于设置和获取地址的端点。
在我们的示例中,我们使用Ganache,它允许我们部署智能合约并在本地环境中测试我们的网络。 Mac上的安装归结为下载应用程序并打开它 - 我们不需要配置任何东西。
一旦我们运行Ganache,我们就可以部署我们的解析器合约。首先,我们必须克隆存储库。
git clone https://github.com/tooploox/ens-tagged-resolver
下一步我们安装一些依赖:
cd ens-tagged-resolver npm install
我们的一个依赖是truffle,开发框架,这将帮助我们轻松部署我们的合约。我们为你配置了truffle以支持Ganache网络(在truffle.js文件中),因此我们可以使用一个命令部署它:
./node_modules/.bin/truffle migrate --network ganache
我们应该看到合约地址:
PublicResolver: 0x58552b526049049430c070fcd2148c806deb5b6c
我们稍后会需要这个地址。
现在,我们可以启动Express应用程序。让我们为它创建一个目录并初始化一个新的节点项目:
mkdir resolver cd resolver node init -y
然后我们可以使用body-parser和Web3安装Express:
npm install express body-parser web3@0.20 --save
我们还可以从我们的repo下载实用程序脚本:
curl -O https://raw.githubusercontent.com/tooploox/ens-tagged-resolver/master/tagged-resolver-utils.js
毕竟,我们可以在server.js文件中创建我们的服务器。
首先,我们必须导入express和Web3库。
const express = require("express"); const bodyParser = require("body-parser"); const Web3 = require("web3");
其次,我们需要我们的utils模块:
const { taggedResolverUtils } = require("./tagged-resolver-utils");
第三,我们将创建一个Web3实例:
web3 = new Web3(new Web3.providers.HttpProvider("http://localhost:7545"));
端口7545是Ganache使用的默认端口,你可以根据需要在设置中更改它。
接下来,我们将创建一个utils实例,将一个Web3实例作为依赖项传递:
const resolver = taggedResolverUtils(web3);
现在,我们可以构建两个端点:
const RESOLVER = "0x58552b526049049430c070fcd2148c806deb5b6c"; // The address of the deployed contract const app = express(); app.use(bodyParser.urlencoded({ extended: false })); app.use(bodyParser.json()); app.get("/addresses/:domain/:tag", (req, res) => { const addr = resolver.getAddrForTag(RESOLVER, req.params.domain, req.params.tag); res.send({ addr }); }); app.post("/addresses", (req, res) => { const txhash = resolver.setAddrForTag(RESOLVER, req.body.domain, req.body.address, req.body.tag); res.send({ txhash }); }); app.listen(3000);
整个列表可在此处获得:
const express = require("express"); const bodyParser = require("body-parser"); const Web3 = require("web3"); const { taggedResolverUtils } = require("./tagged-resolver-utils"); web3 = new Web3(new Web3.providers.HttpProvider("http://localhost:7545")); const resolver = taggedResolverUtils(web3); const RESOLVER = "0x43c26d5a8ac0b72f4688648f979c8d4ef27d782d"; // Address of the resolver contract const app = express(); app.use(bodyParser.urlencoded({ extended: false })); app.use(bodyParser.json()); app.get("/addresses/:domain/:tag", (req, res) => { const addr = resolver.getAddrForTag(RESOLVER, req.params.domain, req.params.tag); res.send({ addr }); }); // An example request to the end-point: // // curl -X POST \ // http://localhost:3000/addresses \ // -H 'content-type: application/json' \ // -d '{ // "domain": "libellum.eth", // "address": "0xF56547A13c8d62bCE5359C20f33bA570D864f01B", // "tag": "default" // }' app.post("/addresses", (req, res) => { const txhash = resolver.setAddrForTag(RESOLVER, req.body.domain, req.body.address, req.body.tag); res.send({ txhash }); }); app.listen(3000);
让我们保存文件并运行服务器:
node server.js
我们有两个端点:
[GET] http://localhost:3000/addresses/:domain/:tag [POST] http://localhost:3000/addresses (params: domain, address, tag)
首先,我们可以检查libellum.eth
域的地址是否具有default
标记:
http://localhost:3000/addresses/libellum.eth/default
我们可以看到地址是0x00000000000000000000000000000000000000000000
。这意味着它是未定义的。
我们可以通过POST请求简单地设置它:
curl -X POST \ http://localhost:3000/addresses \ -H 'content-type: application/json' \ -d '{ "domain": "libellum.eth", "address": "0xF56547A13c8d62bCE5359C20f33bA570D864f01B", "tag": "default" }'
现在你可以刷新浏览器了。瞧!地址已更改。
感谢各位的阅读!关于“如何使用ENS自定义的以太坊地址管理”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!
文章名称:如何使用ENS自定义的以太坊地址管理
网站网址:http://myzitong.com/article/ieisgh.html