एफएमजेड के साथ आसान परिचय एथेरियम आधारित वेब 3 विकास

लेखक:छोटे सपने, बनाया गयाः 2023-03-28 13:32:48, अद्यतन किया गयाः 2023-09-18 20:27:13

[TOC]

img

EtherEaseWithFMZ ट्यूटोरियल

एफएमजेड के साथ आसान परिचय एथेरियम आधारित वेब 3 विकास

एथेरियम एक ब्लॉकचेन तकनीक पर आधारित स्मार्ट कॉन्ट्रैक्ट प्लेटफॉर्म है जो स्मार्ट कॉन्ट्रैक्ट लिखने और तैनात करने के लिए एक विकेंद्रीकृत तरीका प्रदान करता है। स्मार्ट कॉन्ट्रैक्ट एक विशेष कंप्यूटर प्रोग्राम है जो ब्लॉकचेन पर स्वचालित रूप से निष्पादित किया जा सकता है और किसी तीसरे पक्ष पर भरोसा किए बिना सभी प्रकार के व्यावसायिक तर्क को लागू कर सकता है।

आविष्कारक क्वांटिफाइड ट्रेडिंग प्लेटफॉर्म (((FMZ.COM) एक आसान उपयोग एपीआई प्रदान करता है जो डेवलपर्स को एथेरियम ब्लॉकचेन और इसके पारिस्थितिकी तंत्र के साथ अधिक आसानी से बातचीत करने की अनुमति देता है।

इस ट्यूटोरियल में उदाहरणों का उपयोग करेंJavaScriptभाषा लेखन, परीक्षण वातावरण का उपयोगएथेरियमGoerli परीक्षण नेटवर्क⇒ एफएमजेड प्लेटफॉर्म के एपीआई दस्तावेज में ट्यूटोरियल में उपयोग किए गए एपीआई इंटरफेस के साथ-साथ संबंधित विवरण और कोड उदाहरण भी देखे जा सकते हैं।


FMZ का उपयोग करना

एफएमजेड क्वांटिफाइड ट्रेडिंग प्लेटफॉर्म का उपयोग करने से पहले, हमें कुछ बुनियादी अवधारणाओं से परिचित होने की आवश्यकता हैः

एफएमजेड क्वांटिफाइड ट्रेडिंग प्लेटफॉर्म आर्किटेक्चर

एफएमजेड पर क्वांटिफाइड ट्रेडिंग प्लेटफॉर्म की आधिकारिक वेबसाइटhttps://www.fmz.com) पंजीकरण, लॉगिन के बाद प्लेटफॉर्म के विभिन्न कार्यों का उपयोग करना संभव है। FMZ वेबसाइट पूरे सिस्टम का प्रशासन है, उपयोगकर्ता द्वारा लिखे गए प्रोग्राम वास्तव में होस्ट पर चल रहे हैं। होस्ट के लिए यह सॉफ्टवेयर प्रोग्राम विभिन्न उपकरणों पर तैनात किया जा सकता है, जैसे कि सर्वर, कंप्यूटर आदि। जब उपयोगकर्ता FMZ वेबसाइट पर एक अच्छा प्रोग्राम लिखता है, तो FMZ प्लेटफ़ॉर्म होस्ट पर एक प्रोग्राम इंस्टेंस शुरू करने के लिए होस्ट के साथ संवाद करता है।

img

2. संरक्षक

यदि आप प्रोग्राम इंस्टेंस को चलाना चाहते हैं, तो आपको एक होस्ट को तैनात करना होगा, जो कि एक बहुत ही सरल और मंच पर तैनाती ट्यूटोरियल के साथ तैनात किया गया है। आप FMZ पर उपलब्ध "एक बटन पर तैनाती प्रबंधक" का उपयोग करके स्वचालित रूप से FMZ के लिए किराए के सर्वर पर तैनात कर सकते हैं।

  • व्यक्तिगत उपकरणों पर होस्टिंग की तैनाती

    सर्वर, पर्सनल कंप्यूटर आदि उपकरणों पर प्रबन्धक प्रोग्राम चलाने के लिए तैनात किया जा सकता है, जब तक कि नेटवर्क के कामकाज को सुनिश्चित किया जाता है। तैनाती के मुख्य चरणों में निम्नलिखित शामिल हैंः

    1. लॉग इन करें या उस डिवाइस को खोलें जहां आप होस्टिंग प्रोग्राम को तैनात करना चाहते हैं, उदाहरण के लिएसर्वर पर लॉग इन करेंयाकंप्यूटर को ऑपरेटिंग सिस्टम में खोलें.. 2. संबंधित संस्करण के होस्टिंग प्रोग्राम (डिवाइस ऑपरेटिंग सिस्टम के आधार पर) डाउनलोड करें।https://www.fmz.com/m/add-node img3. डाउनलोड करने के लिए एक संपीड़न पैक है, जिसे अनसंपीड़न की आवश्यकता है। 4. इस होस्टिंग प्रोग्राम को चलाने के लिए, होस्टिंग प्रोग्राम एक नाम हैrobotFMZ में प्रवेश करने के बाद 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

    img

3. डिबगिंग टूल

एफएमजेड क्वांटिफाइड ट्रेडिंग प्लेटफॉर्म एक मुफ्त डिबगिंग टूल प्रदान करता है, जो समर्थन करता हैJavaScriptTypeScriptयह पेज इस प्रकार हैःhttps://www.fmz.com/m/debugउदाहरण निर्माण के लिए शुल्क लगता है, इसलिए इस उपकरण का उपयोग प्रारंभिक शिक्षा के दौरान परीक्षण, सीखने के लिए किया जा सकता है। उदाहरण निर्माण के अलावा अन्य पहलुओं में कोई अंतर नहीं है।

उपयोगTypeScriptभाषाओं में, आपको कोड की पहली पंक्ति में लिखना होगा।// @ts-checkके लिए स्विच करने के लिएTypeScriptमोड, नहीं स्विच करने के लिए डिफ़ॉल्ट हैJavaScriptभाषाएँ ।

4। एक्सचेंज

एफएमजेड पर "एक्सचेंज" एक सामान्य अवधारणा है, जो सीईएक्स एक्सचेंज के लिए एक विशिष्ट एक्सचेंज खाता कॉन्फ़िगरेशन को संदर्भित करती है। वेब 3 के लिए, यह एक्सचेंज एक कॉन्फ़िगरेशन जानकारी को संदर्भित करता है जिसमें नोड पता, निजी कुंजी कॉन्फ़िगरेशन शामिल हैं।

FMZ प्लेटफॉर्म पर लॉग इन करने के बाद,https://www.fmz.com/m/add-platformयह पृष्ठ, एक्सचेंज की जानकारी को कॉन्फ़िगर कर सकता है, जहां एक्सचेंज एक सामान्य अवधारणा है।

img

चुनेंWeb3आरपीसी नोड एड्रेस को कॉन्फ़िगर करने के लिए, निजी कुंजी को कॉन्फ़िगर करने के लिए, आप सुरक्षा तंत्र देखने के लिए निचले दाएं कोने में "संवेदनशील जानकारी को स्वतंत्र निजी कुंजी के साथ एन्क्रिप्ट करना" पर क्लिक कर सकते हैं।

नोड्स स्वयं बनाए गए नोड्स के साथ या नोड सर्वर द्वारा प्रदान किए गए नोड्स के साथ हो सकते हैं। नोड सर्वर बहुत सारे हैं, उदाहरण के लिएःइन्फ्यूरा; पंजीकरण के बाद, आप अपने खाते के नोड पते को देख सकते हैं; मुख्य नेटवर्क, परीक्षण नेटवर्क उपलब्ध हैं, तुलनात्मक रूप से सुविधाजनक है, इस नोड पते को ऊपर दिए गए चित्र में कॉन्फ़िगर करें।Rpc Addressइस प्रकार, एक टैग अपने आप को नाम दे सकता है और विनिमय वस्तुओं को अलग करने के लिए उपयोग किया जा सकता है।

img

चित्र मेंhttps://mainnet.infura.io/v3/xxxxxxxxxxxxxयह निजी इंफुरा के ईटीएच मुख्य नेटवर्क के आरपीसी नोड का पता है।


एफएमजेड और एथेरियम का उपयोग करके बातचीत

在部署好托管者程序、配置好交易所对象的前提下,就可以使用FMZ.COM的「调试工具」进行测试了。调用以太坊RPC方法和以太坊交互,除了本章节列举介绍的几个RPC方法,其它RPC方法可以查询资料了解,例如https://www.quicknode.com/docs

हम कुछ सरल उदाहरणों को सूचीबद्ध करते हैं, मूल बातें शुरू करते हैं. विभिन्न भाषाओं और उपकरणों के लिए वेब 3 का उपयोग करने के तरीके हैंः

img

एफएमजेड पर आरपीसी विधि कॉल के लिए भी पैकेज किया गया है, जो एफएमजेड के एपीआई फ़ंक्शन में पैकेज किए गए हैं।exchange.IOमध्य में.exchange.IO("api", "eth", ...)◎ पहला पैरामीटर फिक्स्ड इनपुट"api", दूसरा पैरामीटर फिक्स्ड इनपुट"eth", अन्य पैरामीटर आरपीसी विधि पर निर्भर करते हैं जिसे विशेष रूप से बुलाया जाता है।

हम एफएमजेड प्लेटफॉर्म का उपयोग करते हैं।Logफ़ंक्शन,Logफ़ंक्शन कई पैरामीटर में प्रवेश कर सकता है और फिर FMZ प्लेटफॉर्म पर "डिबगिंग टूल" या "डिस्क" पृष्ठ में लॉग क्षेत्र में आउटपुट कर सकता है, "डिबगिंग टूल" पृष्ठ हमारे परीक्षण का मुख्य उपकरण होगा।

eth_getBalance

एथेरियमeth_getBalanceएक विधि जो किसी एथेरियम पते पर ईटीएच शेष राशि का पता लगाने के लिए उपयोग की जाती है, जिसमें दो पैरामीटर पास करने की आवश्यकता होती है।

  • इस लेख में हम आपको कुछ ऐसे लोगों के बारे में बताने जा रहे हैं जिनसे आप पूछ सकते हैं।
  • टैग, आमतौर पर "latest" का उपयोग करते हैं।

तो चलिए ईथरिन के संस्थापक से पूछते हैं।V神ETH वॉलेट का पता, जो ज्ञात है, हैः0xd8dA6BF26964aF9D7eEd9e03E53415D37aA96045

function main() {
    let ethBalance = exchange.IO("api", "eth", "eth_getBalance", "0xd8dA6BF26964aF9D7eEd9e03E53415D37aA96045", "latest")
    Log("ethBalance:", ethBalance)
}

होस्ट (चित्रः linux/amd64...) को तैनात किया गया है और एक्सचेंज ऑब्जेक्ट (चित्रः वेब 3 परीक्षण) को कॉन्फ़िगर किया गया है, और डिबगिंग टूल में कोड का परीक्षण किया गया हैः

img

इस कोड को निष्पादित करने के लिए "कार्य करें" बटन पर क्लिक करें और परिणाम दिखाई देगाः

ethबालन्सः 0x117296558f185bbc4c6

Logफ़ंक्शन को प्रिंट करेंethBalanceचर का मान हैः0x117296558f185bbc4c6, स्ट्रिंग प्रकार है.16 अंकों के ETH शेष,weiयूनिट,1e18 wei1 के लिए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)
}

