[TOC]
एफएमजेड के साथ आसान परिचय एथेरियम आधारित वेब 3 विकास
एथेरियम एक ब्लॉकचेन तकनीक पर आधारित स्मार्ट कॉन्ट्रैक्ट प्लेटफॉर्म है जो स्मार्ट कॉन्ट्रैक्ट लिखने और तैनात करने के लिए एक विकेंद्रीकृत तरीका प्रदान करता है। स्मार्ट कॉन्ट्रैक्ट एक विशेष कंप्यूटर प्रोग्राम है जो ब्लॉकचेन पर स्वचालित रूप से निष्पादित किया जा सकता है और किसी तीसरे पक्ष पर भरोसा किए बिना सभी प्रकार के व्यावसायिक तर्क को लागू कर सकता है।
आविष्कारक क्वांटिफाइड ट्रेडिंग प्लेटफॉर्म (((FMZ.COM) एक आसान उपयोग एपीआई प्रदान करता है जो डेवलपर्स को एथेरियम ब्लॉकचेन और इसके पारिस्थितिकी तंत्र के साथ अधिक आसानी से बातचीत करने की अनुमति देता है।
इस ट्यूटोरियल में उदाहरणों का उपयोग करेंJavaScript
भाषा लेखन, परीक्षण वातावरण का उपयोगएथेरियम、Goerli परीक्षण नेटवर्क⇒ एफएमजेड प्लेटफॉर्म के एपीआई दस्तावेज में ट्यूटोरियल में उपयोग किए गए एपीआई इंटरफेस के साथ-साथ संबंधित विवरण और कोड उदाहरण भी देखे जा सकते हैं।
एफएमजेड क्वांटिफाइड ट्रेडिंग प्लेटफॉर्म का उपयोग करने से पहले, हमें कुछ बुनियादी अवधारणाओं से परिचित होने की आवश्यकता हैः
एफएमजेड पर क्वांटिफाइड ट्रेडिंग प्लेटफॉर्म की आधिकारिक वेबसाइटhttps://www.fmz.com) पंजीकरण, लॉगिन के बाद प्लेटफॉर्म के विभिन्न कार्यों का उपयोग करना संभव है। FMZ वेबसाइट पूरे सिस्टम का प्रशासन है, उपयोगकर्ता द्वारा लिखे गए प्रोग्राम वास्तव में होस्ट पर चल रहे हैं। होस्ट के लिए यह सॉफ्टवेयर प्रोग्राम विभिन्न उपकरणों पर तैनात किया जा सकता है, जैसे कि सर्वर, कंप्यूटर आदि। जब उपयोगकर्ता FMZ वेबसाइट पर एक अच्छा प्रोग्राम लिखता है, तो FMZ प्लेटफ़ॉर्म होस्ट पर एक प्रोग्राम इंस्टेंस शुरू करने के लिए होस्ट के साथ संवाद करता है।
यदि आप प्रोग्राम इंस्टेंस को चलाना चाहते हैं, तो आपको एक होस्ट को तैनात करना होगा, जो कि एक बहुत ही सरल और मंच पर तैनाती ट्यूटोरियल के साथ तैनात किया गया है। आप FMZ पर उपलब्ध "एक बटन पर तैनाती प्रबंधक" का उपयोग करके स्वचालित रूप से FMZ के लिए किराए के सर्वर पर तैनात कर सकते हैं।
व्यक्तिगत उपकरणों पर होस्टिंग की तैनाती
सर्वर, पर्सनल कंप्यूटर आदि उपकरणों पर प्रबन्धक प्रोग्राम चलाने के लिए तैनात किया जा सकता है, जब तक कि नेटवर्क के कामकाज को सुनिश्चित किया जाता है। तैनाती के मुख्य चरणों में निम्नलिखित शामिल हैंः
1. लॉग इन करें या उस डिवाइस को खोलें जहां आप होस्टिंग प्रोग्राम को तैनात करना चाहते हैं, उदाहरण के लिएसर्वर पर लॉग इन करेंयाकंप्यूटर को ऑपरेटिंग सिस्टम में खोलें..
2. संबंधित संस्करण के होस्टिंग प्रोग्राम (डिवाइस ऑपरेटिंग सिस्टम के आधार पर) डाउनलोड करें।https://www.fmz.com/m/add-node
3. डाउनलोड करने के लिए एक संपीड़न पैक है, जिसे अनसंपीड़न की आवश्यकता है।
4. इस होस्टिंग प्रोग्राम को चलाने के लिए, होस्टिंग प्रोग्राम एक नाम हैrobot
FMZ में प्रवेश करने के बाद FMZ में प्रवेश करने के लिए आवश्यक है कि प्रत्येक FMZ खाते के लिए एक विशिष्ट संचार पता है।https://www.fmz.com/m/add-node
पृष्ठ पर अपने पते को देखने के लिए जा सकते हैं ((यानी./robot -s node.fmz.com/xxxxx
यह पते, यहाँ.xxxxx
प्रत्येक FMZ खाते में स्थान की सामग्री अलग-अलग दिखाई देती है) । अंत में, FMZ खाते का पासवर्ड दर्ज करना आवश्यक है, जिसे कॉन्फ़िगर करने के बाद प्रशासक प्रोग्राम चलाने के लिए आवश्यक है ।
FMZ प्लेटफॉर्म के "एक बटन पर होस्टिंग डिप्लोय करें" फ़ंक्शन का उपयोग करना
एफएमजेड प्लेटफॉर्म पर एक होस्ट पेज जोड़ा गया है, जिसका पता हैःhttps://www.fmz.com/m/add-node
एफएमजेड क्वांटिफाइड ट्रेडिंग प्लेटफॉर्म एक मुफ्त डिबगिंग टूल प्रदान करता है, जो समर्थन करता हैJavaScript
,TypeScript
यह पेज इस प्रकार हैःhttps://www.fmz.com/m/debugउदाहरण निर्माण के लिए शुल्क लगता है, इसलिए इस उपकरण का उपयोग प्रारंभिक शिक्षा के दौरान परीक्षण, सीखने के लिए किया जा सकता है। उदाहरण निर्माण के अलावा अन्य पहलुओं में कोई अंतर नहीं है।
उपयोगTypeScript
भाषाओं में, आपको कोड की पहली पंक्ति में लिखना होगा।// @ts-check
के लिए स्विच करने के लिएTypeScript
मोड, नहीं स्विच करने के लिए डिफ़ॉल्ट हैJavaScript
भाषाएँ ।
एफएमजेड पर "एक्सचेंज" एक सामान्य अवधारणा है, जो सीईएक्स एक्सचेंज के लिए एक विशिष्ट एक्सचेंज खाता कॉन्फ़िगरेशन को संदर्भित करती है। वेब 3 के लिए, यह एक्सचेंज एक कॉन्फ़िगरेशन जानकारी को संदर्भित करता है जिसमें नोड पता, निजी कुंजी कॉन्फ़िगरेशन शामिल हैं।
FMZ प्लेटफॉर्म पर लॉग इन करने के बाद,https://www.fmz.com/m/add-platform
यह पृष्ठ, एक्सचेंज की जानकारी को कॉन्फ़िगर कर सकता है, जहां एक्सचेंज एक सामान्य अवधारणा है।
चुनेंWeb3
आरपीसी नोड एड्रेस को कॉन्फ़िगर करने के लिए, निजी कुंजी को कॉन्फ़िगर करने के लिए, आप सुरक्षा तंत्र देखने के लिए निचले दाएं कोने में "संवेदनशील जानकारी को स्वतंत्र निजी कुंजी के साथ एन्क्रिप्ट करना" पर क्लिक कर सकते हैं।
नोड्स स्वयं बनाए गए नोड्स के साथ या नोड सर्वर द्वारा प्रदान किए गए नोड्स के साथ हो सकते हैं। नोड सर्वर बहुत सारे हैं, उदाहरण के लिएःइन्फ्यूरा; पंजीकरण के बाद, आप अपने खाते के नोड पते को देख सकते हैं; मुख्य नेटवर्क, परीक्षण नेटवर्क उपलब्ध हैं, तुलनात्मक रूप से सुविधाजनक है, इस नोड पते को ऊपर दिए गए चित्र में कॉन्फ़िगर करें।Rpc Address
इस प्रकार, एक टैग अपने आप को नाम दे सकता है और विनिमय वस्तुओं को अलग करने के लिए उपयोग किया जा सकता है।
चित्र मेंhttps://mainnet.infura.io/v3/xxxxxxxxxxxxx
यह निजी इंफुरा के ईटीएच मुख्य नेटवर्क के आरपीसी नोड का पता है।
在部署好托管者程序、配置好交易所对象的前提下,就可以使用FMZ.COM的「调试工具」进行测试了。调用以太坊RPC方法和以太坊交互,除了本章节列举介绍的几个RPC方法,其它RPC方法可以查询资料了解,例如https://www.quicknode.com/docs。
हम कुछ सरल उदाहरणों को सूचीबद्ध करते हैं, मूल बातें शुरू करते हैं. विभिन्न भाषाओं और उपकरणों के लिए वेब 3 का उपयोग करने के तरीके हैंः
एफएमजेड पर आरपीसी विधि कॉल के लिए भी पैकेज किया गया है, जो एफएमजेड के एपीआई फ़ंक्शन में पैकेज किए गए हैं।exchange.IO
मध्य में.exchange.IO("api", "eth", ...)
◎ पहला पैरामीटर फिक्स्ड इनपुट"api"
, दूसरा पैरामीटर फिक्स्ड इनपुट"eth"
, अन्य पैरामीटर आरपीसी विधि पर निर्भर करते हैं जिसे विशेष रूप से बुलाया जाता है।
हम एफएमजेड प्लेटफॉर्म का उपयोग करते हैं।Log
फ़ंक्शन,Log
फ़ंक्शन कई पैरामीटर में प्रवेश कर सकता है और फिर FMZ प्लेटफॉर्म पर "डिबगिंग टूल" या "डिस्क" पृष्ठ में लॉग क्षेत्र में आउटपुट कर सकता है, "डिबगिंग टूल" पृष्ठ हमारे परीक्षण का मुख्य उपकरण होगा।
एथेरियमeth_getBalance
एक विधि जो किसी एथेरियम पते पर ईटीएच शेष राशि का पता लगाने के लिए उपयोग की जाती है, जिसमें दो पैरामीटर पास करने की आवश्यकता होती है।
तो चलिए ईथरिन के संस्थापक से पूछते हैं।V神
ETH वॉलेट का पता, जो ज्ञात है, हैः0xd8dA6BF26964aF9D7eEd9e03E53415D37aA96045
。
function main() {
let ethBalance = exchange.IO("api", "eth", "eth_getBalance", "0xd8dA6BF26964aF9D7eEd9e03E53415D37aA96045", "latest")
Log("ethBalance:", ethBalance)
}
होस्ट (चित्रः linux/amd64...) को तैनात किया गया है और एक्सचेंज ऑब्जेक्ट (चित्रः वेब 3 परीक्षण) को कॉन्फ़िगर किया गया है, और डिबगिंग टूल में कोड का परीक्षण किया गया हैः
इस कोड को निष्पादित करने के लिए "कार्य करें" बटन पर क्लिक करें और परिणाम दिखाई देगाः
ethबालन्सः 0x117296558f185bbc4c6
Log
फ़ंक्शन को प्रिंट करेंethBalance
चर का मान हैः0x117296558f185bbc4c6
, स्ट्रिंग प्रकार है.16 अंकों के ETH शेष,wei
यूनिट,1e18 wei
1 के लिएETH
इसलिए, इसे पढ़ने योग्य दशमलव ईटीएच संतुलन में बदलने के लिए रूपांतरण की आवश्यकता है।
होगाethBalance
डेटा को पठनीय में परिवर्तित करेंः
function main() {
let ethBalance = exchange.IO("api", "eth", "eth_getBalance", "0xd8dA6BF26964aF9D7eEd9e03E53415D37aA96045", "latest")
Log("ethBalance:", ethBalance)
// 将ethBalance转换为可读的数据
let vitalikEthBalance = parseInt(ethBalance.substring(2), 16) / 1e18
Log("vitalikEthBalance:", vitalikEthBalance)
}
ऊपरhttps://etherscan.io/
पूछताछः
हालाँकि, यह तर्क दिया जाता है कि भाषा की सटीकता के मुद्दे में कुछ विचलन हो सकता है, इसलिए एफएमजेड प्लेटफॉर्म ने डेटा को संसाधित करने के लिए दो अंतर्निहित कार्य किए हैंः
एक बार फिर कोड को संशोधित करेंः
function main() {
let ethBalance = exchange.IO("api", "eth", "eth_getBalance", "0xd8dA6BF26964aF9D7eEd9e03E53415D37aA96045", "latest")
// ETH的精度单位为1e18
let ethDecimal = 18
Log("vitalikEthBalance:", Number((BigDecimal(BigInt(ethBalance)) / BigDecimal(Math.pow(10, ethDecimal))).toString()))
}
जीवनसाथी बैलेंसः 5149.6244846875215
eth_chainId
औरnet_version
दोनों फ़ंक्शन वर्तमान आरपीसी नोड के प्रवेश के लिए ब्लॉकचेन का आईडी वापस करते हैं, अंतर यह है किnet_version
यह दशमलव संख्याओं की संख्या को लौटाता है।eth_chainId
यह 16 अंकों की संख्या को लौटाता है।
चेन आईडी के अनुरूप नेटवर्क नाम
1 - ethereum mainnet
2 - morden testnet (deprecated)
3 - ropsten testnet
4 - rinkeby testnet
5 - goerli testnet
11155111 - sepolia testnet
10 - optimism mainnet
69 - optimism kovan testnet
42 - kovan testnet
137 - matic/polygon mainnet
80001 - matic/polygon mumbai testnet
250 - fantom mainnet
100 - xdai mainnet
56 - bsc mainnet
एथेरियम टेस्टिंग नेट का उपयोग करनाgoerli
नोड टेस्टः
function main() {
let netVersionId = exchange.IO("api", "eth", "net_version")
let ethChainId = exchange.IO("api", "eth", "eth_chainId")
Log("netVersionId:", netVersionId)
Log("ethChainId:", ethChainId, " ,转换:", parseInt(ethChainId.substring(2), 16))
}
कॉल करेंeth_gasPrice
विधि, वर्तमान चेन पर क्वेरीgas price
。
function toAmount(s, decimals) {
return Number((BigDecimal(BigInt(s)) / BigDecimal(Math.pow(10, decimals))).toString())
}
function main() {
let gasPrice = exchange.IO("api", "eth", "eth_gasPrice")
Log("gasPrice:", gasPrice, " ,转换:", toAmount(gasPrice, 0))
}
यहाँ हम 16 अंकों की स्ट्रिंग को पढ़ने योग्य संख्यात्मक मान में परिवर्तित करने के लिए एक फ़ंक्शन लिखते हैंःtoAmount
⇒ यह भी ध्यान दिया जाना चाहिए कि गैस मूल्य की इकाई हैwei
तो, हम इसे आकार देते हैं।decimals
इसके लिए वास्तविक पैरामीटर का मान 0 हो सकता है।
eth_blockNumbe
ब्लॉक की ऊंचाई का पता लगाने के लिए प्रयोग किया जाता है।
function toAmount(s, decimals) {
return Number((BigDecimal(BigInt(s)) / BigDecimal(Math.pow(10, decimals))).toString())
}
function main() {
let blockNumber = exchange.IO("api", "eth", "eth_blockNumber")
Log(toAmount(blockNumber, 0))
}
डिबगिंग टूल में चल रहा हैः
https://etherscan.io/
पूछताछः
ब्लॉक की जानकारी के लिए क्वेरी करें।
function main() {
let blockNumber = exchange.IO("api", "eth", "eth_blockNumber")
Log(blockNumber)
let blockMsg = exchange.IO("api", "eth", "eth_getBlockByNumber", blockNumber, true)
Log(typeof(blockMsg), blockMsg)
// 由于Log输出的内容过多,会自动截断,所以遍历返回的区块信息各个字段,逐个打印
for (let key in blockMsg) {
Log("key:", key, ", val:", blockMsg[key])
}
}
"डिबगिंग टूल" में निष्पादित करने के लिए निम्नलिखित जानकारी प्राप्त करेंः
Ethereum पर कई स्मार्ट कॉन्ट्रैक्ट एप्लिकेशन चल रहे हैं।ENS
इस तरह के लोगों के लिए, यह बहुत अच्छा है।ENS
एथेरियम डोमेन नाम सेवा (अंग्रेज़ीः Ethereum Name Service) एथेरियम ब्लॉकचेन पर आधारित एक विकेंद्रीकृत डोमेन नाम विश्लेषण सेवा है।
याद रखें कि ट्यूटोरियल में हमने एथेरियम के संस्थापक वी गॉड के बटुए के संतुलन का उदाहरण पूछा था।0xd8dA6BF26964aF9D7eEd9e03E53415D37aA96045
◊ तो हम इस पते को कैसे जानते हैं?ENS
स्मार्ट कॉन्ट्रैक्ट, एक सहज नाम का उपयोग करनाvitalik.eth
इस तरह से, हम अपने ब्लॉग पर एक लेख लिखते हैं, जिसमें हम अपने ब्लॉग के बारे में पूछते हैं।
इस अध्याय में निम्नलिखित सामग्री को एथेरियम नेटवर्क वातावरण का उपयोग करके,ENS
प्रलेखन के लिए ज्ञात है कि एथेरियम डोमेन नामों के लिए क्वेरी की आवश्यकता हैHashing Names
, निम्नलिखित कोड का उपयोग करके जोड़ेंvitalik.eth
नामों का संसाधित किया जा रहा है।
function nameHash(name) {
if (name == "") {
return "0000000000000000000000000000000000000000000000000000000000000000"
} else {
let arr = name.split(".")
let label = arr[0]
arr.shift()
let remainder = arr.join(".")
return Encode("sha3.keccak256", "hex", "hex", nameHash(remainder) + Encode("sha3.keccak256", "raw", "hex", label))
}
}
और हम एक और अजीब फ़ंक्शन देख रहे हैं.Encode
यह फ़ंक्शन एक एपीआई फ़ंक्शन है जो विशेष रूप से एफएमजेड प्लेटफ़ॉर्म पर एन्कोडिंग संचालन के लिए उपयोग किया जाता है। यह फ़ंक्शन कई एन्कोडिंग विधियों का समर्थन करता है और कई हैश एल्गोरिदम का समर्थन करता है।
Encode(algo, inputFormat, outputFormat, data, keyFormat, key string)
ENS दस्तावेज़ में वर्णित के अनुसार उपयोग करेंsha3.keccak256
एल्गोरिदम डेटा को संसाधित करते हैं।
कॉल करेंnameHash
फ़ंक्शन, उदाहरण के लिएःLog(nameHash("vitalik.eth"))
और आप कर सकते हैंःee6c4522aab0003e8d14cd40a6af439055fd2577951148c14b6cea9a53475835
, इसके साथ "0x" उपसर्ग जोड़ना होगा.0xee6c4522aab0003e8d14cd40a6af439055fd2577951148c14b6cea9a53475835
एनईएस स्मार्ट कॉन्ट्रैक्ट के रूप मेंresolver
विधि के पैरामीटर।
let ensNode = "0x" + nameHash("vitalik.eth") // 准备好调用resolver方法的参数ensNode
ईएनएस दस्तावेजों की जांच करने से पता चलता है कि ईएनएस स्मार्ट कॉन्ट्रैक्ट एप्लिकेशन का अनुबंध पता हैः0x00000000000C2E074eC69A0dFb2997BA6C7d2e1e
◊ स्मार्ट कॉन्ट्रैक्ट पर कॉल करनाresolver
इस तरह के तरीकों से पहले, हमें एक अनुबंध तैयार करना होगा।ABI
。
यहाँ आने के लिए सीखने के लिए, आप पूछ सकते हैं कि स्मार्ट कॉन्ट्रैक्ट क्या है?ABI
क्या?
ABI,即应用程序二进制接口(Application Binary Interface),是智能合约与外部世界进行通信的接口标准。
智能合约的 ABI 定义了合约的函数接口、参数类型、返回值等信息,以及调用合约的方式和参数传递方式等规范。
智能合约的 ABI 通常以 JSON 格式存储,包含以下信息:
合约的函数接口:函数名、参数列表、返回值等信息。
函数参数类型:如 uint256、bool、string 等。
函数的输入参数和输出参数的编码方式:智能合约使用一种称为 Solidity ABI 的编码方式来编码函数的输入参数和输出参数,
以便与以太坊网络进行交互。
在以太坊网络中,使用智能合约的 ABI 来调用合约的函数。当需要调用合约函数时,需要提供函数名和函数参数,以及将函数参数按照 ABI 编码方式编码后的字节码。
以太坊节点会将这些信息打包成一笔交易,并将交易发送到以太坊网络中执行。
智能合约的 ABI 在 Solidity 语言中可以通过 interface 关键字来定义。以太坊开发工具如 Remix IDE、Truffle 等也提供了 ABI 编辑和生成工具,
使得开发者可以方便地创建和使用智能合约的 ABI。
ENS के एबीआई से निकालेंresolver
विधि का एक हिस्सा है, और यह भी पूर्ण एबीआई का उपयोग कर सकते हैंhttps://etherscan.io/
अनुबंध के लिए ABI का पता लगाएं, या अन्य तरीकों से ABI प्राप्त करें (उदाहरण के लिएः संबंधित परियोजना दस्तावेज) ।
let abiENS_resolver = `[{"constant":true,"inputs":[{"internalType":"bytes32","name":"node","type":"bytes32"}],"name":"resolver","outputs":[{"internalType":"address","name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"}]`
यहाँ हम FMZ प्लेटफॉर्म पर एक और नया कॉल करने का तरीका सीख रहे हैं।exchange.IO("abi", address, abiContent)
इस विधि का उपयोग करके एबीआई को पंजीकृत करें।address
एक पैरामीटर एक स्मार्ट कॉन्ट्रैक्ट का पता है।abiContent
पैरामीटर संबंधित स्मार्ट कॉन्ट्रैक्ट एबीआई (स्ट्रिंग) है।
let abiENS_resolver = `[{"constant":true,"inputs":[{"internalType":"bytes32","name":"node","type":"bytes32"}],"name":"resolver","outputs":[{"internalType":"address","name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"}]`
exchange.IO("abi", "0x00000000000C2E074eC69A0dFb2997BA6C7d2e1e", abiENS_resolver) // 0x00000000000C2E074eC69A0dFb2997BA6C7d2e1e 是在以太坊主网上部署的ENS智能合约的地址
अब आप ENS स्मार्ट कॉन्ट्रैक्ट को कॉल कर सकते हैं।resolver
विधि है, विधि वापस आता हैENS: Public Resolver
अनुबंध का पता।
let resolverAddress = exchange.IO("api", "0x00000000000C2E074eC69A0dFb2997BA6C7d2e1e", "resolver", ensNode)
उपयोगENS: Public Resolver
अनुबंधaddr
कैसे प्राप्त करें V के बटुए का पता?ENS: Public Resolver
इस स्मार्ट कॉन्ट्रैक्ट में एबीआई की जानकारी अभी भी उपलब्ध है।https://etherscan.io/
प्राप्त किया गया।
let abiENSPublicResolver = `[{"inputs":[{"internalType":"contract ENS","name":"_ens","type":"address"}],"payable":false,"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"bytes32","name":"node","type":"bytes32"},{"indexed":true,"internalType":"uint256","name":"contentType","type":"uint256"}],"name":"ABIChanged","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"bytes32","name":"node","type":"bytes32"},{"indexed":false,"internalType":"address","name":"a","type":"address"}],"name":"AddrChanged","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"bytes32","name":"node","type":"bytes32"},{"indexed":false,"internalType":"uint256","name":"coinType","type":"uint256"},{"indexed":false,"internalType":"bytes","name":"newAddress","type":"bytes"}],"name":"AddressChanged","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"bytes32","name":"node","type":"bytes32"},{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"target","type":"address"},{"indexed":false,"internalType":"bool","name":"isAuthorised","type":"bool"}],"name":"AuthorisationChanged","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"bytes32","name":"node","type":"bytes32"},{"indexed":false,"internalType":"bytes","name":"hash","type":"bytes"}],"name":"ContenthashChanged","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"bytes32","name":"node","type":"bytes32"},{"indexed":false,"internalType":"bytes","name":"name","type":"bytes"},{"indexed":false,"internalType":"uint16","name":"resource","type":"uint16"},{"indexed":false,"internalType":"bytes","name":"record","type":"bytes"}],"name":"DNSRecordChanged","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"bytes32","name":"node","type":"bytes32"},{"indexed":false,"internalType":"bytes","name":"name","type":"bytes"},{"indexed":false,"internalType":"uint16","name":"resource","type":"uint16"}],"name":"DNSRecordDeleted","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"bytes32","name":"node","type":"bytes32"}],"name":"DNSZoneCleared","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"bytes32","name":"node","type":"bytes32"},{"indexed":true,"internalType":"bytes4","name":"interfaceID","type":"bytes4"},{"indexed":false,"internalType":"address","name":"implementer","type":"address"}],"name":"InterfaceChanged","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"bytes32","name":"node","type":"bytes32"},{"indexed":false,"internalType":"string","name":"name","type":"string"}],"name":"NameChanged","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"bytes32","name":"node","type":"bytes32"},{"indexed":false,"internalType":"bytes32","name":"x","type":"bytes32"},{"indexed":false,"internalType":"bytes32","name":"y","type":"bytes32"}],"name":"PubkeyChanged","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"bytes32","name":"node","type":"bytes32"},{"indexed":true,"internalType":"string","name":"indexedKey","type":"string"},{"indexed":false,"internalType":"string","name":"key","type":"string"}],"name":"TextChanged","type":"event"},{"constant":true,"inputs":[{"internalType":"bytes32","name":"node","type":"bytes32"},{"internalType":"uint256","name":"contentTypes","type":"uint256"}],"name":"ABI","outputs":[{"internalType":"uint256","name":"","type":"uint256"},{"internalType":"bytes","name":"","type":"bytes"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[{"internalType":"bytes32","name":"node","type":"bytes32"}],"name":"addr","outputs":[{"internalType":"address payable","name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[{"internalType":"bytes32","name":"node","type":"bytes32"},{"internalType":"uint256","name":"coinType","type":"uint256"}],"name":"addr","outputs":[{"internalType":"bytes","name":"","type":"bytes"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[{"internalType":"bytes32","name":"","type":"bytes32"},{"internalType":"address","name":"","type":"address"},{"internalType":"address","name":"","type":"address"}],"name":"authorisations","outputs":[{"internalType":"bool","name":"","type":"bool"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"internalType":"bytes32","name":"node","type":"bytes32"}],"name":"clearDNSZone","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[{"internalType":"bytes32","name":"node","type":"bytes32"}],"name":"contenthash","outputs":[{"internalType":"bytes","name":"","type":"bytes"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[{"internalType":"bytes32","name":"node","type":"bytes32"},{"internalType":"bytes32","name":"name","type":"bytes32"},{"internalType":"uint16","name":"resource","type":"uint16"}],"name":"dnsRecord","outputs":[{"internalType":"bytes","name":"","type":"bytes"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[{"internalType":"bytes32","name":"node","type":"bytes32"},{"internalType":"bytes32","name":"name","type":"bytes32"}],"name":"hasDNSRecords","outputs":[{"internalType":"bool","name":"","type":"bool"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[{"internalType":"bytes32","name":"node","type":"bytes32"},{"internalType":"bytes4","name":"interfaceID","type":"bytes4"}],"name":"interfaceImplementer","outputs":[{"internalType":"address","name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"internalType":"bytes[]","name":"data","type":"bytes[]"}],"name":"multicall","outputs":[{"internalType":"bytes[]","name":"results","type":"bytes[]"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[{"internalType":"bytes32","name":"node","type":"bytes32"}],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[{"internalType":"bytes32","name":"node","type":"bytes32"}],"name":"pubkey","outputs":[{"internalType":"bytes32","name":"x","type":"bytes32"},{"internalType":"bytes32","name":"y","type":"bytes32"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"internalType":"bytes32","name":"node","type":"bytes32"},{"internalType":"uint256","name":"contentType","type":"uint256"},{"internalType":"bytes","name":"data","type":"bytes"}],"name":"setABI","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"bytes32","name":"node","type":"bytes32"},{"internalType":"uint256","name":"coinType","type":"uint256"},{"internalType":"bytes","name":"a","type":"bytes"}],"name":"setAddr","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"bytes32","name":"node","type":"bytes32"},{"internalType":"address","name":"a","type":"address"}],"name":"setAddr","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"bytes32","name":"node","type":"bytes32"},{"internalType":"address","name":"target","type":"address"},{"internalType":"bool","name":"isAuthorised","type":"bool"}],"name":"setAuthorisation","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"bytes32","name":"node","type":"bytes32"},{"internalType":"bytes","name":"hash","type":"bytes"}],"name":"setContenthash","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"bytes32","name":"node","type":"bytes32"},{"internalType":"bytes","name":"data","type":"bytes"}],"name":"setDNSRecords","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"bytes32","name":"node","type":"bytes32"},{"internalType":"bytes4","name":"interfaceID","type":"bytes4"},{"internalType":"address","name":"implementer","type":"address"}],"name":"setInterface","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"bytes32","name":"node","type":"bytes32"},{"internalType":"string","name":"name","type":"string"}],"name":"setName","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"bytes32","name":"node","type":"bytes32"},{"internalType":"bytes32","name":"x","type":"bytes32"},{"internalType":"bytes32","name":"y","type":"bytes32"}],"name":"setPubkey","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"bytes32","name":"node","type":"bytes32"},{"internalType":"string","name":"key","type":"string"},{"internalType":"string","name":"value","type":"string"}],"name":"setText","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[{"internalType":"bytes4","name":"interfaceID","type":"bytes4"}],"name":"supportsInterface","outputs":[{"internalType":"bool","name":"","type":"bool"}],"payable":false,"stateMutability":"pure","type":"function"},{"constant":true,"inputs":[{"internalType":"bytes32","name":"node","type":"bytes32"},{"internalType":"string","name":"key","type":"string"}],"name":"text","outputs":[{"internalType":"string","name":"","type":"string"}],"payable":false,"stateMutability":"view","type":"function"}]`
exchange.IO("abi", resolverAddress, abiENSPublicResolver)
अंतिम कॉलENS: Public Resolver
अनुबंधaddr
विधि, पैरामीटर अभी भीensNode
。
let vitalikAddress = exchange.IO("api", resolverAddress, "addr", ensNode)
Log("vitalikAddress:", vitalikAddress)
लॉग फ़ंक्शन आउटपुटः
vitalikAddress: 0xd8da6bf26964af9d7eed9e03e53415d37aa96045
function nameHash(name) {
if (name == "") {
return "0000000000000000000000000000000000000000000000000000000000000000"
} else {
let arr = name.split(".")
let label = arr[0]
arr.shift()
let remainder = arr.join(".")
return Encode("sha3.keccak256", "hex", "hex", nameHash(remainder) + Encode("sha3.keccak256", "raw", "hex", label))
}
}
function main() {
// 计算名称
let ensNode = "0x" + nameHash("vitalik.eth")
// 注册ENS合约
let abiENS_resolver = `[{"constant":true,"inputs":[{"internalType":"bytes32","name":"node","type":"bytes32"}],"name":"resolver","outputs":[{"internalType":"address","name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"}]`
exchange.IO("abi", "0x00000000000C2E074eC69A0dFb2997BA6C7d2e1e", abiENS_resolver)
let resolverAddress = exchange.IO("api", "0x00000000000C2E074eC69A0dFb2997BA6C7d2e1e", "resolver", ensNode)
// 注册ENS Public Resolver合约
let abiENSPublicResolver = `[{"inputs":[{"internalType":"contract ENS","name":"_ens","type":"address"}],"payable":false,"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"bytes32","name":"node","type":"bytes32"},{"indexed":true,"internalType":"uint256","name":"contentType","type":"uint256"}],"name":"ABIChanged","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"bytes32","name":"node","type":"bytes32"},{"indexed":false,"internalType":"address","name":"a","type":"address"}],"name":"AddrChanged","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"bytes32","name":"node","type":"bytes32"},{"indexed":false,"internalType":"uint256","name":"coinType","type":"uint256"},{"indexed":false,"internalType":"bytes","name":"newAddress","type":"bytes"}],"name":"AddressChanged","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"bytes32","name":"node","type":"bytes32"},{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"target","type":"address"},{"indexed":false,"internalType":"bool","name":"isAuthorised","type":"bool"}],"name":"AuthorisationChanged","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"bytes32","name":"node","type":"bytes32"},{"indexed":false,"internalType":"bytes","name":"hash","type":"bytes"}],"name":"ContenthashChanged","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"bytes32","name":"node","type":"bytes32"},{"indexed":false,"internalType":"bytes","name":"name","type":"bytes"},{"indexed":false,"internalType":"uint16","name":"resource","type":"uint16"},{"indexed":false,"internalType":"bytes","name":"record","type":"bytes"}],"name":"DNSRecordChanged","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"bytes32","name":"node","type":"bytes32"},{"indexed":false,"internalType":"bytes","name":"name","type":"bytes"},{"indexed":false,"internalType":"uint16","name":"resource","type":"uint16"}],"name":"DNSRecordDeleted","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"bytes32","name":"node","type":"bytes32"}],"name":"DNSZoneCleared","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"bytes32","name":"node","type":"bytes32"},{"indexed":true,"internalType":"bytes4","name":"interfaceID","type":"bytes4"},{"indexed":false,"internalType":"address","name":"implementer","type":"address"}],"name":"InterfaceChanged","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"bytes32","name":"node","type":"bytes32"},{"indexed":false,"internalType":"string","name":"name","type":"string"}],"name":"NameChanged","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"bytes32","name":"node","type":"bytes32"},{"indexed":false,"internalType":"bytes32","name":"x","type":"bytes32"},{"indexed":false,"internalType":"bytes32","name":"y","type":"bytes32"}],"name":"PubkeyChanged","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"bytes32","name":"node","type":"bytes32"},{"indexed":true,"internalType":"string","name":"indexedKey","type":"string"},{"indexed":false,"internalType":"string","name":"key","type":"string"}],"name":"TextChanged","type":"event"},{"constant":true,"inputs":[{"internalType":"bytes32","name":"node","type":"bytes32"},{"internalType":"uint256","name":"contentTypes","type":"uint256"}],"name":"ABI","outputs":[{"internalType":"uint256","name":"","type":"uint256"},{"internalType":"bytes","name":"","type":"bytes"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[{"internalType":"bytes32","name":"node","type":"bytes32"}],"name":"addr","outputs":[{"internalType":"address payable","name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[{"internalType":"bytes32","name":"node","type":"bytes32"},{"internalType":"uint256","name":"coinType","type":"uint256"}],"name":"addr","outputs":[{"internalType":"bytes","name":"","type":"bytes"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[{"internalType":"bytes32","name":"","type":"bytes32"},{"internalType":"address","name":"","type":"address"},{"internalType":"address","name":"","type":"address"}],"name":"authorisations","outputs":[{"internalType":"bool","name":"","type":"bool"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"internalType":"bytes32","name":"node","type":"bytes32"}],"name":"clearDNSZone","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[{"internalType":"bytes32","name":"node","type":"bytes32"}],"name":"contenthash","outputs":[{"internalType":"bytes","name":"","type":"bytes"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[{"internalType":"bytes32","name":"node","type":"bytes32"},{"internalType":"bytes32","name":"name","type":"bytes32"},{"internalType":"uint16","name":"resource","type":"uint16"}],"name":"dnsRecord","outputs":[{"internalType":"bytes","name":"","type":"bytes"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[{"internalType":"bytes32","name":"node","type":"bytes32"},{"internalType":"bytes32","name":"name","type":"bytes32"}],"name":"hasDNSRecords","outputs":[{"internalType":"bool","name":"","type":"bool"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[{"internalType":"bytes32","name":"node","type":"bytes32"},{"internalType":"bytes4","name":"interfaceID","type":"bytes4"}],"name":"interfaceImplementer","outputs":[{"internalType":"address","name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"internalType":"bytes[]","name":"data","type":"bytes[]"}],"name":"multicall","outputs":[{"internalType":"bytes[]","name":"results","type":"bytes[]"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[{"internalType":"bytes32","name":"node","type":"bytes32"}],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[{"internalType":"bytes32","name":"node","type":"bytes32"}],"name":"pubkey","outputs":[{"internalType":"bytes32","name":"x","type":"bytes32"},{"internalType":"bytes32","name":"y","type":"bytes32"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"internalType":"bytes32","name":"node","type":"bytes32"},{"internalType":"uint256","name":"contentType","type":"uint256"},{"internalType":"bytes","name":"data","type":"bytes"}],"name":"setABI","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"bytes32","name":"node","type":"bytes32"},{"internalType":"uint256","name":"coinType","type":"uint256"},{"internalType":"bytes","name":"a","type":"bytes"}],"name":"setAddr","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"bytes32","name":"node","type":"bytes32"},{"internalType":"address","name":"a","type":"address"}],"name":"setAddr","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"bytes32","name":"node","type":"bytes32"},{"internalType":"address","name":"target","type":"address"},{"internalType":"bool","name":"isAuthorised","type":"bool"}],"name":"setAuthorisation","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"bytes32","name":"node","type":"bytes32"},{"internalType":"bytes","name":"hash","type":"bytes"}],"name":"setContenthash","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"bytes32","name":"node","type":"bytes32"},{"internalType":"bytes","name":"data","type":"bytes"}],"name":"setDNSRecords","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"bytes32","name":"node","type":"bytes32"},{"internalType":"bytes4","name":"interfaceID","type":"bytes4"},{"internalType":"address","name":"implementer","type":"address"}],"name":"setInterface","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"bytes32","name":"node","type":"bytes32"},{"internalType":"string","name":"name","type":"string"}],"name":"setName","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"bytes32","name":"node","type":"bytes32"},{"internalType":"bytes32","name":"x","type":"bytes32"},{"internalType":"bytes32","name":"y","type":"bytes32"}],"name":"setPubkey","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"bytes32","name":"node","type":"bytes32"},{"internalType":"string","name":"key","type":"string"},{"internalType":"string","name":"value","type":"string"}],"name":"setText","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[{"internalType":"bytes4","name":"interfaceID","type":"bytes4"}],"name":"supportsInterface","outputs":[{"internalType":"bool","name":"","type":"bool"}],"payable":false,"stateMutability":"pure","type":"function"},{"constant":true,"inputs":[{"internalType":"bytes32","name":"node","type":"bytes32"},{"internalType":"string","name":"key","type":"string"}],"name":"text","outputs":[{"internalType":"string","name":"","type":"string"}],"payable":false,"stateMutability":"view","type":"function"}]`
exchange.IO("abi", resolverAddress, abiENSPublicResolver)
let vitalikAddress = exchange.IO("api", resolverAddress, "addr", ensNode)
Log("vitalikAddress:", vitalikAddress)
}
पिछले पाठों में हमने सीखा है कि निजी कुंजी को कैसे कॉन्फ़िगर किया जाए, और हम कैसे जानते हैं कि यह निजी कुंजी एक विनिमय वस्तु के लिए एक वॉलेट का पता है जिसे कॉन्फ़िगर किया गया है?exchange.IO("address")
फ़ंक्शन कॉन्फ़िगर किए गए निजी कुंजी के लिए संबंधित वॉलेट का पता प्राप्त करता है।
इस अध्याय में निम्नलिखित सामग्री के उपयोग के कारणGoerli
यह एक वेब परीक्षण वातावरण है, इसलिए मैं इसका उपयोग करता हूंःhttps://goerli.infura.io/v3/*******
इन्फ्यूरा ने प्रत्येक पंजीकृत उपयोगकर्ता को अलग-अलग नोड एड्रेस दिए हैं।*******
इस तरह की जानकारी को छिपाया गया है।
function main() {
let walletAddress = exchange.IO("address")
Log("测试网 goerli 钱包地址:", walletAddress)
}
एक बार जब आप अपना वॉलेट पता जानते हैं, तो आप एथेरियम के आरपीसी तरीके का उपयोग कर सकते हैं।eth_getTransactionCount
वॉलेट के पते की जांच करने के लिए लेनदेन की गिनती। एथेरियम में यह गिनती बहुत आम है, वास्तव में स्थानांतरण ऑपरेशन के लिए आवश्यक है।nonce
पैरामीटर, एथेरियम में, nonce का उपयोग यह सुनिश्चित करने के लिए किया जाता है कि प्रत्येक लेनदेन एक अद्वितीय संख्या है। यह एक वृद्धिशील संख्या है जो हर बार एक नया लेनदेन भेजे जाने पर स्वचालित रूप से बढ़ जाती है। इसलिए, जब आप स्मार्ट कॉन्ट्रैक्ट को लेनदेन भेजते हैं, तो यह सुनिश्चित करने के लिए कि लेनदेन अद्वितीय है और क्रम सही है, एक nonce प्रदान करने की आवश्यकता होती है। कुछ जानकारी और दस्तावेजों में हम पूछ सकते हैंः
यहाँ Go भाषा में एथेरियम भंडार हैPendingNonceAt
फ़ंक्शन को वास्तव में बुलाया जाता हैeth_getTransactionCount
विधि. पिछले पाठ में हम भी सीखा है कि कैसे आरपीसी विधि कॉल करने के लिए, और हम फिर से यहाँ उपयोग करते हैं.exchange.IO("api", "eth", ...)
फ़ंक्शन ।
function toAmount(s, decimals) {
return Number((BigDecimal(BigInt(s)) / BigDecimal(Math.pow(10, decimals))).toString())
}
function main() {
let walletAddress = exchange.IO("address")
Log("测试网 goerli 钱包地址:", walletAddress)
/**
* eth_getTransactionCount
* @param address - string - The address from which the transaction count to be checked.
* @param blockNumber - string - The block number as a string in hexadecimal format or tags.
* @returns The integer of the number of transactions sent from an address encoded as hexadecimal.
*/
let nonce = exchange.IO("api", "eth", "eth_getTransactionCount", walletAddress, "pending")
Log("钱包地址:", walletAddress, "当前的 nonce:", nonce, ",转换为10进制:", toAmount(nonce, 0))
}
ट्रांसफर के बारे में बात करने से पहले, हम कुछ अवधारणाओं को समझते हैं, जो एथेरियम पर ट्रांसफर करते समय कुछ ईटीएच टोकन (जैसे गैस शुल्क) का उपभोग करते हैं। यह गैस शुल्क दो मापदंडों द्वारा निर्धारित किया जाता हैः
गैस मूल्य
हालांकि, एथेरियम नेटवर्क पर गैस की कीमतें हमेशा बाजार की मांग और उपयोगकर्ताओं के लिए भुगतान करने के लिए तैयार होने के आधार पर बदलती रहती हैं, इसलिए कोड में एक निश्चित गैस की कीमत लिखना कभी-कभी आदर्श विकल्प नहीं होता है।eth_gasPrice
एक तरीका है कि आप औसत गैस मूल्य प्राप्त कर सकते हैं।
गैस सीमा
एक मानक एथेरियम लेनदेन के लिए गैस सीमा 21000 इकाइयां है।
समझ गया।nonce
,gasPrice
,gasLimit
इन अवधारणाओं का परीक्षण किया जा सकता है। FMZ पर एक बहुत ही सरल और उपयोग में आसान स्थानांतरण फ़ंक्शन शामिल है।
exchange.IO("api", "eth", "send", toAddress, toAmount)
यह एक बहुत ही अच्छा तरीका है।exchange.IO
"Send" के तीसरे पैरामीटर को "send" के रूप में लिखा जाता है।toAddress
पैरामीटर ईटीएच को स्थानांतरित करने पर प्राप्त करने के लिए पता है,toAmount
ट्रांसफर के लिए ETH की मात्रा।
nonce
,gasPrice
,gasLimit
ये पैरामीटर एफएमजेड पर सिस्टम के डिफ़ॉल्ट रूप से स्वचालित रूप से प्राप्त किए गए मानों का उपयोग कर सकते हैं.
exchange.IO("api", "eth", "send", toAddress, toAmount, {gasPrice: 5000000000, gasLimit: 21000, nonce: 100})
इसके बाद हम परीक्षण नेटवर्क goerli पर एक निश्चित ETH को किसी पते पर स्थानांतरित करते हैंः
function toInnerAmount(s, decimals) {
return (BigDecimal(s)*BigDecimal(Math.pow(10, decimals))).toFixed(0)
}
function main() {
let walletAddress = exchange.IO("address")
Log("测试网 goerli 钱包地址:", walletAddress)
let ret = exchange.IO("api", "eth", "send", "0x4D75a08E870674E68cAE611f329A27f446A66813", toInnerAmount(0.01, 18))
return ret // 返回Transaction Hash : 0xa6f9f51b00d8ae850b0f204380b59da98f4bbce34b813577d3d948f61de4734e
}
क्योंकि एथेरियम के लिए ट्रांसफर की संख्या की इकाई हैwei
एक कस्टम फ़ंक्शन का उपयोग करेंtoInnerAmount
के रूप में संसाधितwei
यूनिट का संख्यात्मक मान।
मेंhttps://etherscan.io/
ट्रांसेक्शन हैश के बारे में पूछेंः0xa6f9f51b00d8ae850b0f204380b59da98f4bbce34b813577d3d948f61de4734e
。
आप कोड लिख सकते हैं, क्वेरी स्थानांतरण हैश0xa6f9f51b00d8ae850b0f204380b59da98f4bbce34b813577d3d948f61de4734e
, उपयोगeth_getTransactionReceipt
प्रश्न पूछने के तरीके।
function main() {
let transHash = "0xa6f9f51b00d8ae850b0f204380b59da98f4bbce34b813577d3d948f61de4734e"
let info = exchange.IO("api", "eth", "eth_getTransactionReceipt", transHash)
return info
}
खोज परिणामः
{
"cumulativeGasUsed": "0x200850",
"effectiveGasPrice": "0x1748774421",
"transactionHash": "0xa6f9f51b00d8ae850b0f204380b59da98f4bbce34b813577d3d948f61de4734e",
"type": "0x0",
"blockHash": "0x6bdde8b0f0453ecd24eecf7c634d65306f05511e0e8f09f9ed3f59eee2d06ac7",
"contractAddress": null,
"blockNumber": "0x868a50",
"logsBloom": "0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000",
"gasUsed": "0x5208",
"to": "0x4d75a08e870674e68cae611f329a27f446a66813",
"status": "0x1",
"transactionIndex": "0x23",
"from": "0x6b3f11d807809b0b1e5e3243df04a280d9f94bf4",
"logs": []
}
प्रत्येक फ़ील्ड का विवरणः
blockHash - 该交易所在区块的哈希值
blockNumber - 以十六进制编码的该交易所在区块的块号
contractAddress - 如果是合约创建,该合约的地址;否则为null
cumulativeGasUsed - 该交易在区块中执行时使用的总燃气量
effectiveGasPrice - 每单位燃气的总基础费用加小费
from - 发送者的地址
gasUsed - 该特定交易使用的燃气量
logs - 生成该交易的日志对象数组
address - 生成该日志的地址
topics - 0到4个32字节索引日志参数的数据数组。在Solidity中,第一个主题是事件签名的哈希值(例如Deposit(address,bytes32,uint256)),除非你使用匿名说明符声明该事件
data - 日志的32字节非索引参数
blockNumber - 该日志所在区块的块号
transactionHash - 该日志创建时的交易哈希值。如果该日志处于待定状态,则为null
transactionIndex - 该日志创建时的交易索引位置。如果该日志处于待定状态,则为null
blockHash - 该日志所在区块的哈希值
logIndex - 该日志在区块中的索引位置,以十六进制编码的整数。如果该日志处于待定状态,则为null
removed - 如果该日志已被删除,则为true,由于链重组而被删除;如果是有效的日志,则为false
logsBloom - 用于检索相关日志的布隆过滤器
status - 以十六进制编码的值,它要么是1(成功),要么是0(失败)
to - 接收者的地址。如果是合约创建交易,则为null
transactionHash - 该交易的哈希值
transactionIndex - 以十六进制编码的该交易在区块中的索引位置
type - 值的类型
हमअनुबंध की जानकारी पढ़नाइस अध्याय में एक पूर्ण उदाहरण के माध्यम से, ईएनएस अनुबंधों को ईथरन पर तैनात करने के तरीकों को कॉल करने के लिए V के लिए एक वॉलेट पता प्राप्त किया गया है। ये तरीके एथेरियम के अंतर्गत आते हैं।Read
विधि, इनका उपयोग करना आवश्यक नहीं है।gas
इस अध्याय में हम Ethereum पर कुछ स्मार्ट अनुबंधों को कॉल करेंगे।Write
विधि और भुगतानgas
❖ ये ऑपरेशन पूरे नेटवर्क पर प्रत्येक नोड और खनिक द्वारा सत्यापित किए जाते हैं और ब्लॉकचेन की स्थिति को बदलते हैं.
ERC20 अनुबंधों के लिए (ERC20 टोकन अनुबंध), FMZ प्लेटफॉर्म ने ERC20 अनुबंधों के एबीआई को सीधे सिस्टम में एम्बेडेड एबीआई के रूप में सूचीबद्ध किया है, एबीआई को पंजीकृत करने के इस चरण को छोड़ दिया है। एबीआई के लिए हमने पिछले ट्यूटोरियल में भी सीखा है, जब हमने एनएस अनुबंध विधि को कॉल किया था, तो हमने एनएस अनुबंध के एबीआई को पंजीकृत किया था।
एबीआई को बेहतर ढंग से समझने के लिए, उपयोग करने से पहले, नीचे दिए गए एबीआई को देखेंः
[{"constant":true,"inputs":[],"name":"name","outputs":[{"name":"","type":"string"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"name":"guy","type":"address"},{"name":"wad","type":"uint256"}],"name":"approve","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"totalSupply","outputs":[{"name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"name":"src","type":"address"},{"name":"dst","type":"address"},{"name":"wad","type":"uint256"}],"name":"transferFrom","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"name":"wad","type":"uint256"}],"name":"withdraw","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"decimals","outputs":[{"name":"","type":"uint8"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[{"name":"","type":"address"}],"name":"balanceOf","outputs":[{"name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"symbol","outputs":[{"name":"","type":"string"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"name":"dst","type":"address"},{"name":"wad","type":"uint256"}],"name":"transfer","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[],"name":"deposit","outputs":[],"payable":true,"stateMutability":"payable","type":"function"},{"constant":true,"inputs":[{"name":"","type":"address"},{"name":"","type":"address"}],"name":"allowance","outputs":[{"name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"payable":true,"stateMutability":"payable","type":"fallback"},{"anonymous":false,"inputs":[{"indexed":true,"name":"src","type":"address"},{"indexed":true,"name":"guy","type":"address"},{"indexed":false,"name":"wad","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"name":"src","type":"address"},{"indexed":true,"name":"dst","type":"address"},{"indexed":false,"name":"wad","type":"uint256"}],"name":"Transfer","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"name":"dst","type":"address"},{"indexed":false,"name":"wad","type":"uint256"}],"name":"Deposit","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"name":"src","type":"address"},{"indexed":false,"name":"wad","type":"uint256"}],"name":"Withdrawal","type":"event"}]
इस अनुभाग में निम्नलिखित सामग्री का उपयोग करेंGoerli
वेब के परीक्षण के माहौल में।
और फिर हम एक बार फिर से अभ्यास करते हैं कि हम अनुबंधों को कैसे कॉल करते हैं।Read
ERC20 अनुबंधों को कॉल करने के लिए अनुबंध सूचनाओं को पढ़ने का तरीकाbalanceOf
टोकन बैलेंस का पता लगाने का तरीकाbalanceOf
विधि में केवल एक पैरामीटर है, लेकिन इसका नाम नहीं है, जिसे प्रकार द्वारा एक पता देखा जा सकता है (यानी, क्वेरी किए गए टोकन का पता) । चूंकि लौटाया गया डेटा एक टोकन के लिए नहीं है, इसलिए टोकन की सटीकता डेटा की आवश्यकता होती है।decimals
हम एथेरियम परीक्षण नेटवर्क का उपयोग करते हैंgoerli
परीक्षण करें, ध्यान दें कि विभिन्न श्रृंखलाओं पर टोकन अनुबंध के पते भी अलग-अलग हो सकते हैं।
function toAmount(s, decimals) {
return Number((BigDecimal(BigInt(s)) / BigDecimal(Math.pow(10, decimals))).toString())
}
function main() {
let walletAddress = exchange.IO("address")
// goerli WETH address
let wethAddress = "0xB4FBF271143F4FBf7B91A5ded31805e42b2208d6"
// goerli LINK address
let linkAddress = "0x326C977E6efc84E512bB9C30f76E30c160eD06FB"
// 由于是ERC20合约,FMZ已经内置ABI注册,所以这里不用注册ERC20 ABI
let wethDecimals = exchange.IO("api", wethAddress, "decimals")
let linkDecimals = exchange.IO("api", linkAddress, "decimals")
let wethBalance = exchange.IO("api", wethAddress, "balanceOf", walletAddress)
let linkBalance = exchange.IO("api", linkAddres