在本教程中,我将向大家展示我能想到的最简单的例子,如何在web应用程序中将ENS地址转换为ETH地址。
、
知道如何做是很有价值的,因为大多数智能合约只接受ETH地址,而不接受ENS地址。
介绍
如何做到这一点的简单答案是,用户只需要从子图中查询数据。
有多种方法转换一个ENS地址:
1:使用ENS.js
MakerDAO:wstETH超过ETH成为Maker上最大抵押资产:7月8日消息,MakerDAO发推称,wstETH超过ETH成为Maker上DAI的最大抵押资产,5.3亿枚DAI来自wstETH,4.97亿枚来自ETH。[2023/7/9 22:26:20]
我曾经使用这个库来转换ENS地址。但是,它不适用于位于layer2的应用程序,所以我不会展示如何以这种方式进行操作。
2:使用ENS提供的去中心化子图
这是最可靠的方法,因为它是去中心化的。然而,当我在ENSdiscord中询问时,他们说不要用这个。此外,每次用户在你的应用程序上查询这个子图时,你都要花钱——所以它不是免费的。我认为ENS计划告诉每个人使用这个子图,但我可能是错的,我不确定他们会等待什么。
3:使用ENS提供的中心化子图
隐私技术初创公司Beldex完成2500万美元融资:金色财经报道,隐私技术初创公司 Beldex 完成 2500 万美元融资,数字资产做市商和投资公司 DWF Labs 投资并与其建立合作伙伴关系,这些资金将有助于推动 Beldex 生态系统的研发,而 DWF 将担任顾问并帮助开展营销活动。
Beldex 生态系统包括私人消息传递应用程序 BChat、去中心化虚拟专用网络 (VPN) BelNet、Web3 浏览器 Beldex 和跨链隐私协议 Beldex,它使跨链资产移动匿名化。[2023/2/23 12:25:42]
这个子图是免费使用的,也是巴黎高等师范学院推荐人们使用的。这是我将教如何使用这里。
项目设置
首先,在本地克隆repo。然后,安装所有依赖项并运行本地服务器。如果要检查localhost,就应该在页面上看到一个输入。如果输入了一个有效的ENS地址,就将看到有效性和ETH地址正在浏览器控制台中登录,确认转换。
Alameda在FTX的清算程序中获得秘密豁免:金色财经报道,根据FTX新任首席执行官John Ray提交给特拉华州法院的一系列文件,Alameda Research在FTX的清算程序中获得了“秘密豁免”。法庭文件中的披露虽然缺乏细节,但表明Alameda在FTX上进行高风险杠杆交易时具有优势。
据悉,FTX等加密衍生品交易所会自动出售借入资金的交易员的抵押品。(CoinDesk)[2022/11/18 13:18:58]
解释
既然你已经有了所有的代码,我将用本教程的剩余部分来解释它如何线性工作。
在主页上有一个输入(src/pages/index.tsx)。输入时,它设置inputAddress状态变量。
SBF:FTX将推出IP地址白名单功能,可显著降低API订单延迟:10月11日消息,FTX创始人兼首席执行官SBF在社交媒体上发文表示,FTX将推出IP地址白名单功能,用户可在API页面列出一串IP地址白名单,绕过Cloudflare直接快速访问FTX服务器。这将显著降低API订单延迟。[2022/10/11 10:30:34]
每当这个状态变量发生变化时,它都会被这里的useENSAddresshook检测到:
FTX 创始人SBF已在捐赠承诺平台Giving Pledge签署捐赠誓言:6月2日消息,FTX 创始人 SBF 已在捐赠承诺平台 Giving Pledge 签署捐赠誓言,承诺将大部分财富用于慈善事业。
据悉,Giving Pledge 成立于 2010 年,由微软创始人比尔·盖茨与投资人巴菲特共同创立,旨在鼓励超级富豪做出更大的捐赠。迄今为止,该承诺共有来自 28 个不同国家的 230 个签署者,包括扎克伯格、马斯克等。(Coindesk)[2022/6/2 3:57:26]
现在打开Reacthook的文件(src/components/useENSAddress.ts)。你可以看到它使用了里面的useEffect的hook。这个useEffect的依赖项列表中有一个inputAddress参数。这会导致useEffect主体在每次inputAddress改变时(通过用户输入)被调用。
useEffect(():any=>{...bodycodehere...},)
那么当调用useEffect的主体时会发生什么呢?几乎所有发生的都是run方法被调用。
run方法通过调用其他方法来设置ETH地址。让我们检查一下那个方法,因为它是调用堆栈中的下一个。
打开src/stores/ensStore.ts。里面是queryENSForETHAddress方法。
首先,它进行软检查,看看传入的值是否为ENS地址。
然后,它查询由HTTP_GRAPHQL_ENDPOINT定义的子图。为了获得我们想要的数据,我们需要创建一个graphql查询。这就是getQueryENSForETHAddress方法的作用。
现在转到那个方法。它正在查询子图以获取传入的ENS地址的数据。
如果你想知道我是怎么想通了如何创建此查询,那么你需要更多关于thegraph和graphql工作的知识。基本上,每个子图都有一个游乐场,我一直在摆弄它,直到我得到了所需的数据。
例如,在playground中,可以输入查询,然后按下播放键,以便查看返回的数据。
现在,如果返回到queryENSForETHAddress,你可以看到数据存储在result变量中:
return语句的基本意思是,ifvalidENSaddresspassedin,returntheETHaddress…otherwise,return0。你还会注意到返回的数据采用来自getQueryENSForETHAddress。
一旦它返回,它可以追溯到useEffect中useENSAddress.ts的文件和设置ethAddress状态变量。
然后,返回三个值:
return
第一个值表示传入的值是否有效。第二个值是从子图中检索到的ETH地址。第三个值表示这些值当前是否正在加载。
差不多就是这样了。完成这个过程后,我将这些值记录到主页上的控制台。
现在你已经知道如何将第一层和第二层的ENS地址转换为ETH地址。
Source:https://medium.com/coinmonks/how-to-convert-ens-address-to-eth-address-in-js-251c6209c208
郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。