img

ऊपरhttps://etherscan.io/पूछताछः

img

हालाँकि, यह तर्क दिया जाता है कि भाषा की सटीकता के मुद्दे में कुछ विचलन हो सकता है, इसलिए एफएमजेड प्लेटफॉर्म ने डेटा को संसाधित करने के लिए दो अंतर्निहित कार्य किए हैंः

  • BigInt: 16 अंकों की स्ट्रिंग को BigInt ऑब्जेक्ट में परिवर्तित करता है.
  • BigDecimal: संख्यात्मक प्रकार के ऑब्जेक्ट को BigDecimal ऑब्जेक्ट में परिवर्तित करता है।

एक बार फिर कोड को संशोधित करेंः

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

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

img

एथेरियम टेस्टिंग नेट का उपयोग करना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))
}

img

eth_gasPrice

कॉल करें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

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))
}

डिबगिंग टूल में चल रहा हैः

img

https://etherscan.io/पूछताछः

img

eth_getBlockByNumber

ब्लॉक की जानकारी के लिए क्वेरी करें।

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])
    }
}

"डिबगिंग टूल" में निष्पादित करने के लिए निम्नलिखित जानकारी प्राप्त करेंः

img


अनुबंध की जानकारी पढ़ना

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 प्राप्त करें (उदाहरण के लिएः संबंधित परियोजना दस्तावेज) ।

