這篇文章給大家分享的是有關(guān)如何使用ENS自定義的以太坊地址管理的內(nèi)容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
創(chuàng)新互聯(lián)堅持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:成都網(wǎng)站制作、網(wǎng)站設(shè)計、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時代的廣豐網(wǎng)站設(shè)計、移動媒體設(shè)計的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!
我們的目標(biāo)是支持以太坊錢包和信用卡支付,以減少技術(shù)嫻熟的客戶的依賴。如果客戶決定使用信用卡付款,我們必須使用我們的錢包并代他付款。
為此,我們決定在Ruby中構(gòu)建后端,并在React中使用兩個分散的前端客戶端(dApp)。我們還利用了web3,這是最成熟的庫,允許連接到以太坊節(jié)點。由于它是用JavaScript編寫的,因此我們決定在Node.js中實現(xiàn)AWS Lambda函數(shù),并通過我們的后端調(diào)用它們。
一旦我們想要在所有環(huán)境(開發(fā),測試,登錄,生產(chǎn))中保持地址同步,就會出現(xiàn)問題。任何合約的新版本的每次部署都要求我們在FE客戶端和AWS Lambda函數(shù)中設(shè)置新地址,并要求我們通知所有開發(fā)人員他們應(yīng)該在本地計算機(jī)上更新版本。從長遠(yuǎn)來看,這非常令人煩惱和耗時。我們決定花一些時間來解決這個問題。
我們想到的第一個解決方案是使用公共ENS(以太坊名稱服務(wù)),這是智能合約的“DNS”。與DNS類似,此服務(wù)將唯一的域名指向復(fù)雜,冗長且難以記憶的地址。一切都存儲在我們智能合約所在的同一區(qū)塊鏈中。此外,你可以隨時更改地址,因此我們不必在應(yīng)用程序的許多配置中執(zhí)行此操作,而只需在ENS中執(zhí)行此操作。非常棒!
但是,ENS中的域名注冊需要一些時間,你需要鎖定以太網(wǎng)才能擁有它,或者注冊一個在28天后過期的.test域名。此外,你的域名不會直接指向你的地址;它指向你必須部署的解析器合約(用于自行管理所有子域)。在快速開發(fā)階段,我們希望繞過這個過程并進(jìn)行某種標(biāo)記和版本控制。
我們決定準(zhǔn)備一個簡化版本的解析器合約和一組幫助程序,簡化管理地址的最低限度,而不必依賴ENS。我們還提出了標(biāo)記地址的可能性,例如v1,v2,test,latest,default,production等。
我們還準(zhǔn)備了一個腳本,你可以在geth控制臺中加載該腳本,并使用方便的函數(shù)來配置指向地址的名稱。這些幫助程序也可以在JS代碼中導(dǎo)入。你可以在此處找到開源代碼,完整文檔和示例。
合約與官方ENS標(biāo)準(zhǔn)兼容,因此,最終可以注冊你的真實域并指向此解析器。
假設(shè)我們想在Express.js中編寫一個簡單的Web服務(wù)器,它將有兩個用于設(shè)置和獲取地址的端點。
在我們的示例中,我們使用Ganache,它允許我們部署智能合約并在本地環(huán)境中測試我們的網(wǎng)絡(luò)。 Mac上的安裝歸結(jié)為下載應(yīng)用程序并打開它 - 我們不需要配置任何東西。
一旦我們運行Ganache,我們就可以部署我們的解析器合約。首先,我們必須克隆存儲庫。
git clone https://github.com/tooploox/ens-tagged-resolver
下一步我們安裝一些依賴:
cd ens-tagged-resolver npm install
我們的一個依賴是truffle,開發(fā)框架,這將幫助我們輕松部署我們的合約。我們?yōu)槟闩渲昧藅ruffle以支持Ganache網(wǎng)絡(luò)(在truffle.js文件中),因此我們可以使用一個命令部署它:
./node_modules/.bin/truffle migrate --network ganache
我們應(yīng)該看到合約地址:
PublicResolver: 0x58552b526049049430c070fcd2148c806deb5b6c
我們稍后會需要這個地址。
現(xiàn)在,我們可以啟動Express應(yīng)用程序。讓我們?yōu)樗鼊?chuàng)建一個目錄并初始化一個新的節(jié)點項目:
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文件中創(chuàng)建我們的服務(wù)器。
首先,我們必須導(dǎo)入express和Web3庫。
const express = require("express"); const bodyParser = require("body-parser"); const Web3 = require("web3");
其次,我們需要我們的utils模塊:
const { taggedResolverUtils } = require("./tagged-resolver-utils");
第三,我們將創(chuàng)建一個Web3實例:
web3 = new Web3(new Web3.providers.HttpProvider("http://localhost:7545"));
端口7545是Ganache使用的默認(rèn)端口,你可以根據(jù)需要在設(shè)置中更改它。
接下來,我們將創(chuàng)建一個utils實例,將一個Web3實例作為依賴項傳遞:
const resolver = taggedResolverUtils(web3);
現(xiàn)在,我們可以構(gòu)建兩個端點:
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);
讓我們保存文件并運行服務(wù)器:
node server.js
我們有兩個端點:
[GET] http://localhost:3000/addresses/:domain/:tag [POST] http://localhost:3000/addresses (params: domain, address, tag)
首先,我們可以檢查libellum.eth
域的地址是否具有default
標(biāo)記:
http://localhost:3000/addresses/libellum.eth/default
我們可以看到地址是0x00000000000000000000000000000000000000000000
。這意味著它是未定義的。
我們可以通過POST請求簡單地設(shè)置它:
curl -X POST \ http://localhost:3000/addresses \ -H 'content-type: application/json' \ -d '{ "domain": "libellum.eth", "address": "0xF56547A13c8d62bCE5359C20f33bA570D864f01B", "tag": "default" }'
現(xiàn)在你可以刷新瀏覽器了。瞧!地址已更改。
感謝各位的閱讀!關(guān)于“如何使用ENS自定義的以太坊地址管理”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學(xué)到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!