使用ENS自定义以太坊智能合约的地址管理

花项虎
• 阅读 1769

我们的目标是支持以太坊钱包和信用卡支付,以减少技术娴熟的客户的依赖。如果客户决定使用信用卡付款,我们必须使用我们的钱包并代他付款。

为此,我们决定在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"
          }'

现在你可以刷新浏览器了。瞧!地址已更改。

希望这个例子可以让你了解如何在应用程序中使用解析器。

摘要

Libellum是我们的本土产品,旨在利用以太坊区块链上的智能合约。该网络的分散性使我们能够为想要证明其有价值产品的制造商提供服务。然而,在开发阶段,我们遇到了一些不便。在这里阅读更多关于Libellum的信息。

当我们遵循KISS(keep it simple,stupid!)的原则时,我们宁愿不要过于复杂化简单的事情并尽可能多地节省时间。我们希望Tagged Public Resolver也能节省你的时间。让我们知道你对此的看法以及你如何处理这些问题。

======================================================================

分享一些以太坊、EOS、比特币等区块链相关的交互式在线编程实战教程:

  • java以太坊开发教程,主要是针对java和android程序员进行区块链以太坊开发的web3j详解。
  • python以太坊,主要是针对python工程师使用web3.py进行区块链以太坊开发的详解。
  • php以太坊,主要是介绍使用php进行智能合约开发交互,进行账号创建、交易、转账、代币开发以及过滤器和交易等内容。
  • 以太坊入门教程,主要介绍智能合约与dapp应用开发,适合入门。
  • 以太坊开发进阶教程,主要是介绍使用node.js、mongodb、区块链、ipfs实现去中心化电商DApp实战,适合进阶。
  • C#以太坊,主要讲解如何使用C#开发基于.Net的以太坊应用,包括账户管理、状态与交易、智能合约开发与交互、过滤器和交易等。
  • EOS教程,本课程帮助你快速入门EOS区块链去中心化应用的开发,内容涵盖EOS工具链、账户与钱包、发行代币、智能合约开发与部署、使用代码与智能合约交互等核心知识点,最后综合运用各知识点完成一个便签DApp的开发。
  • java比特币开发教程,本课程面向初学者,内容即涵盖比特币的核心概念,例如区块链存储、去中心化共识机制、密钥与脚本、交易与UTXO等,同时也详细讲解如何在Java代码中集成比特币支持功能,例如创建地址、管理钱包、构造裸交易等,是Java工程师不可多得的比特币开发学习课程。
  • php比特币开发教程,本课程面向初学者,内容即涵盖比特币的核心概念,例如区块链存储、去中心化共识机制、密钥与脚本、交易与UTXO等,同时也详细讲解如何在Php代码中集成比特币支持功能,例如创建地址、管理钱包、构造裸交易等,是Php工程师不可多得的比特币开发学习课程。
  • tendermint区块链开发详解,本课程适合希望使用tendermint进行区块链开发的工程师,课程内容即包括tendermint应用开发模型中的核心概念,例如ABCI接口、默克尔树、多版本状态库等,也包括代币发行等丰富的实操代码,是go语言工程师快速入门区块链开发的最佳选择。

汇智网原创翻译,转载请标明出处。这里是原文使用ENS自定义智能合约的地址管理

点赞
收藏
评论区
推荐文章
blmius blmius
4年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
美凌格栋栋酱 美凌格栋栋酱
7个月前
Oracle 分组与拼接字符串同时使用
SELECTT.,ROWNUMIDFROM(SELECTT.EMPLID,T.NAME,T.BU,T.REALDEPART,T.FORMATDATE,SUM(T.S0)S0,MAX(UPDATETIME)CREATETIME,LISTAGG(TOCHAR(
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
Stella981 Stella981
3年前
Defi数据引擎The Graph调用方法【含源码】
当你尝试访问以太坊智能合约以及DApp产生的区块链数据时,可能会发现很难将数据转换为一种可读的格式。TheGraph提供了一种用于查询以太坊和IPFS网络数据的索引协议,任何人都可以基于其提供的开放API创建并发布索引数据,即subgraph,这使得区块链数据更容易访问。在这个教程中,我们将学习如何使用TheGraph来查询Aave协议数据,使用的技术
Wesley13 Wesley13
3年前
37个常见的智能合约安全问题【以太坊】
SWCRegistry是以太坊安全人员和开发人员的必备知识库。它是SmartContractSecurity提供的以太坊智能合约安全漏洞分类及测试用例集,其中包含了37种以太坊Solidity智能合约开发中常见的安全问题的描述及后果,例如重入、溢出等,同时也给出了CWE漏洞分类、解决方案和作为示例的合约程序代码。用自己熟悉的语言学习以太坊DA
Easter79 Easter79
3年前
Twitter的分布式自增ID算法snowflake (Java版)
概述分布式系统中,有一些需要使用全局唯一ID的场景,这种时候为了防止ID冲突可以使用36位的UUID,但是UUID有一些缺点,首先他相对比较长,另外UUID一般是无序的。有些时候我们希望能使用一种简单一些的ID,并且希望ID能够按照时间有序生成。而twitter的snowflake解决了这种需求,最初Twitter把存储系统从MySQL迁移
Stella981 Stella981
3年前
DeFi Compound开发REST API
在这个教程中,我们将学习如何为DeFi协议Compound的智能合约创建一个可以通过HTTP访问的API开发接口,并学习如何使用Infura作为以太坊网络和应用之间的桥梁。Compound是一个基于以太坊的数字资产借贷利率协议。Infura(https://www.oschina.net/action/GoToLink?urlhttp%3A%2F%
Stella981 Stella981
3年前
Solidity内联汇编简明指南
在用Solidity开发以太坊智能合约时,使用汇编可以直接与EVM交互,降低gas开销成本,更精细的控制智能合约的行为,因此值得Solidity开发者学习并加以利用。本文是Solidity汇编开发的简明教程,旨在帮助你快速熟悉如何在Solidity智能合约代码中嵌入汇编代码。以太坊教程链接:Dapp入门(https://www.oschina.n
Python进阶者 Python进阶者
1年前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这