img

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अनुबंध का पता।

img

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)

img

अंतिम कॉलENS: Public Resolverअनुबंधaddrविधि, पैरामीटर अभी भीensNode

let vitalikAddress = exchange.IO("api", resolverAddress, "addr", ensNode)
Log("vitalikAddress:", vitalikAddress)

लॉग फ़ंक्शन आउटपुटः

img

vitalikAddress: 0xd8da6bf26964af9d7eed9e03e53415d37aa96045

ENS को कॉल करने का पूरा कोड

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)
}

img

एक बार जब आप अपना वॉलेट पता जानते हैं, तो आप एथेरियम के आरपीसी तरीके का उपयोग कर सकते हैं।eth_getTransactionCountवॉलेट के पते की जांच करने के लिए लेनदेन की गिनती। एथेरियम में यह गिनती बहुत आम है, वास्तव में स्थानांतरण ऑपरेशन के लिए आवश्यक है।nonceपैरामीटर, एथेरियम में, nonce का उपयोग यह सुनिश्चित करने के लिए किया जाता है कि प्रत्येक लेनदेन एक अद्वितीय संख्या है। यह एक वृद्धिशील संख्या है जो हर बार एक नया लेनदेन भेजे जाने पर स्वचालित रूप से बढ़ जाती है। इसलिए, जब आप स्मार्ट कॉन्ट्रैक्ट को लेनदेन भेजते हैं, तो यह सुनिश्चित करने के लिए कि लेनदेन अद्वितीय है और क्रम सही है, एक nonce प्रदान करने की आवश्यकता होती है। कुछ जानकारी और दस्तावेजों में हम पूछ सकते हैंः

