亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何使用ENS自定義的以太坊地址管理

發布時間:2021-12-24 16:55:03 來源:億速云 閱讀:101 作者:小新 欄目:互聯網科技

這篇文章給大家分享的是有關如何使用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自定義的以太坊地址管理”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

湾仔区| 宝兴县| 云浮市| 南安市| 乐清市| 沧州市| 田林县| 浮梁县| 怀来县| 湖南省| 固阳县| 萨迦县| 富锦市| 阳东县| 寻甸| 封开县| 广河县| 宜良县| 莫力| 呼玛县| 永寿县| 灵石县| 齐齐哈尔市| 故城县| 诸暨市| 嘉定区| 昌图县| 迁西县| 科技| 东光县| 隆德县| 温宿县| 黄龙县| 上杭县| 古浪县| 无极县| 高要市| 资讯| 日土县| 常山县| 墨竹工卡县|