JSON-RPC API
Utolsó módosítás: @Satglow(opens in a new tab), 2024. december 13.
Ahhoz, hogy egy szoftveralkalmazás interakcióba lépjen az Ethereum blokklánccal –a blokkláncadatokat olvasva vagy tranzakciókat küldve a hálózatra –, rá kell csatlakoznia egy Ethereum-csomópontra.
Ebből a célból minden Ethereum-kliens implementálja a JSON-RPC specifikációt(opens in a new tab), így az alkalmazások egységesen egyféle metóduscsomagra támaszkodhatnak, függetlenül az adott csomópont vagy kliens fajtájától.
A JSON-RPC(opens in a new tab) egy státuszmentes, könnyű remote procedure call (RPC) protokoll. Számos adatstruktúrát, valamint ezek feldolgozásának szabályait is meghatározza. Ez a megoldás nem függ az átadási módoktól, mivel a koncepciókat használni lehet ugyanabban a folyamatban, socketeknél, HTTP-vel és számos más üzenetküldő környezetben. Az adatformátum JSON (RFC 4627).
Kliensimplementációk
Az Ethereum-kliensek mindegyike használhat különböző programozási nyelveket, amikor a JSON-RPC specifikációt implementálja. Tekintse meg az egyéni kliensdokumentációt további részletekért a specifikus programozási nyelvekről. Érdemes megnézni a kliensdokumentációt a legutóbbi API-támogatási információ miatt is.
Kényelmi könyvtárak
Választhatja, hogy az Ethereum-kliensekkel közvetlenül kapcsolódik a JSON-RPC API révén, de az alkalmazásfejlesztők rendelkezésére állnak egyszerűbb opciók is. Számos JavaScript és backend API könyvtár létezik, hogy a JSON-RPC API tetejére egy wrappert (burkoló réteget) adjon. Ezekkel a könyvtárakkal a fejlesztők intuitív, egysoros metódusokat írhatnak, hogy JSON-RPC-kérést kezdeményezzenek (a háttérben), amely interakcióba lép az Ethereummal.
Konszenzusos kliens API-k
Ez az írás főleg a JSON-RPC API-val foglalkozik, melyet az Ethereum végrehajtási kliensei használnak. Ugyanakkor a konszenzusos klienseknek is van egy RPC API-ja, amellyel a felhasználók lekérhetnek információkat a csomópontról, Beacon-blokkokról, Beacon-státuszokról és más konszenzussal kapcsolatos adatokról közvetlenül a csomópontról. Ez az API a Beacon API honlapon(opens in a new tab) van dokumentálva.
Egy belső API-t használnak a kliensek közötti kommunikációra a csomóponton belül, így a konszenzusos kliens és a végrehajtási kliens képes adatot cserélni. Ezt nevezik Motor API-nak, amelynek specifikációja a GitHubon(opens in a new tab) érhető el.
Végrehajtási kliens specifikációi
Tekintse meg a teljes JSON-RPC API specifikációt a GitHubon(opens in a new tab). Ez az API a Végrehajtási API oldalon(opens in a new tab) van dokumentálva, és tartalmaz egy ellenőrt, hogy a rendelkezésre álló metódusokat ki lehessen próbálni.
Egyezmények
Hexadecimális értékű kódolás
Két fontos adattípus megy át a JSON-ön: formázatlan bájttömbök és mennyiségek. Mindkettő hexadecimális kódolásban van elküldve, de más a formázási követelmény.
Mennyiségek
A mennyiségek (egész számok, számok) kódolásánál: hexadecimálisban, „0x” előtaggal, a legtömörebb kifejeződésben kell kódolni (kivéve a nullát, mert az „0x0” lesz).
Néhány példa:
- 0x41 (65 decimálisban)
- 0x400 (1024 decimálisban)
- HELYTELEN: 0x (legalább egy számjegy még szükséges, a nulla írása „0x0”)
- HELYTELEN: 0x0400 (nem kezdődhet nullával a szám)
- HELYTELEN: ff (a 0x előtagot ki kell tenni)
Formázatlan adat
Amikor formázatlan adatot (bájtsorok, számlacímek, hashek, bájtkódtömbök) kell kódolni: hexadecimálisban, „0x” előtaggal, két hex számjegy bájtonként.
Néhány példa:
- 0x41 (1-es méret, „A”)
- 0x004200 (3-as méret, „0B0”)
- 0x (size 0, "")
- HELYTELEN: 0xf0f0f (páros számú kell legyen)
- HELYTELEN: 004200 (a 0x előtagot ki kell tenni)
Az alapértelmezett blokkparaméter
A következő metódusok egy extra alapértelmezett blokkparaméterrel rendelkeznek:
Amikor az Ethereum státuszát érintő kérések érkeznek, akkor a legutolsó alapértelmezett blokkparaméter határozza meg a blokk méretét.
A defaultBlock paraméter a következők lehetnek:
HEX String
– egy egész szám mint blokkszámString "earliest"
– a legkorábbi/genezis blokkString "latest"
– a legutóbb javasolt blokkString "safe"
– a blokk legutóbbi biztonságos fejeString "finalized"
– a legutóbbi véglegesedett blokkString "pending"
– a függőben lévő státusz/tranzakciók esetében
Példák
Ebben a leírásban példákat mutatunk be, hogyan lehet használni az egyéni JSON_RPC API végpontokat a parancssoreszközzel, ami a curl(opens in a new tab). Ezek az egyéni végpontpéldák a Curl példák szekciókban találhatók alább. Ezek után bemutatunk egy példát az elejétől a végéig egy okosszerződés átfordítására és telepítésére egy Geth csomópont, a JSON_RPC API és a curl használatával.
Példák a curlre
Alább láthatók azok a példák, amikor a JSON_RPC API-t használjuk egy curl(opens in a new tab) kérést létrehozva egy Ethereum-csomópontnak. Minden példa tartalmazza az adott végpont specifikációit, paramétereit, visszatérési típusát és egy működő példát arról, hogyan kell használni.
A curl-kérések hibát adhatnak vissza a tartalom típusa miatt. Ennek az az oka, hogy a --data
opció beállítja a tartalomtípust application/x-www-form-urlencoded
értékre. Ha az Ön által használt csomópontnak ez nem tetszik, akkor manuálisa állítsa át a fejlécet, hogy a -H "Content-Type: application/json"
a hívás elején legyen. A példák nem tartalmazzák az URL/IP és port kombinációját, amit a curl utolsó változójaként kell megadni (például 127.0.0.1:8545
). Egy komplett curl-kérés, amely ezeket a plusz adatokat is tartalmazza, így néz ki:
1curl -H "Content-Type: application/json" -X POST --data '{"jsonrpc":"2.0","method":"web3_clientVersion","params":[],"id":67}' 127.0.0.1:8545
Pletyka, státusz, előzményadatok
Néhány központi JSON-RPC metódushoz szükség van az Ethereum hálózati adataira, amelyek általában háromfélék lehetnek: Pletyka, státusz és előzményadatok. Az ebben a részben található hivatkozások segítségével az adott metódusra tud lépni, de a tartalomjegyzéket is használhatja a metódusok teljes listájának megtekintéséhez.
Pletyka metódusok
Ezek a metódusok a lánc fejét követik nyomon. Így kerülnek be tranzakciók a hálózatra, találják meg az útjukat a blokkokba, és az, a kliensek így szereznek tudomást az új blokkokról.
Státusz metódusok
Olyan metódusok, melyek az összes tárolt adat jelenlegi státuszát riportálják. A „státusz” olyan, akár egy nagy, megosztott RAM rész, ami számlaegyenlegeket, szerződésadatokat és gázbecsléseket tartalmaz.
Előzményadatok metódusok
Minden egyes blokkból képes előzményadatokat lekérni egészen a genezisig. Olyan mint egy hatalmas, egyre bővülő fájl, amely tartalmazza az összes blokkfejlécet, blokkadatot, a szülőblokk testvérblokkjait (ommer/uncle) és a tranzakció-visszaigazolásokat.
- eth_getBlockTransactionCountByHash
- eth_getBlockTransactionCountByNumber
- eth_getUncleCountByBlockHash
- eth_getUncleCountByBlockNumber
- eth_getBlockByHash
- eth_getBlockByNumber
- eth_getTransactionByHash
- eth_getTransactionByBlockHashAndIndex
- eth_getTransactionByBlockNumberAndIndex
- eth_getTransactionReceipt
- eth_getUncleByBlockHashAndIndex
- eth_getUncleByBlockNumberAndIndex
JSON-RPC API próbafelület
Az API-módszerek felfedezéséhez és kipróbálásához használhatja a próbaeszközt(opens in a new tab). Azt is megmutatja, hogy a különböző csomópontszolgáltatók milyen metódusokat és hálózatokat támogatnak.
JSON-RPC API metódusok
web3_clientVersion
Visszaadja a jelenlegi kliensverziót.
Paraméterek
Egyik sem
Visszaad
String
– A jelenlegi kliensverzió
Példa
1// Request2curl -X POST --data '{"jsonrpc":"2.0","method":"web3_clientVersion","params":[],"id":67}'3// Result4{5 "id":67,6 "jsonrpc":"2.0",7 "result": "Geth/v1.12.1-stable/linux-amd64/go1.19.1"8}Másolás
web3_sha3
Visszaadja az adott adat keccak-256 szerinti értékét (nem a szabványosított SHA3-256 szerintit).
Paraméterek
DATA
– Az adatok átkonvertálva SHA3 hash formátumba
1params: ["0x68656c6c6f20776f726c64"]Másolás
Visszaad
DATA
– Az adott sztring SHA3-eredménye.
Példa
1// Request2curl -X POST --data '{"jsonrpc":"2.0","method":"web3_sha3","params":["0x68656c6c6f20776f726c64"],"id":64}'3// Result4{5 "id":64,6 "jsonrpc": "2.0",7 "result": "0x47173285a8d7341e5e972fc677286384f802f8ef42a5ec5f03bbfa254cb01fad"8}Másolás
net_version
Visszaadja a jelenlegi hálózati azonosítót.
Paraméterek
Egyik sem
Visszaad
String
– Jelenlegi hálózati azonosító.
A jelenlegi hálózati azonosítók teljes listája a chainlist.org(opens in a new tab) oldalon érhető el. Néhány jellemző példa:
1
: Ethereum főhálózata5
: Goerli teszthálózat11155111
: Sepolia teszthálózat
Példa
1// Request2curl -X POST --data '{"jsonrpc":"2.0","method":"net_version","params":[],"id":67}'3// Result4{5 "id":67,6 "jsonrpc": "2.0",7 "result": "3"8}Másolás
net_listening
A true
értéket adja vissza, ha a kliens aktívan hallgatja a hálózati kapcsolatokat.
Paraméterek
Egyik sem
Visszaad
Boolean
– true
, amikor hallgatja, máskülönben false
.
Példa
1// Request2curl -X POST --data '{"jsonrpc":"2.0","method":"net_listening","params":[],"id":67}'3// Result4{5 "id":67,6 "jsonrpc":"2.0",7 "result":true8}Másolás
net_peerCount
Visszaadja a társak számát, amelyek jelenleg a klienshez kapcsolódnak.
Paraméterek
Egyik sem
Visszaad
QUANTITY
– a kapcsolódó társak száma egész számként.
Példa
1// Request2curl -X POST --data '{"jsonrpc":"2.0","method":"net_peerCount","params":[],"id":74}'3// Result4{5 "id":74,6 "jsonrpc": "2.0",7 "result": "0x2" // 28}Másolás
eth_protocolVersion
A jelenlegi Ethereum-protokollverziót adja vissza. Vegye figyelembe, hogy ez a metódus a Geth-ben nem érhető el(opens in a new tab).
Paraméterek
Egyik sem
Visszaad
String
– Az Ethereum jelenlegi protokollverziója
Példa
1// Request2curl -X POST --data '{"jsonrpc":"2.0","method":"eth_protocolVersion","params":[],"id":67}'3// Result4{5 "id":67,6 "jsonrpc": "2.0",7 "result": "54"8}Másolás
eth_syncing
Egy objektumot ad vissza a szinkronizálási státuszról szóló adattal vagy false
.
Paraméterek
Egyik sem
Visszaad
A pontos visszakapott adat a kliensimplementációk szerint változik. Minden kliens false
értéket küld, amikor a csomópont nem szinkronizál, és mindegyik elküldi a következő mezőket.
Object|Boolean
, egy objektum a szinkronizálási státuszról szóló adattal vagy false
, amikor nem szinkronizál:
startingBlock
:QUANTITY
– Az a blokk, amelynél az importálása kezdődött (csak akkor lesz visszaállítva, miután a szinkronizálás elérte a fejet)currentBlock
:QUANTITY
– A jelenlegi blokk, azonos az eth_blockNumber mezővelhighestBlock
:QUANTITY
– A becsült legnagyobb számú blokk
Ugyanakkor az egyéni kliensek további adatokat is adhatnak. A Geth például ezt küldi vissza:
1{2 "jsonrpc": "2.0",3 "id": 1,4 "result": {5 "currentBlock": "0x3cf522",6 "healedBytecodeBytes": "0x0",7 "healedBytecodes": "0x0",8 "healedTrienodes": "0x0",9 "healingBytecode": "0x0",10 "healingTrienodes": "0x0",11 "highestBlock": "0x3e0e41",12 "startingBlock": "0x3cbed5",13 "syncedAccountBytes": "0x0",14 "syncedAccounts": "0x0",15 "syncedBytecodeBytes": "0x0",16 "syncedBytecodes": "0x0",17 "syncedStorage": "0x0",18 "syncedStorageBytes": "0x0"19 }20}Összes megjelenítéseMásolás
Amíg a Besu ezt küldi vissza:
1{2 "jsonrpc": "2.0",3 "id": 51,4 "result": {5 "startingBlock": "0x0",6 "currentBlock": "0x1518",7 "highestBlock": "0x9567a3",8 "pulledStates": "0x203ca",9 "knownStates": "0x200636"10 }11}Összes megjelenítéseMásolás
Tekintse meg az adott kliens dokumentációját a további adatokért.
Példa
1// Request2curl -X POST --data '{"jsonrpc":"2.0","method":"eth_syncing","params":[],"id":1}'3// Result4{5 "id":1,6 "jsonrpc": "2.0",7 "result": {8 startingBlock: '0x384',9 currentBlock: '0x386',10 highestBlock: '0x454'11 }12}13// Or when not syncing14{15 "id":1,16 "jsonrpc": "2.0",17 "result": false18}Összes megjelenítéseMásolás
eth_coinbase
A kliens coinbase-címét adja vissza.
Paraméterek
Egyik sem
Visszaad
DATA
, 20 bájt – a jelenlegi coinbase címe.
Példa
1// Request2curl -X POST --data '{"jsonrpc":"2.0","method":"eth_coinbase","params":[],"id":64}'3// Result4{5 "id":64,6 "jsonrpc": "2.0",7 "result": "0x407d73d8a49eeb85d32cf465507dd71d507100c1"8}Másolás
eth_chainId
Visszaadja a láncazonosítót, amellyel az újrajátszástól védett tranzakciókat írják alá.
Paraméterek
Egyik sem
Visszaad
chainId
, hexadecimális érték mint sztring, amely a jelenlegi láncazonosítót mutatja egész számként.
Példa
1// Request2curl -X POST --data '{"jsonrpc":"2.0","method":"eth_chainId","params":[],"id":67}'3// Result4{5 "id":67,6 "jsonrpc": "2.0",7 "result": "0x1"8}Másolás
eth_mining
A visszaadott érték true
, ha a kliens aktívan bányászik új blokkokat. Ez csak proof-of-work hálózatok esetén küld vissza true
értéket, és talán a egyesítés (Merge) óta nincs is benne minden kliensben.
Paraméterek
Egyik sem
Visszaad
Boolean
– true
értéket ad vissza, ha a kliens bányászik, különben false
.
Példa
1// Request2curl -X POST --data '{"jsonrpc":"2.0","method":"eth_mining","params":[],"id":71}'3//4{5 "id":71,6 "jsonrpc": "2.0",7 "result": true8}Másolás
eth_hashrate
Visszaadja a hashek számát másodpercenként, amellyel a csomópont a bányászatot végzi. Ez csak proof-of-work hálózatok esetén küld vissza true
értéket, és talán a egyesítés (Merge) óta nincs is benne minden kliensben.
Paraméterek
Egyik sem
Visszaad
QUANTITY
– hashek száma másodpercenként.
Példa
1// Request2curl -X POST --data '{"jsonrpc":"2.0","method":"eth_hashrate","params":[],"id":71}'3// Result4{5 "id":71,6 "jsonrpc": "2.0",7 "result": "0x38a"8}Másolás
eth_gasPrice
Visszaadja a jelenlegi becsült gázárat wei-ben. Például a Besu kliens megvizsgálja az utolsó 100 blokkot, és a gáz egységárának mediánját küldi vissza alapból.
Paraméterek
Egyik sem
Visszaad
QUANTITY
– a jelenlegi gázár wei-ben egész számként.
Példa
1// Request2curl -X POST --data '{"jsonrpc":"2.0","method":"eth_gasPrice","params":[],"id":73}'3// Result4{5 "id":73,6 "jsonrpc": "2.0",7 "result": "0x1dfd14000" // 8049999872 Wei8}Másolás
eth_accounts
A kliens által birtokolt címek listáját adja vissza.
Paraméterek
Egyik sem
Visszaad
Array of DATA
, 20 bájt – a kliens által birtokolt címek.
Példa
1// Request2curl -X POST --data '{"jsonrpc":"2.0","method":"eth_accounts","params":[],"id":1}'3// Result4{5 "id":1,6 "jsonrpc": "2.0",7 "result": ["0x407d73d8a49eeb85d32cf465507dd71d507100c1"]8}Másolás
eth_blockNumber
A legutóbbi blokk számát adja vissza.
Paraméterek
Egyik sem
Visszaad
QUANTITY
– a legutóbbi blokk száma egész számként, amelynél a kliens tart.
Példa
1// Request2curl -X POST --data '{"jsonrpc":"2.0","method":"eth_blockNumber","params":[],"id":83}'3// Result4{5 "id":83,6 "jsonrpc": "2.0",7 "result": "0x4b7" // 12078}Másolás
eth_getBalance
Az adott cím számlaegyenlegét adja vissza.
Paraméterek
DATA
, 20 bájt – cím, melynek az egyenlegét ellenőrizzük.QUANTITY|TAG
– a blokk száma egész számként, vagy a„latest”
,„earliest”
,„pending”
,„safe”
vagy„finalized”
sztringek – nézze meg az alapértelmezett blokkparamétereket
1params: ["0x407d73d8a49eeb85d32cf465507dd71d507100c1", "latest"]Másolás
Visszaad
QUANTITY
– a jelenlegi egyenleg wei-ben egész számként.
Példa
1// Request2curl -X POST --data '{"jsonrpc":"2.0","method":"eth_getBalance","params":["0x407d73d8a49eeb85d32cf465507dd71d507100c1", "latest"],"id":1}'3// Result4{5 "id":1,6 "jsonrpc": "2.0",7 "result": "0x0234c8a3397aab58" // 1589724902343750008}Másolás
eth_getStorageAt
Egy adott címen lévő tárhely pozícióját adja vissza.
Paraméterek
DATA
, 20 bájt – a tárhely címe.QUANTITY
– a tárhelyben lévő pozíció egész számként.QUANTITY|TAG
– a blokk száma egész számként, vagy a„latest”
,„earliest”
,„pending”
,„safe”
vagy„finalized”
sztringek – nézze meg az alapértelmezett blokkparamétereket
Visszaad
DATA
– az adott tárhelypozíció értéke.
Példa Kiszámolja a pontos pozíciót, a visszakapott tárhely függvényében. Vegyük a következő szerződést, ami itt van telepítve: 0x295a70b2de5e3953354a6a8344e616ed314d7251
, ezzel a címmel:0x391694e7e0b0cce554cb130d723a9d27458f9298
.
1contract Storage {2 uint pos0;3 mapping(address => uint) pos1;4 function Storage() {5 pos0 = 1234;6 pos1[msg.sender] = 5678;7 }8}
A pos0 érték megszerzése egyértelmű:
1curl -X POST --data '{"jsonrpc":"2.0", "method": "eth_getStorageAt", "params": ["0x295a70b2de5e3953354a6a8344e616ed314d7251", "0x0", "latest"], "id": 1}' localhost:85452{"jsonrpc":"2.0","id":1,"result":"0x00000000000000000000000000000000000000000000000000000000000004d2"}Másolás
A térkép egyik elemének megszerzése már nehezebb. A térképen egy elem pozícióját így kalkuláljuk:
1keccak(LeftPad32(key, 0), LeftPad32(map position, 0))Másolás
Ahhoz, hogy megszerezzük a tárhelyet a pos1["0x391694e7e0b0cce554cb130d723a9d27458f9298"] tekintetében, a pozíciót így kell kalkulálni:
1keccak(2 decodeHex(3 "000000000000000000000000391694e7e0b0cce554cb130d723a9d27458f9298" +4 "0000000000000000000000000000000000000000000000000000000000000001"5 )6)Másolás
A web3-könyvtárban található Geth konzolt lehet használni a kalkulációhoz:
1> var key = "000000000000000000000000391694e7e0b0cce554cb130d723a9d27458f9298" + "0000000000000000000000000000000000000000000000000000000000000001"2undefined3> web3.sha3(key, {"encoding": "hex"})4"0x6661e9d6d8b923d5bbaab1b96e1dd51ff6ea2a93520fdc9eb75d059238b8c5e9"Másolás
Most pedig a tárhely megszerzése:
1curl -X POST --data '{"jsonrpc":"2.0", "method": "eth_getStorageAt", "params": ["0x295a70b2de5e3953354a6a8344e616ed314d7251", "0x6661e9d6d8b923d5bbaab1b96e1dd51ff6ea2a93520fdc9eb75d059238b8c5e9", "latest"], "id": 1}' localhost:85452{"jsonrpc":"2.0","id":1,"result":"0x000000000000000000000000000000000000000000000000000000000000162e"}Másolás
eth_getTransactionCount
Visszaadja a tranzakciók számát, amelyeket egy adott címről küldtek.
Paraméterek
DATA
, 20 bájt – cím.QUANTITY|TAG
– a blokk száma egész számként, vagy a„latest”
,„earliest”
,„pending”
,„safe”
vagy„finalized”
sztringek – nézze meg az alapértelmezett blokkparamétereket
1params: [2 "0x407d73d8a49eeb85d32cf465507dd71d507100c1",3 "latest", // state at the latest block4]Másolás
Visszaad
QUANTITY
– a tranzakciók száma egész számként, amit erről a címről küldtek.
Példa
1// Request2curl -X POST --data '{"jsonrpc":"2.0","method":"eth_getTransactionCount","params":["0x407d73d8a49eeb85d32cf465507dd71d507100c1","latest"],"id":1}'3// Result4{5 "id":1,6 "jsonrpc": "2.0",7 "result": "0x1" // 18}Másolás
eth_getBlockTransactionCountByHash
Visszaadja a tranzakciók számát egy blokkban, egy olyan blokkból, mely egyezik a megadott blokkhashsel.
Paraméterek
DATA
, 32 bájt – blokkhash
1params: ["0xd03ededb7415d22ae8bac30f96b2d1de83119632693b963642318d87d1bece5b"]Másolás
Visszaad
QUANTITY
– ebben a blokkban lévő tranzakciók száma egész számként.
Példa
1// Request2curl -X POST --data '{"jsonrpc":"2.0","method":"eth_getBlockTransactionCountByHash","params":["0xd03ededb7415d22ae8bac30f96b2d1de83119632693b963642318d87d1bece5b"],"id":1}'3// Result4{5 "id":1,6 "jsonrpc": "2.0",7 "result": "0x8b" // 1398}Másolás
eth_getBlockTransactionCountByNumber
Visszaadja a tranzakciók számát egy blokkban, amely az adott blokkszámnak felel meg.
Paraméterek
QUANTITY|TAG
– a blokk száma egész számként, vagy a„latest”
,„earliest”
,„pending”
,„safe”
vagy„finalized”
sztringek az alapértelmezett blokkparaméterek szerint.
1params: [2 "0x13738ca", // 203962343]Másolás
Visszaad
QUANTITY
– ebben a blokkban lévő tranzakciók száma egész számként.
Példa
1// Request2curl -X POST --data '{"jsonrpc":"2.0","method":"eth_getBlockTransactionCountByNumber","params":["0x13738ca"],"id":1}'3// Result4{5 "id":1,6 "jsonrpc": "2.0",7 "result": "0x8b" // 1398}Másolás
eth_getUncleCountByBlockHash
Visszaadja az uncle-blokkok számát egy olyan blokkból, ami a blokkhashnek megfelel.
Paraméterek
DATA
, 32 bájt – blokkhash
1params: ["0x1d59ff54b1eb26b013ce3cb5fc9dab3705b415a67127a003c3e61eb445bb8df2"]Másolás
Visszaad
QUANTITY
– ebben a blokkban az uncle-blokkok száma egész számként.
Példa
1// Request2curl -X POST --data '{"jsonrpc":"2.0","method":"eth_getUncleCountByBlockHash","params":["0x1d59ff54b1eb26b013ce3cb5fc9dab3705b415a67127a003c3e61eb445bb8df2"],"id":1}'3// Result4{5 "id":1,6 "jsonrpc": "2.0",7 "result": "0x1" // 18}Másolás
eth_getUncleCountByBlockNumber
Visszaadja az uncle-blokkok számát egy olyan blokkból, ami egy adott blokkszámnak megfelel.
Paraméterek
QUANTITY|TAG
– a blokk száma egész számként, vagy a„latest”
,„earliest”
,„pending”
,„safe”
vagy„finalized”
sztringek – nézze meg az alapértelmezett blokkparamétereket
1params: [2 "0xe8", // 2323]Másolás
Visszaad
QUANTITY
– ebben a blokkban az uncle-blokkok száma egész számként.
Példa
1// Request2curl -X POST --data '{"jsonrpc":"2.0","method":"eth_getUncleCountByBlockNumber","params":["0xe8"],"id":1}'3// Result4{5 "id":1,6 "jsonrpc": "2.0",7 "result": "0x0" // 08}Másolás
eth_getCode
Visszaadja az adott címen lévő kódot.
Paraméterek
DATA
, 20 bájt – címQUANTITY|TAG
– a blokk száma egész számként, vagy a„latest”
,„earliest”
,„pending”
,„safe”
vagy„finalized”
sztringek – nézze meg az alapértelmezett blokkparamétereket
1params: [2 "0xC02aaA39b223FE8D0A0e5C4F27eAD9083C756Cc2",3 "0x5daf3b", // 61397074]Másolás
Visszaad
DATA
– a kód az adott címről.
Példa
1// Request2curl -X POST --data '{"jsonrpc":"2.0","method":"eth_getCode","params":["0xC02aaA39b223FE8D0A0e5C4F27eAD9083C756Cc2", "0x5daf3b"],"id":1}'3// Result4{5 "id":1,6 "jsonrpc": "2.0",7 "result": "0x6060604052600436106100af576000357c0100000000000000000000000000000000000000000000000000000000900463ffffffff16806306fdde03146100b9578063095ea7b31461014757806318160ddd146101a157806323b872dd146101ca5780632e1a7d4d14610243578063313ce5671461026657806370a082311461029557806395d89b41146102e2578063a9059cbb14610370578063d0e30db0146103ca578063dd62ed3e146103d4575b6100b7610440565b005b34156100c457600080fd5b6100cc6104dd565b6040518080602001828103825283818151815260200191508051906020019080838360005b8381101561010c5780820151818401526020810190506100f1565b50505050905090810190601f1680156101395780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b341561015257600080fd5b610187600480803573ffffffffffffffffffffffffffffffffffffffff1690602001909190803590602001909190505061057b565b604051808215151515815260200191505060405180910390f35b34156101ac57600080fd5b6101b461066d565b6040518082815260200191505060405180910390f35b34156101d557600080fd5b610229600480803573ffffffffffffffffffffffffffffffffffffffff1690602001909190803573ffffffffffffffffffffffffffffffffffffffff1690602001909190803590602001909190505061068c565b604051808215151515815260200191505060405180910390f35b341561024e57600080fd5b61026460048080359060200190919050506109d9565b005b341561027157600080fd5b610279610b05565b604051808260ff1660ff16815260200191505060405180910390f35b34156102a057600080fd5b6102cc600480803573ffffffffffffffffffffffffffffffffffffffff16906020019091905050610b18565b6040518082815260200191505060405180910390f35b34156102ed57600080fd5b6102f5610b30565b6040518080602001828103825283818151815260200191508051906020019080838360005b8381101561033557808201518184015260208101905061031a565b50505050905090810190601f1680156103625780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b341561037b57600080fd5b6103b0600480803573ffffffffffffffffffffffffffffffffffffffff16906020019091908035906020019091905050610bce565b604051808215151515815260200191505060405180910390f35b6103d2610440565b005b34156103df57600080fd5b61042a600480803573ffffffffffffffffffffffffffffffffffffffff1690602001909190803573ffffffffffffffffffffffffffffffffffffffff16906020019091905050610be3565b6040518082815260200191505060405180910390f35b34600360003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020600082825401925050819055503373ffffffffffffffffffffffffffffffffffffffff167fe1fffcc4923d04b559f4d29a8bfc6cda04eb5b0d3c460751c2402c5c5cc9109c346040518082815260200191505060405180910390a2565b60008054600181600116156101000203166002900480601f0160208091040260200160405190810160405280929190818152602001828054600181600116156101000203166002900480156105735780601f1061054857610100808354040283529160200191610573565b820191906000526020600020905b81548152906001019060200180831161055657829003601f168201915b505050505081565b600081600460003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020819055508273ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925846040518082815260200191505060405180910390a36001905092915050565b60003073ffffffffffffffffffffffffffffffffffffffff1631905090565b600081600360008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054101515156106dc57600080fd5b3373ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff16141580156107b457507fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff600460008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000205414155b156108cf5781600460008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020541015151561084457600080fd5b81600460008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020600082825403925050819055505b81600360008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000206000828254039250508190555081600360008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020600082825401925050819055508273ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef846040518082815260200191505060405180910390a3600190509392505050565b80600360003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000205410151515610a2757600080fd5b80600360003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020600082825403925050819055503373ffffffffffffffffffffffffffffffffffffffff166108fc829081150290604051600060405180830381858888f193505050501515610ab457600080fd5b3373ffffffffffffffffffffffffffffffffffffffff167f7fcf532c15f0a6db0bd6d0e038bea71d30d808c7d98cb3bf7268a95bf5081b65826040518082815260200191505060405180910390a250565b600260009054906101000a900460ff1681565b60036020528060005260406000206000915090505481565b60018054600181600116156101000203166002900480601f016020809104026020016040519081016040528092919081815260200182805460018160011615610100020316600290048015610bc65780601f10610b9b57610100808354040283529160200191610bc6565b820191906000526020600020905b815481529060010190602001808311610ba957829003601f168201915b505050505081565b6000610bdb33848461068c565b905092915050565b60046020528160005260406000206020528060005260406000206000915091505054815600a165627a7a72305820deb4c2ccab3c2fdca32ab3f46728389c2fe2c165d5fafa07661e4e004f6c344a0029"8}Másolás
eth_sign
Az aláírás metódus kikalkulál egy Ethereum-specifikus aláírást a következővel: sign(keccak256("\x19Ethereum Signed Message:\n" + len(message) + message)))
.
Ha az üzenethez egy előtagot adunk, akkor a kikalkulált aláírást úgy ismeri fel, mint Ethereum-specifikus aláírás. Ez megakadályozza a rosszhiszemű felhasználást, amikor egy támadó alkalmazás tetszőleges adatokat (például tranzakciókat) ír alá, és arra használja az aláírást, hogy megszemélyesítse áldozatát.
Megjegyzés: az aláíráshoz olyan cím kell, amely nincs zárolva.
Paraméterek
DATA
, 20 bájt – címDATA
, N bájt – az aláírandó üzenet
Visszaad
DATA
: Aláírás
Példa
1// Request2curl -X POST --data '{"jsonrpc":"2.0","method":"eth_sign","params":["0x9b2055d370f73ec7d8a03e965129118dc8f5bf83", "0xdeadbeaf"],"id":1}'3// Result4{5 "id":1,6 "jsonrpc": "2.0",7 "result": "0xa3f20717a250c2b0b729b7e5becbff67fdaef7e0699da4de7ca5895b02a170a12d887fd3b17bfdce3481f10bea41f45ba9f709d39ce8325427b57afcfc994cee1b"8}Másolás
eth_signTransaction
Aláír egy olyan tranzakciót, amelyet egy későbbi időpontban be lehet küldeni a hálózatra az eth_sendRawTransaction segítségével.
Paraméterek
Object
– A tranzakcióobjektum
type
:from
:DATA
, 20 bájt – A cím, amelyről a tranzakció érkezett.to
:DATA
, 20 bájt – (opcionális új szerződés létrehozásakor) A tranzakció címzettjének címe.gas
:QUANTITY
– (opcionális, alapértelmezett: 90 000) A tranzakció végrehajtásához biztosított gáz egész számban megadva. Visszaküldi a fel nem használt gázt.gasPrice
:QUANTITY
– (opcionális, alapértelmezett: To-Be-Determined) a gasPrice (gázár) egész számként, ami a wei-ben fizetendő gázra vonatkozik.value
:QUANTITY
– (opcionális) a tranzakcióban küldött érték egész számként, wei-ben.data
:DATA
– A szerződés kódjának átfordítása VAGY a meghívott metódus aláírásának és kódolt paramétereinek a hashe.nonce
:QUANTITY
– (opcionális) A nonce egész számmal megadva. Ez lehetővé teszi a saját függőben lévő tranzakciók felülírását, amelyek ugyanazt a nonce-t használják.
Visszaad
DATA
, Az RLP-kódolású tranzakcióobjektum, melyet a specifikus számla aláírt.
Példa
1// Request2curl -X POST --data '{"id": 1,"jsonrpc": "2.0","method": "eth_signTransaction","params": [{"data":"0xd46e8dd67c5d32be8d46e8dd67c5d32be8058bb8eb970870f072445675058bb8eb970870f072445675","from": "0xb60e8dd61c5d32be8058bb8eb970870f07233155","gas": "0x76c0","gasPrice": "0x9184e72a000","to": "0xd46e8dd67c5d32be8058bb8eb970870f07244567","value": "0x9184e72a"}]}'3// Result4{5 "id": 1,6 "jsonrpc": "2.0",7 "result": "0xa3f20717a250c2b0b729b7e5becbff67fdaef7e0699da4de7ca5895b02a170a12d887fd3b17bfdce3481f10bea41f45ba9f709d39ce8325427b57afcfc994cee1b"8}Másolás
eth_sendTransaction
Készít egy új üzenetküldési tranzakciót vagy szerződéslétrehozást, ha az adatmezőben kód van, és aláírja a from
mezőben definiált számlával.
Paraméterek
Object
– A tranzakcióobjektum
from
:DATA
, 20 bájt – A cím, amelyről a tranzakció érkezett.to
:DATA
, 20 bájt – (opcionális új szerződés létrehozásakor) A tranzakció címzettjének címe.gas
:QUANTITY
– (opcionális, alapértelmezett: 90 000) A tranzakció végrehajtásához biztosított gáz egész számban megadva. Visszaküldi a fel nem használt gázt.gasPrice
:QUANTITY
– (opcionális, alapértelmezett: To-Be-Determined) a gasPrice (gázár) egész számként, ami a fizetendő gázra vonatkozik.value
:QUANTITY
– (opcionális) a tranzakcióban küldött érték egész számként.input
:DATA
– A szerződés kódjának átfordítása VAGY a meghívott metódus aláírásának és kódolt paramétereinek a hashe.nonce
:QUANTITY
– (opcionális) A nonce egész számmal megadva. Ez lehetővé teszi a saját függőben lévő tranzakciók felülírását, amelyek ugyanazt a nonce-t használják.
1params: [2 {3 from: "0xb60e8dd61c5d32be8058bb8eb970870f07233155",4 to: "0xd46e8dd67c5d32be8058bb8eb970870f07244567",5 gas: "0x76c0", // 304006 gasPrice: "0x9184e72a000", // 100000000000007 value: "0x9184e72a", // 24414062508 input:9 "0xd46e8dd67c5d32be8d46e8dd67c5d32be8058bb8eb970870f072445675058bb8eb970870f072445675",10 },11]Összes megjelenítéseMásolás
Visszaad
DATA
, 32 bájt – a tranzakció hashe vagy a nulla hash, ha a tranzakció még nem elérhető.
Használja az eth_getTransactionReceipt parancsot, hogy megszerezze a szerződéscímet, miután a tranzakciót egy blokkban előterjesztették, és amikor létrehozta a szerződést.
Példa
1// Request2curl -X POST --data '{"jsonrpc":"2.0","method":"eth_sendTransaction","params":[{see above}],"id":1}'3// Result4{5 "id":1,6 "jsonrpc": "2.0",7 "result": "0xe670ec64341771606e55d6b4ca35a1a6b75ee3d5145a99d05921026d1527331"8}Másolás
eth_sendRawTransaction
Egy új üzenetküldési tranzakciót vagy szerződéslétrehozást hoz létre az aláírt tranzakciókhoz.
Paraméterek
DATA
, az aláírt tranzakciós adatok.
1params: [2 "0xd46e8dd67c5d32be8d46e8dd67c5d32be8058bb8eb970870f072445675058bb8eb970870f072445675",3]Másolás
Visszaad
DATA
, 32 bájt – a tranzakció hashe vagy a nulla hash, ha a tranzakció még nem elérhető.
Használja az eth_getTransactionReceipt parancsot, hogy megszerezze a szerződéscímet, miután a tranzakciót egy blokkban előterjesztették, és amikor létrehozta a szerződést.
Példa
1// Request2curl -X POST --data '{"jsonrpc":"2.0","method":"eth_sendRawTransaction","params":[{see above}],"id":1}'3// Result4{5 "id":1,6 "jsonrpc": "2.0",7 "result": "0xe670ec64341771606e55d6b4ca35a1a6b75ee3d5145a99d05921026d1527331"8}Másolás
eth_call
Azonnal végrehajt egy új üzenethívást anélkül, hogy létrehozna egy tranzakciót a blokkláncon. Gyakran használják arra, hogy csak olvasási (read-only) okosszerződés-függvényeket hajtsanak végre, például a balanceOf
kód egy ERC-20-as szerződésnél.
Paraméterek
Object
– A tranzakcióhívás objektuma
from
:DATA
, 20 bájt – (opcionális) A tranzakció küldőjének címe.to
:DATA
, 20 bájt – A tranzakció címzettjének címe.gas
:QUANTITY
– (opcionális) A tranzakció végrehajtásához adott gáz egész számként. Az eth_call nulla gázt fogyaszt, de néhány végrehajtásnak szüksége lehet rá.gasPrice
:QUANTITY
– (opcionális) a gasPrice (gázár) egész számként, ami a fizetendő gázra vonatkozikvalue
:QUANTITY
– (opcionális) a tranzakcióban küldött érték egész számkéntinput
:DATA
– (opcionális) a metódus aláírásának és kódolt paramétereinek a hashe. A részletekért tekintse meg az Ethereum-szerződés ABI-ját a Solidity dokumentációban(opens in a new tab).
QUANTITY|TAG
– a blokk száma egész számként, vagy a„latest”
,„earliest”
,„pending”
,„safe”
vagy„finalized”
sztringek – nézze meg az alapértelmezett blokkparamétereket
Visszaad
DATA
– a végrehajtott szerződés visszatérési értéke.
Példa
1// Request2curl -X POST --data '{"jsonrpc":"2.0","method":"eth_call","params":[{see above}],"id":1}'3// Result4{5 "id":1,6 "jsonrpc": "2.0",7 "result": "0x"8}Másolás
eth_estimateGas
Megbecsüli, hogy egy tranzakció végrehajtásához mennyi gázra lesz szükség. A tranzakció nem kerül hozzáadásra a blokklánchoz. Vegye figyelembe, hogy a becslés szignifikánsan több is lehet, mint amennyit elhasznál a tranzakció, melynek számos oka van, beleértve az EVM működési módját és a csomópontok teljesítményét.
Paraméterek
Nézze meg az eth_call paramétereit az összes opcionális paraméter kivételével. Ha nincs megadva gázkorlátozás, akkor a Geth a függőben lévő blokk gázkorlátozását használja felső értékként. Ennek eredményeként a visszakapott becslés talán nem elég a hívás/tranzakció végrehajtásához, amikor a gáz mennyisége magasabb, mint a függőben lévő blokk gázkorlátozása.
Visszaad
QUANTITY
– a felhasznált gáz mennyisége.
Példa
1// Request2curl -X POST --data '{"jsonrpc":"2.0","method":"eth_estimateGas","params":[{see above}],"id":1}'3// Result4{5 "id":1,6 "jsonrpc": "2.0",7 "result": "0x5208" // 210008}Másolás
eth_getBlockByHash
Egy blokkról ad információt hash alapján.
Paraméterek
DATA
, 32 bájt – egy blokk hashe.Boolean
– Hatrue
, akkor visszaadja a teljes tranzakcióobjektumot, hafalse
, akkor csak a tranzakciók hashét.
1params: [2 "0xdc0818cf78f21a8e70579cb46a43643f78291264dda342ae31049421c82d21ae",3 false,4]Másolás
Visszaad
Object
– Egy blokkobjektum, vagy null
, amikor nem talál blokkot:
number
:QUANTITY
– a blokkszám.null
, amikor a blokk függőben van.hash
:DATA
, 32 bájt – a blokk hashe.null
, amikor a blokk függőben van.parentHash
:DATA
, 32 bájt – a szülőblokk hashe.nonce
:DATA
, 8 bájt – a létrehozott proof-of-work hashe.null
, amikor a blokk függőben van.sha3Uncles
:DATA
, 32 bájt – a blokkban lévő uncle blokkok SHA3-ja.logsBloom
:DATA
, 256 bájt – a bloom-szűrés a blokkok naplózására.null
, amikor a blokk függőben van.transactionsRoot
:DATA
, 32 bájt – a blokk tranzakciós fájának a gyökere.stateRoot
:DATA
, 32 bájt – a blokk végső státuszfájának a gyökere.receiptsRoot
:DATA
, 32 bájt – a blokk visszaigazolás-fájának a gyökere.miner
:DATA
, 20 bájt – annak a címe, akinek a bányászati jutalom jár.difficulty
:QUANTITY
– erre a blokkra vonatkozó nehézség egész számként.totalDifficulty
:QUANTITY
– a lánc teljes nehézsége eddig a blokkig, egész számként.extraData
:DATA
– ennek a blokknak a „további adatok” mezője.size
:QUANTITY
– a blokk mérete bájtban, egész számként.gasLimit
:QUANTITY
– a maximálisan megengedett gáz ebben a blokkban.gasUsed
:QUANTITY
– a tranzakciók által elhasznált összes gáz ebben a blokkban.timestamp
:QUANTITY
– a unix időbélyege, amikor a blokkot összeállították.transactions
:Array
– Tranzakcióobjektumok tömbje, vagy 32 bájtos tranzakcióhashek az utolsó megadott paraméter alapján.uncles
:Array
– Az uncle hashek sora.
Példa
1// Request2curl -X POST --data '{"jsonrpc":"2.0","method":"eth_getBlockByHash","params":["0xdc0818cf78f21a8e70579cb46a43643f78291264dda342ae31049421c82d21ae", false],"id":1}'3// Result4{5{6"jsonrpc": "2.0",7"id": 1,8"result": {9 "difficulty": "0x4ea3f27bc",10 "extraData": "0x476574682f4c5649562f76312e302e302f6c696e75782f676f312e342e32",11 "gasLimit": "0x1388",12 "gasUsed": "0x0",13 "hash": "0xdc0818cf78f21a8e70579cb46a43643f78291264dda342ae31049421c82d21ae",14 "logsBloom": "0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000",15 "miner": "0xbb7b8287f3f0a933474a79eae42cbca977791171",16 "mixHash": "0x4fffe9ae21f1c9e15207b1f472d5bbdd68c9595d461666602f2be20daf5e7843",17 "nonce": "0x689056015818adbe",18 "number": "0x1b4",19 "parentHash": "0xe99e022112df268087ea7eafaf4790497fd21dbeeb6bd7a1721df161a6657a54",20 "receiptsRoot": "0x56e81f171bcc55a6ff8345e692c0f86e5b48e01b996cadc001622fb5e363b421",21 "sha3Uncles": "0x1dcc4de8dec75d7aab85b567b6ccd41ad312451b948a7413f0a142fd40d49347",22 "size": "0x220",23 "stateRoot": "0xddc8b0234c2e0cad087c8b389aa7ef01f7d79b2570bccb77ce48648aa61c904d",24 "timestamp": "0x55ba467c",25 "totalDifficulty": "0x78ed983323d",26 "transactions": [27 ],28 "transactionsRoot": "0x56e81f171bcc55a6ff8345e692c0f86e5b48e01b996cadc001622fb5e363b421",29 "uncles": [30 ]31}32}Összes megjelenítéseMásolás
eth_getBlockByNumber
Egy blokkról ad információt a blokkszám alapján.
Paraméterek
QUANTITY|TAG
– a blokk száma egész számként, vagy a„latest”
,„earliest”
,„pending”
,„safe”
vagy„finalized”
sztringek az alapértelmezett blokkparaméterek szerint.Boolean
– Hatrue
, akkor visszaadja a teljes tranzakcióobjektumot, hafalse
, akkor csak a tranzakciók hashét.
1params: [2 "0x1b4", // 4363 true,4]Másolás
Visszaküldött információk Nézze meg az eth_getBlockByHash résznél
Példa
1// Request2curl -X POST --data '{"jsonrpc":"2.0","method":"eth_getBlockByNumber","params":["0x1b4", true],"id":1}'Másolás
Az eredményeket nézze meg az eth_getBlockByHash résznél
eth_getTransactionByHash
Információt ad egy tranzakcióról a tranzakció hashe alapján.
Paraméterek
DATA
, 32 bájt – tranzakció-hash
1params: ["0x88df016429689c079f3b2f6ad39fa052532c56795b733da78a91ebe6a713944b"]Másolás
Visszaad
Object
– Egy tranzakcióobjektum, vagy null
, amikor nem talál tranzakciót:
blockHash
:DATA
, 32 bájt – a blokk-hash, amelyben ez a tranzakció volt.null
, amikor függőben van.blockNumber
:QUANTITY
– a blokkszám, amelyben ez a tranzakció volt.null
, amikor függőben van.from
:DATA
, 20 bájt – a küldő címe.gas
:QUANTITY
– a küldő által adott gáz.gasPrice
:QUANTITY
– a küldő által megadott gázár wei-ben.hash
:DATA
, 32 bájt – a tranzakció hashe.input
:DATA
– a tranzakcióval együtt küldött adatok.nonce
:QUANTITY
– a tranzakciók száma, melyet a küldő az adott tranzakció előtt végzett.to
:DATA
, 20 bájt – a fogadó címe.null
, amikor ez egy szerződéslétrehozó tranzakció.transactionIndex
:QUANTITY
– a tranzakcióindex pozíciója a blokkban, egész számként.null
, amikor függőben van.value
:QUANTITY
– a küldött érték wei-ben.v
:QUANTITY
– ECDSA visszaállítási azonosítór
:QUANTITY
– ECDSA aláírás rs
:QUANTITY
– ECDSA aláírás s
Példa
1// Request2curl -X POST --data '{"jsonrpc":"2.0","method":"eth_getTransactionByHash","params":["0x88df016429689c079f3b2f6ad39fa052532c56795b733da78a91ebe6a713944b"],"id":1}'3// Result4{5 "jsonrpc":"2.0",6 "id":1,7 "result":{8 "blockHash":"0x1d59ff54b1eb26b013ce3cb5fc9dab3705b415a67127a003c3e61eb445bb8df2",9 "blockNumber":"0x5daf3b", // 613970710 "from":"0xa7d9ddbe1f17865597fbd27ec712455208b6b76d",11 "gas":"0xc350", // 5000012 "gasPrice":"0x4a817c800", // 2000000000013 "hash":"0x88df016429689c079f3b2f6ad39fa052532c56795b733da78a91ebe6a713944b",14 "input":"0x68656c6c6f21",15 "nonce":"0x15", // 2116 "to":"0xf02c1c8e6114b1dbe8937a39260b5b0a374432bb",17 "transactionIndex":"0x41", // 6518 "value":"0xf3dbb76162000", // 429000000000000019 "v":"0x25", // 3720 "r":"0x1b5e176d927f8e9ab405058b2d2457392da3e20f328b16ddabcebc33eaac5fea",21 "s":"0x4ba69724e8f69de52f0125ad8b3c5c2cef33019bac3249e2c0a2192766d1721c"22 }23}Összes megjelenítéseMásolás
eth_getTransactionByBlockHashAndIndex
Egy tranzakcióról ad információt a blokk-hash és a tranzakcióindex pozíciója alapján.
Paraméterek
DATA
, 32 bájt – egy blokk hashe.QUANTITY
– a tranzakcióindex pozíciója egész számként.
1params: [2 "0x1d59ff54b1eb26b013ce3cb5fc9dab3705b415a67127a003c3e61eb445bb8df2",3 "0x0", // 04]Másolás
Visszaküldött információk Nézze meg az eth_getTransactionByHash résznél
Példa
1// Request2curl -X POST --data '{"jsonrpc":"2.0","method":"eth_getTransactionByBlockHashAndIndex","params":["0x1d59ff54b1eb26b013ce3cb5fc9dab3705b415a67127a003c3e61eb445bb8df2", "0x0"],"id":1}'Másolás
Az eredményeket nézze meg az eth_getTransactionByHash résznél
eth_getTransactionByBlockNumberAndIndex
Egy tranzakcióról ad információt a blokkszám és a tranzakcióindex pozíciója alapján.
Paraméterek
QUANTITY|TAG
– a blokk száma egész számként, vagy a„latest”
,„earliest”
,„pending”
,„safe”
vagy„finalized”
sztringek az alapértelmezett blokkparaméterek szerint.QUANTITY
– a tranzakcióindex pozíciója.
1params: [2 "0x9c47cf", // 102419993 "0x24", // 364]Másolás
Visszaküldött információk Nézze meg az eth_getTransactionByHash résznél
Példa
1// Request2curl -X POST --data '{"jsonrpc":"2.0","method":"eth_getTransactionByBlockNumberAndIndex","params":["0x9c47cf", "0x24"],"id":1}'Másolás
Az eredményeket nézze meg az eth_getTransactionByHash résznél
eth_getTransactionReceipt
Egy tranzakció visszaigazolását adja meg a tranzakció-hash alapján.
Megjegyzés: A visszaigazolás nem érthető el függőben lévő tranzakciók esetében.
Paraméterek
DATA
, 32 bájt – tranzakció-hash
1params: ["0x85d995eba9763907fdf35cd2034144dd9d53ce32cbec21349d4b12823c6860c5"]Másolás
Visszaküldött információk Object
– Egy tranzakció visszaigazolási objektuma, vagy null
, amikor a visszaigazolást nem találja:
transactionHash
:DATA
, 32 bájt – a tranzakció hashe.transactionIndex
:QUANTITY
– a tranzakcióindex pozíciója a blokkban, egész számként.blockHash
:DATA
, 32 bájt – a blokk-hash, amelyben ez a tranzakció volt.blockNumber
:QUANTITY
– a blokkszám, amelyben ez a tranzakció volt.from
:DATA
, 20 bájt – a küldő címe.to
:DATA
, 20 bájt – a fogadó címe. null, amikor ez egy szerződéslétrehozó tranzakció.cumulativeGasUsed
:QUANTITY
– A gáz teljes mennyisége, amikor ez a tranzakció végrehajtásra került a blokkban.effectiveGasPrice
:QUANTITY
– Az alapdíj és a borravaló összege a gáz egységére vonatkozóan.gasUsed
:QUANTITY
– A felhasznált gáz mennyisége erre az adott tranzakcióra vonatkozóan.contractAddress
:DATA
, 20 bájt – A létrehozott szerződéscím, ha ez a tranzakció szerződéslétrehozásról szól, máskülönbennull
.logs
:Array
– A naplózási objektumok tömbje, amelyet ez a tranzakció generált.logsBloom
:DATA
, 256 bájt – Bloom-szűrés a könnyű kliensekhez, hogy gyorsan elérjék a kapcsolódó naplóbejegyzéseket.type
:QUANTITY
– a tranzakciótípus egész számként,0x0
a korábbi tranzakciókért,0x1
a hozzáférési lista típusért,0x2
a dinamikus díjakért.
Emellett megadja a kettő közül az egyiket :
root
:DATA
32 bájt tranzakció utáni státuszgyökér (pre Byzantium)status
:QUANTITY
vagy1
(sikeres), vagy0
(sikertelen)
Példa
1// Request2curl -X POST --data '{"jsonrpc":"2.0","method":"eth_getTransactionReceipt","params":["0x85d995eba9763907fdf35cd2034144dd9d53ce32cbec21349d4b12823c6860c5"],"id":1}'3// Result4{5 "jsonrpc": "2.0",6 "id": 1,7 "result": {8 "blockHash":9 "0xa957d47df264a31badc3ae823e10ac1d444b098d9b73d204c40426e57f47e8c3",10 "blockNumber": "0xeff35f",11 "contractAddress": null, // string of the address if it was created12 "cumulativeGasUsed": "0xa12515",13 "effectiveGasPrice": "0x5a9c688d4",14 "from": "0x6221a9c005f6e47eb398fd867784cacfdcfff4e7",15 "gasUsed": "0xb4c8",16 "logs": [{17 // logs as returned by getFilterLogs, etc.18 }],19 "logsBloom": "0x00...0", // 256 byte bloom filter20 "status": "0x1",21 "to": "0xc02aaa39b223fe8d0a0e5c4f27ead9083c756cc2",22 "transactionHash":23 "0x85d995eba9763907fdf35cd2034144dd9d53ce32cbec21349d4b12823c6860c5",24 "transactionIndex": "0x66",25 "type": "0x2"26 }27}Összes megjelenítéseMásolás
eth_getUncleByBlockHashAndIndex
Egy blokk uncle-blokkjáról ad információt a hash és az uncle-index pozíciója alapján.
Paraméterek
DATA
, 32 bájt – egy blokk hashe.QUANTITY
– az uncle-index pozíciója.
1params: [2 "0x1d59ff54b1eb26b013ce3cb5fc9dab3705b415a67127a003c3e61eb445bb8df2",3 "0x0", // 04]Másolás
Visszaküldött információk Nézze meg az eth_getBlockByHash résznél
Példa
1// Request2curl -X POST --data '{"jsonrpc":"2.0","method":"eth_getUncleByBlockHashAndIndex","params":["0x1d59ff54b1eb26b013ce3cb5fc9dab3705b415a67127a003c3e61eb445bb8df2", "0x0"],"id":1}'Másolás
Az eredményeket nézze meg az eth_getBlockByHash résznél
Megjegyzés: A nagybácsi nem tartalmaz egyedi tranzakciókat.
eth_getUncleByBlockNumberAndIndex
Egy blokk uncle-blokkjáról ad információt a blokkszám és az uncle-index pozíciója alapján.
Paraméterek
QUANTITY|TAG
– a blokk száma egész számként, vagy az„earliest”
,„latest”
,„pending”
,„safe”
,„finalized”
sztringek az alapértelmezett blokkparaméterek szerint.QUANTITY
– az uncle-index pozíciója.
1params: [2 "0x29c", // 6683 "0x0", // 04]Másolás
Visszaküldött információk Nézze meg az eth_getBlockByHash résznél
Megjegyzés: A nagybácsi nem tartalmaz egyedi tranzakciókat.
Példa
1// Request2curl -X POST --data '{"jsonrpc":"2.0","method":"eth_getUncleByBlockNumberAndIndex","params":["0x29c", "0x0"],"id":1}'Másolás
Az eredményeket nézze meg az eth_getBlockByHash résznél
eth_newFilter
Egy szűrőobjektumot hoz létre a szűrőopciók alapján, hogy értesítsen, amikor a státusz változik (a naplóban). A státusz megváltozásának ellenőrzéséhez az eth_getFilterChanges metódust kell meghívni.
Megjegyzés a témaszűrők meghatározásához: A témák sorrendfüggők. Egy tranzakció egy olyan naplóval, melyben [A, B] téma (topic) van, a következő témaszűrőkhöz lesz hozzáillesztve:
[]
„bármi”[A]
„A az első helyen (utána bármi)”[null, B]
„bármi az első helyen ÉS B a második helyen (és utána bármi)”[A, B]
„A az első helyen ÉS B a második helyen (és utána bármi)”[[A, B], [A, B]]
„(A VAGY B) az első helyen ÉS (A VAGY B) a második helyen (és utána bármi)”- Paraméterek
Object
– A szűrőopciók:
fromBlock
:QUANTITY|TAG
– (opcionális, alapértelmezett:„latest”
) blokkszám egész számként, vagy„latest”
az utolsó előterjesztett blokkra,„safe”
az utolsó biztosított blokkra,„finalized”
az utolsó véglegesített blokkra, vagy„pending”
,„earliest”
a még blokkba nem került tranzakciókra.toBlock
:QUANTITY|TAG
– (opcionális, alapértelmezett:„latest”
) blokkszám egész számként, vagy„latest”
az utolsó előterjesztett blokkra,„safe”
az utolsó biztosított blokkra,„finalized”
az utolsó véglegesített blokkra, vagy„pending”
,„earliest”
a még blokkba nem került tranzakciókra.address
:DATA|Array
, 20 bájt – (opcionális) A szerződéscím vagy címek listája, amelyekről a naplók származnak.topics
:Array of DATA
, – (opcionális) aDATA
témák (topics) 32 bájtos tömbje. A témák sorrendfüggők. Minden téma egy DATA tömb lehet „vagy” opciókkal.
1params: [2 {3 fromBlock: "0x1",4 toBlock: "0x2",5 address: "0x8888f1f195afa192cfee860698584c030f4c9db1",6 topics: [7 "0x000000000000000000000000a94f5374fce5edbc8e2a8697c15331677e6ebf0b",8 null,9 [10 "0x000000000000000000000000a94f5374fce5edbc8e2a8697c15331677e6ebf0b",11 "0x0000000000000000000000000aff3454fce5edbc8cca8697c15331677e6ebccc",12 ],13 ],14 },15]Összes megjelenítéseMásolás
Visszaküldött információk QUANTITY
– Egy szűrő id.
Példa
1// Request2curl -X POST --data '{"jsonrpc":"2.0","method":"eth_newFilter","params":[{"topics":["0x12341234"]}],"id":73}'3// Result4{5 "id":1,6 "jsonrpc": "2.0",7 "result": "0x1" // 18}Másolás
eth_newBlockFilter
Létrehoz egy szűrőt a csomópontban, hogy értesítsen az új blokk érkezéséről. A státusz megváltozásának ellenőrzéséhez az eth_getFilterChanges metódust kell meghívni.
Paraméterek Egyik sem
Visszaküldött információk QUANTITY
– Egy szűrő id.
Példa
1// Request2curl -X POST --data '{"jsonrpc":"2.0","method":"eth_newBlockFilter","params":[],"id":73}'3// Result4{5 "id":1,6 "jsonrpc": "2.0",7 "result": "0x1" // 18}Másolás
eth_newPendingTransactionFilter
Létrehoz egy szűrőt a csomópontban, hogy értesítsen új függőben lévő tranzakciók érkezéséről. A státusz megváltozásának ellenőrzéséhez az eth_getFilterChanges metódust kell meghívni.
Paraméterek Egyik sem
Visszaküldött információk QUANTITY
– Egy szűrő id.
Példa
1// Request2curl -X POST --data '{"jsonrpc":"2.0","method":"eth_newPendingTransactionFilter","params":[],"id":73}'3// Result4{5 "id":1,6 "jsonrpc": "2.0",7 "result": "0x1" // 18}Másolás
eth_uninstallFilter
Egy adott azonosító alatti szűrő eltávolítása. Mindig érdemes meghívni, ha már nincs szükség az adott ellenőrzésre. Emellett a szűrőket ideiglenesen leállíthatja, amikor egy időszakban nincs azokra szükség az eth_getFilterChanges metódussal.
Paraméterek
QUANTITY
– A szűrő azonosítója.
1params: [2 "0xb", // 113]Másolás
Visszaküldött információk Boolean
– true
, ha a szűrőt sikeresen eltávolította, máskülönben false
.
Példa
1// Request2curl -X POST --data '{"jsonrpc":"2.0","method":"eth_uninstallFilter","params":["0xb"],"id":73}'3// Result4{5 "id":1,6 "jsonrpc": "2.0",7 "result": true8}Másolás
eth_getFilterChanges
Egy szűrőre vonatkozó szelektív hívás, ami a naplótömböt adja vissza, amely az utolsó szelektív hívás óta történteket foglalja magában.
Paraméterek
QUANTITY
– A szűrő azonosítója.
1params: [2 "0x16", // 223]Másolás
Visszaküldött információk Array
– Naplóobjektumok tömbje, vagy egy üres tömb, ha semmi sem változott a legutóbbi szelektív hívás óta.
- Az
eth_newBlockFilter
által létrehozott szűrőkre a visszakapott értékek a blokkhashek (DATA
, 32 bájt), például["0x3454645634534..."]
. - Az
eth_newPendingTransactionFilter
által létrehozott szűrőkre a visszakapott értékek a tranzakcióhashek (DATA
, 32 bájt), például["0x6345343454645..."]
. - Az
eth_newFilter
által készített szűrőkre a naplók olyan objektumok lesznek, melyek a következő paraméterekkel rendelkeznek:removed
:TAG
–true
, amikor a naplót törölték a lánc újrarendezése miatt.false
, ha ez egy érvényes napló.logIndex
:QUANTITY
– a naplóindex pozíciója a blokkban, egész számként.null
, amikor a napló függőben van.transactionIndex
:QUANTITY
– a tranzakcióindex pozíciója, amelyből a napló készült, egész számként.null
, amikor a napló függőben van.transactionHash
:DATA
, 32 bájt – a tranzakció hashe, amelyből ez a napló készült.null
, amikor a napló függőben van.blockHash
:DATA
, 32 bájt – a blokk-hash, amelyben ez a napló volt.null
, amikor függőben van.null
, amikor a napló függőben van.blockNumber
:QUANTITY
– a blokkszám, ahol ez a napló volt.null
, amikor függőben van.null
, amikor a napló függőben van.address
:DATA
, 20 bájt – a cím, ahonnan ez a napló származik.data
:DATA
– nullát vagy a napló több 32 bájtos nem indexált argumentumát tartalmazza.topics
:Array of DATA
– 0-tól 4-ig tartó tömbje a 32 bájtos, indexált naplóargumentumokDATA
részleteinek. (A Solidity-ben: Az első téma (topic) az esemény aláírásának a hashe (példáulDeposit(address,bytes32,uint256)
), kivéve ha az eseményt azanonymous
specifikációval deklarálták.)
- Példa
1// Request2curl -X POST --data '{"jsonrpc":"2.0","method":"eth_getFilterChanges","params":["0x16"],"id":73}'3// Result4{5 "id":1,6 "jsonrpc":"2.0",7 "result": [{8 "logIndex": "0x1", // 19 "blockNumber":"0x1b4", // 43610 "blockHash": "0x8216c5785ac562ff41e2dcfdf5785ac562ff41e2dcfdf829c5a142f1fccd7d",11 "transactionHash": "0xdf829c5a142f1fccd7d8216c5785ac562ff41e2dcfdf5785ac562ff41e2dcf",12 "transactionIndex": "0x0", // 013 "address": "0x16c5785ac562ff41e2dcfdf829c5a142f1fccd7d",14 "data":"0x0000000000000000000000000000000000000000000000000000000000000000",15 "topics": ["0x59ebeb90bc63057b6515673c3ecf9438e5058bca0f92585014eced636878c9a5"]16 },{17 ...18 }]19}Összes megjelenítéseMásolás
eth_getFilterLogs
Visszaadja a megadott azonosítóval rendelkező szűrőnek megfelelő összes napló tömbjét.
Paraméterek
QUANTITY
– A szűrő azonosítója.
1params: [2 "0x16", // 223]Másolás
Visszaküldött információk Nézze meg az eth_getFilterChanges résznél
Példa
1// Request2curl -X POST --data '{"jsonrpc":"2.0","method":"eth_getFilterLogs","params":["0x16"],"id":74}'Másolás
Az eredményeket nézze meg az eth_getFilterChanges résznél
eth_getLogs
Visszaadja az adott szűrőobjektumnak megfelelő összes naplótömböt.
Paraméterek
Object
– A szűrőopciók:
fromBlock
:QUANTITY|TAG
– (opcionális, alapértelmezett:„latest”
) blokkszám egész számként, vagy„latest”
az utolsó előterjesztett blokkra,„safe”
az utolsó biztosított blokkra,„finalized”
az utolsó véglegesített blokkra, vagy„pending”
,„earliest”
a még blokkba nem került tranzakciókra.toBlock
:QUANTITY|TAG
– (opcionális, alapértelmezett:„latest”
) blokkszám egész számként, vagy„latest”
az utolsó előterjesztett blokkra,„safe”
az utolsó biztosított blokkra,„finalized”
az utolsó véglegesített blokkra, vagy„pending”
,„earliest”
a még blokkba nem került tranzakciókra.address
:DATA|Array
, 20 bájt – (opcionális) A szerződéscím vagy címek listája, amelyekről a naplók származnak.topics
:Array of DATA
, – (opcionális) aDATA
témák (topics) 32 bájtos tömbje. A témák sorrendfüggők. Minden téma egy DATA tömb lehet „vagy” opciókkal.blockhash
:DATA
, 32 bájt – (opcionális, jövő) Az EIP-234 bevezetésével ablockHash
egy új szűrőopció lesz, amely egyetlen blokkra redukálja a visszakapott naplókat egy 32-bájtos hashsel rendelkezőblockHash
segítségével. AblockHash
használata azonos afromBlock
=toBlock
= blokkszám hashsel (blockHash
). Ha ablockHash
benne van a szűrőkritériumban, akkor nem engedélyezett se afromBlock
, se atoBlock
.
1params: [2 {3 topics: [4 "0x000000000000000000000000a94f5374fce5edbc8e2a8697c15331677e6ebf0b",5 ],6 },7]Másolás
Visszaküldött információk Nézze meg az eth_getFilterChanges résznél
Példa
1// Request2curl -X POST --data '{"jsonrpc":"2.0","method":"eth_getLogs","params":[{"topics":["0x000000000000000000000000a94f5374fce5edbc8e2a8697c15331677e6ebf0b"]}],"id":74}'Másolás
Az eredményeket nézze meg az eth_getFilterChanges résznél
Használati példa
Egy szerződés telepítése JSON_RPC-vel
Ez a rész azt mutatja be, hogyan lehet egy szerződést telepíteni kizárólag az RPC-interfésszel. Alternatív utak állnak rendelkezésre a szerződéstelepítéshez, ahol ez a komplexitás csökken, például az RPC-interfészre épített könyvtárak segítségével, mint amilyen a web3.js(opens in a new tab) és a web3.py(opens in a new tab). Ezek az absztrakciók általában könnyebben érthetők és nem annyira hajlamosak a hibára, de akkor is érdemes megérteni, hogy mi is zajlik a háttérben.
A következő egy egyszerű, Multiply7
nevű okosszerződés, amelyet a JSON-RPC-interfésszel telepítünk egy Ethereum-csomópontra. Ez az útmutató azt feltételezi, hogy Ön már futtat egy Geth-csomópontot. A csomópontokról és a kliensekről bővebben itt olvashat. Tekintse meg az egyéni kliensdokumentációt, hogy hogyan lehet HTTP JSON-RPC-t indítani nem Geth-klienseken. A legtöbb kliens alapértelmezés szerint a localhost:8545
kódon működik.
1contract Multiply7 {2 event Print(uint);3 function multiply(uint input) returns (uint) {4 Print(input * 7);5 return input * 7;6 }7}
Az első dolog, hogy a HTTP RPC-interfész engedélyezve legyen. Ez azt jelenti, hogy a Geth-nek a beállításkor megadjuk a --http
jelölőt (flag). Ebben a példában egy Geth-csomópontot használunk egy privát fejlesztési láncon. Ehhez a megközelítéshez nincs szükség etherre, mint egy valódi hálózaton.
geth --http --dev console 2>>geth.log
Ez elindítja a HTTP RPC interfészt a http://localhost:8545
kódon.
A curl(opens in a new tab) segítségével a Coinbase-címet és egyenleget lekérve ellenőrizhetjük, hogy az interfész fut-e. Vegye figyelembe, hogy e példában az adatok mások, mint az Ön lokális csomópontján. Ha ki szeretné próbálni ezeket a parancsokat, akkor a lekérdezés paramétereit a második curl kérésben cserélje le az első kérésre kapott eredményekre.
curl --data '{"jsonrpc":"2.0","method":"eth_coinbase", "id":1}' -H "Content-Type: application/json" localhost:8545{"id":1,"jsonrpc":"2.0","result":["0x9b1d35635cc34752ca54713bb99d38614f63c955"]}curl --data '{"jsonrpc":"2.0","method":"eth_getBalance", "params": ["0x9b1d35635cc34752ca54713bb99d38614f63c955", "latest"], "id":2}' -H "Content-Type: application/json" localhost:8545{"id":2,"jsonrpc":"2.0","result":"0x1639e49bba16280000"}
Mivel a számok hexadecimálisan vannak kódolva, ezért a visszakapott egyenleg wei-ben egy hexadecimális sztring. Ha az egyenleget etherben, számként szeretnénk megkapni, akkor használhatjuk a web3-at a Geth-konzolból.
1web3.fromWei("0x1639e49bba16280000", "ether")2// "410"
Most, hogy ethert tettünk a privát fejlesztési láncra, telepíthetjük a szerződést. Az első lépés, hogy a Multiply7 szerződést át kell fordítani bájtkódra, hogy el lehessen küldeni az EVM-nek. A solc, a Solidity átfordító telepítéséhez kövesse a Solidity dokumentációt(opens in a new tab). (Előfordulhat, hogy egy régebbi solc
kiadást szeretne használni, hogy az illeszkedjen a példában szereplő átfordító verziójához(opens in a new tab).)
Most tehát átfordíthatjuk a Multiply7 szerződést bájtkódra, hogy el lehessen küldeni az EVM-nek.
echo 'pragma solidity ^0.4.16; contract Multiply7 { event Print(uint); function multiply(uint input) public returns (uint) { Print(input * 7); return input * 7; } }' | solc --bin======= <stdin>:Multiply7 =======Binary:6060604052341561000f57600080fd5b60eb8061001d6000396000f300606060405260043610603f576000357c0100000000000000000000000000000000000000000000000000000000900463ffffffff168063c6888fa1146044575b600080fd5b3415604e57600080fd5b606260048080359060200190919050506078565b6040518082815260200191505060405180910390f35b60007f24abdb5865df5079dcc5ac590ff6f01d5c16edbc5fab4e195d9febd1114503da600783026040518082815260200191505060405180910390a16007820290509190505600a165627a7a7230582040383f19d9f65246752244189b02f56e8d0980ed44e7a56c0b200458caad20bb0029
Megvan az átfordított kód, úgyhogy most meghatározzunk, mennyi gázköltséget igényel a telepítése. Az RPC-interfésznek van egy eth_estimateGas
metódusa, ami megadja a becsült értéket.
curl --data '{"jsonrpc":"2.0","method": "eth_estimateGas", "params": [{"from": "0x9b1d35635cc34752ca54713bb99d38614f63c955", "data": "0x6060604052341561000f57600080fd5b60eb8061001d6000396000f300606060405260043610603f576000357c0100000000000000000000000000000000000000000000000000000000900463ffffffff168063c6888fa1146044575b600080fd5b3415604e57600080fd5b606260048080359060200190919050506078565b6040518082815260200191505060405180910390f35b60007f24abdb5865df5079dcc5ac590ff6f01d5c16edbc5fab4e195d9febd1114503da600783026040518082815260200191505060405180910390a16007820290509190505600a165627a7a7230582040383f19d9f65246752244189b02f56e8d0980ed44e7a56c0b200458caad20bb0029"}], "id": 5}' -H "Content-Type: application/json" localhost:8545{"jsonrpc":"2.0","id":5,"result":"0x1c31e"}
Végül telepítjük a szerződést.
curl --data '{"jsonrpc":"2.0","method": "eth_sendTransaction", "params": [{"from": "0x9b1d35635cc34752ca54713bb99d38614f63c955", "gas": "0x1c31e", "data": "0x6060604052341561000f57600080fd5b60eb8061001d6000396000f300606060405260043610603f576000357c0100000000000000000000000000000000000000000000000000000000900463ffffffff168063c6888fa1146044575b600080fd5b3415604e57600080fd5b606260048080359060200190919050506078565b6040518082815260200191505060405180910390f35b60007f24abdb5865df5079dcc5ac590ff6f01d5c16edbc5fab4e195d9febd1114503da600783026040518082815260200191505060405180910390a16007820290509190505600a165627a7a7230582040383f19d9f65246752244189b02f56e8d0980ed44e7a56c0b200458caad20bb0029"}], "id": 6}' -H "Content-Type: application/json" localhost:8545{"id":6,"jsonrpc":"2.0","result":"0xe1f3095770633ab2b18081658bad475439f6a08c902d0915903bafff06e6febf"}
A tranzakciót elfogadta a csomópont, és visszaküldte a tranzakcióhasht. Ezzel a hashsel lehet nyomon követni a tranzakciót. A következő lépés, hogy meghatározzuk a címet, ahová a szerződés telepítésre került. Minden végrehajtott tranzakció egy visszaigazolást ad. Ez a visszaigazolás számos információt tartalmaz a tranzakcióról, például melyik blokkba került be és mennyi gázt használt fel az EVM. Ha egy tranzakció létrehoz egy szerződést, akkor a szerződés címe is benne lesz a visszaigazolásban. A visszaigazolást megszerezhetjük az eth_getTransactionReceipt
RPC metódussal.
curl --data '{"jsonrpc":"2.0","method": "eth_getTransactionReceipt", "params": ["0xe1f3095770633ab2b18081658bad475439f6a08c902d0915903bafff06e6febf"], "id": 7}' -H "Content-Type: application/json" localhost:8545{"jsonrpc":"2.0","id":7,"result":{"blockHash":"0x77b1a4f6872b9066312de3744f60020cbd8102af68b1f6512a05b7619d527a4f","blockNumber":"0x1","contractAddress":"0x4d03d617d700cf81935d7f797f4e2ae719648262","cumulativeGasUsed":"0x1c31e","from":"0x9b1d35635cc34752ca54713bb99d38614f63c955","gasUsed":"0x1c31e","logs":[],"logsBloom":"0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000","status":"0x1","to":null,"transactionHash":"0xe1f3095770633ab2b18081658bad475439f6a08c902d0915903bafff06e6febf","transactionIndex":"0x0"}}
A szerződést a 0x4d03d617d700cf81935d7f797f4e2ae719648262
címen hozta létre. Ha nullát kapunk eredményül, akkor a tranzakció még nem került be a blokkba. Várjon egy kicsit, ellenőrizze, hogy a konszenzuskliens fut-e, és próbálja meg újra.
Interakció okosszerződésekkel
Ebben a példában elküldünk egy tranzakciót az eth_sendTransaction
metódussal a szerződés multiply
metódusának.
Az eth_sendTransaction
számos argumentumot igényel, mint a from
, to
és data
. From
a számla nyilvános címe, a to
pedig a szerződés címe. A data
tartalmazza a csomagot, hogy melyik metódust milyen argumentumokkal kell meghívni. Itt jön képbe az ABI (application binary interface)(opens in a new tab). Az ABI egy JSON-fájl, amely meghatározza, hogyan kell az EVM számára megadni és kódolni az adatokat.
Az adattörzs bájtjai határozzák meg, hogy a szerződés melyik metódusát hívják meg. Ez a Kessak-hash első 4 bájtja a függvénynév és az argumentumtípusok felett, hexadecimálisan kódolva. A szorzás függvény uint-et fogad el, ami azonos az uint256-tal. Ez a következőt jelenti:
1web3.sha3("multiply(uint256)").substring(0, 10)2// "0xc6888fa1"
A következő lépés az argumentumok kódolása. Egyetlen uint256 van csak, amelynek értéke legyen 6. Az ABI egyik része azt mutatja be, hogy miként kell kódolni az uint256 típusokat.
int<M>: enc(X)
az X két kiegészítős big-endian kódolása, a magasabb rendű (bal) oldalon 0xff-el feltöltve negatív X esetén és nulla > bájttal pozitív X esetén úgy, hogy a hossza a 32 bájt többszöröse legyen.
Ennek a kódolása a következő: 0000000000000000000000000000000000000000000000000000000000000006
.
A függvényválasztót és a kódolt argumentumot kombinálva az adatunk a következő: 0xc6888fa10000000000000000000000000000000000000000000000000000000000000006
.
Ezt el lehet küldeni a csomópontnak:
curl --data '{"jsonrpc":"2.0","method": "eth_sendTransaction", "params": [{"from": "0xeb85a5557e5bdc18ee1934a89d8bb402398ee26a", "to": "0x6ff93b4b46b41c0c3c9baee01c255d3b4675963d", "data": "0xc6888fa10000000000000000000000000000000000000000000000000000000000000006"}], "id": 8}' -H "Content-Type: application/json" localhost:8545{"id":8,"jsonrpc":"2.0","result":"0x759cf065cbc22e9d779748dc53763854e5376eea07409e590c990eafc0869d74"}
Mivel egy tranzakciót küldtünk, ezért egy hasht kapunk vissza. A visszaigazolás megérkezésekor a következőt látjuk:
1{2 blockHash: "0xbf0a347307b8c63dd8c1d3d7cbdc0b463e6e7c9bf0a35be40393588242f01d55",3 blockNumber: 268,4 contractAddress: null,5 cumulativeGasUsed: 22631,6 gasUsed: 22631,7 logs: [{8 address: "0x6ff93b4b46b41c0c3c9baee01c255d3b4675963d",9 blockHash: "0xbf0a347307b8c63dd8c1d3d7cbdc0b463e6e7c9bf0a35be40393588242f01d55",10 blockNumber: 268,11 data: "0x000000000000000000000000000000000000000000000000000000000000002a",12 logIndex: 0,13 topics: ["0x24abdb5865df5079dcc5ac590ff6f01d5c16edbc5fab4e195d9febd1114503da"],14 transactionHash: "0x759cf065cbc22e9d779748dc53763854e5376eea07409e590c990eafc0869d74",15 transactionIndex: 016 }],17 transactionHash: "0x759cf065cbc22e9d779748dc53763854e5376eea07409e590c990eafc0869d74",18 transactionIndex: 019}Összes megjelenítése
A visszaigazolás tartalmaz egy naplót. Ezt a naplót az EVM generálta a tranzakció-végrehajtáskor és beletette a visszaigazolásba. A multiply
függvény azt mutatja, hogy a Print
eseményt a bemeneti érték 7-szeresével indította el. Mivel a Print
eseményre az argumentum egy uint256 volt, kódolhatjuk az ABI szabályai szerint, ami a várt 42-es decimális értéket adja. Az adat mellett érdemes megjegyezni, hogy a témák (topics) révén meghatározható, hogy melyik esemény hozta létre a naplót:
1web3.sha3("Print(uint256)")2// "24abdb5865df5079dcc5ac590ff6f01d5c16edbc5fab4e195d9febd1114503da"
Ez csak egy rövid bevezető volt a leggyakoribb feladatokba, a JSON-RPC közvetlen használatát demonstrálandó.