https://goethereumbook.org/en/

img

यहाँ 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 इकाइयां है।

समझ गया।noncegasPricegasLimitइन अवधारणाओं का परीक्षण किया जा सकता है। FMZ पर एक बहुत ही सरल और उपयोग में आसान स्थानांतरण फ़ंक्शन शामिल है।

exchange.IO("api", "eth", "send", toAddress, toAmount)

यह एक बहुत ही अच्छा तरीका है।exchange.IO"Send" के तीसरे पैरामीटर को "send" के रूप में लिखा जाता है।toAddressपैरामीटर ईटीएच को स्थानांतरित करने पर प्राप्त करने के लिए पता है,toAmountट्रांसफर के लिए ETH की मात्रा।

noncegasPricegasLimitये पैरामीटर एफएमजेड पर सिस्टम के डिफ़ॉल्ट रूप से स्वचालित रूप से प्राप्त किए गए मानों का उपयोग कर सकते हैं.

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

img

आप कोड लिख सकते हैं, क्वेरी स्थानांतरण हैश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 अनुबंधों के लिए (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वेब के परीक्षण के माहौल में।

शेष राशि

और फिर हम एक बार फिर से अभ्यास करते हैं कि हम अनुबंधों को कैसे कॉल करते हैं।ReadERC20 अनुबंधों को कॉल करने के लिए अनुबंध सूचनाओं को पढ़ने का तरीका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", linkAddre

अधिक