当前位置:   article > 正文

区块链加载解析方法_区块链 api 下载数据

区块链 api 下载数据

一.区块链加载解析

对于数据的下载主要包括三种方式:

1.实现比特币网络协议,通过该协议和其他比特币全节点建立联系,然后同步区块数据。

2.通过比特币节点提供的API服务下载区块链数据。

3.通过blickchain.com提供的rest服务下载区块数据。

1.搭建提供公链数据服务的全节点

全节点是拥有完整区块链帐本资料的节点,具备独立验证的能力来确认交易之有效性。具体来说全节点主要在处理下列四件事:

  • 储存所有历史交易信息,资料公开透明
  • 监测矿工挖出来的新区块,验证其合法性后同步该区块
  • 监测区块链网络中的新交易信息,验证每个交易的合法性
  • 将验证过的「交易/区块信息」广播给全网络节点

1.部署节点(参考ETH全节点搭建教程(2024) | 登链社区 | 区块链技术社区

选择要提供数据服务的公链,比如以太坊、比特币、波卡等。以以太坊为例:

  1. 服务器配置:系统:Linux CPU:16核 内存:128 GB 内存 带宽:1G以上 硬盘:大于4T固态SSD可用空间数据盘
  2. 系统环境:git、golang等
  3. 节点安装部署:
  1. # 安装ETH版本的prysm
  2. cd / #进入根目录
  3. mkdir eth #创建eth文件夹
  4. cd eth
  5. mkdir consensus
  6. mkdir execution
  7. cd consensus
  8. mkdir prysm && cd prysm
  9. curl https://raw.githubusercontent.com/prysmaticlabs/prysm/master/prysm.sh --output prysm.sh && chmod +x prysm.sh
  10. ./prysm.sh beacon-chain generate-auth-secret
  11. # 安装ETH版本的geth
  12. cd /eth #进入eth目录
  13. git clone https://github.com/ethereum/go-ethereum.git
  14. make geth
  15. cd go-ethereum/build/bin
  16. # 启动ETH信标客户端
  17. screen -S prysm #创建prysm启动窗口
  18. ./prysm.sh beacon-chain --execution-endpoint=http://localhost:8551 --jwt-secret=/eth/consensus/prysm/jwt.hex
  19. # 启动ETH执行客户端
  20. screen -S eth #创建eth启动窗口
  21. ./geth --cache 10240 --datadir ./node --ws --ws.port 8546 --ws.addr 0.0.0.0 --ws.origins '*' --authrpc.addr localhost --authrpc.port 8551 --authrpc.vhosts localhost --maxpeers=300 --authrpc.jwtsecret /eth/consensus/prysm/jwt.hex --state.scheme=path

d. 节点状态监听

  1. geth attach http://localhost:8545 #端口如果修改配置文件了,就填写配置文件的端口即可
  2. > eth.syncing #查看当前区块情况,结果为false表示已同步最新区块
  3. # currentBlock: 14290861, #当前同步到区块高度 highestBlock: 14297354, #主网当前高度 knownStates:297473485, pulledStates: 297473485, startingBlock: 14270385
  4. # 同步到最高区块用了大概72小时左右就追到了最高区块。

2.拉取数据备份到本地。

3.使用数据分析服务。

(由于数据量过大暂未测试)

2.通过比特币节点提供的API服务下载区块链数据。

  1. 使用区块链浏览器(比如Blockchain Explorer)可以直观地查看特定地址的交易记录。你只需在区块链浏览器中输入地址,就能查看到相关的交易信息、交易金额、时间戳等。

Bitcoin:

https://www.okx.com/zh-hans/web3/explorer/ 中记录了44个主流的虚拟货币网站,包括:

BTC、ETH、BNB Chain、Polygon、XL、TRON、Scroll、USDT、Solana、ArbitrumOne、OP Mainnet等

        2. 网站提供相关的API接口:

有些区块链提供了API接口,允许开发者通过编程方式查询特定地址的交易记录。你可以查阅该区块链的开发文档,了解如何使用他们的API接口。

按照地址查询交易列表,查询 BTC 、LTC、 Doge 、BCH、Cardano 等链,比如:

  1. curl --location --request GET 'https://www.okx.com/api/v5/waas/wallet/post-transaction/transactions-by-address?accountId=44486e05-3235-2f8e-5fe2-a8ab46217863&chains=111,333&chainIndex=1&tokenAddress=xxx&cursor=1&limit=20&begin=168000021888"&end=168000031888 \
  2. --header 'Content-Type: application/json' \
  3. --header 'OK-ACCESS-PROJECT: 86af********d1bc' \
  4. --header 'OK-ACCESS-KEY: 37c541a1-****-****-****-10fe7a038418' \
  5. --header 'OK-ACCESS-SIGN: leaV********3uw=' \
  6. --header 'OK-ACCESS-PASSPHRASE: 1****6' \
  7. --header 'OK-ACCESS-TIMESTAMP: 2023-10-18T12:21:41.274Z' \
  1. {
  2. "code": "0",
  3. "data": [
  4. {
  5. "chainIndex": 3,
  6. "orderId": "string",
  7. "txHash": "0xcbf411766d65f3cf92839ababa73c4afec69a83442e8b67a68b5104b50a04ejb",
  8. "fromAddr": "0x5ffe4eabaf030jg7a1a75d309ead7ad31a0ef980",
  9. "toAddr": "0x5ffe4eabaf03ff67a1a75d309ead7ad31a0ef817",
  10. "txType": "2",
  11. "txTime": "0",
  12. "txStatus": "1",
  13. "assetSummary": [{
  14. "tokenAmount": "5.5",
  15. "tokenAmountNum": "5",
  16. "direction":"1",
  17. "precision": "8",
  18. "tokenSymbol": "ETH",
  19. "tokenName": "ETH",
  20. "tokenLogoUrl": "http://",
  21. "tokenAddress": ""
  22. }]
  23. }
  24. ],
  25. "msg": "success"
  26. }

按照钱包IP查找所有或某条链的交易历史:

  1. curl --location --request GET 'https://www.okx.com/api/v5/waas/wallet/post-transaction/transactions?accountId=44486e05-3235-2f8e-5fe2-a8ab46217863&chains=111,333&chainIndex=1&tokenAddress=xxx&cursor=1&limit=20&begin=168000021888"&end=168000031888 \
  2. --header 'Content-Type: application/json' \
  3. --header 'OK-ACCESS-PROJECT: 86af********d1bc' \
  4. --header 'OK-ACCESS-KEY: 37c541a1-****-****-****-10fe7a038418' \
  5. --header 'OK-ACCESS-SIGN: leaV********3uw=' \
  6. --header 'OK-ACCESS-PASSPHRASE: 1****6' \
  7. --header 'OK-ACCESS-TIMESTAMP: 2023-10-18T12:21:41.274Z' \、

响应体

  1. {
  2. "code": "0",
  3. "data": [
  4. {
  5. "chainIndex": "3",
  6. "orderId": "string",
  7. "txHash": "0xcbf411766d65f3cf92839ababa73c4afec69a83442e8b67a68b5104b50a04ejb",
  8. "fromAddr": "0x5ffe4eabaf030jg7a1a75d309ead7ad31a0ef980",
  9. "toAddr": "0x5ffe4eabaf03ff67a1a75d309ead7ad31a0ef817",
  10. "txType": "2",
  11. "txTime": "0",
  12. "txStatus": "1",
  13. "assetSummary": [{
  14. "tokenAmount": "5.5",
  15. "tokenAmountNum": "5",
  16. "direction":"1",
  17. "precision": "8",
  18. "tokenSymbol": "ETH",
  19. "tokenName": "ETH",
  20. "tokenLogoUrl": "http://",
  21. "tokenAddress": ""
  22. }]
  23. }
  24. ],
  25. "msg": "success"
  26. }

3.通过blickchain.com提供的rest服务下载区块数据。

第一个接口:通过区块高度查询区块哈希。我们以创世区块(Genesis Block,高度为0)为例,调用这个接口:https://blockchain.info/block-height/0?format=json,下面是返回的数据(JSON格式,省略了大部分无关内容):

  1. {
  2. "blocks": [
  3. {
  4. "hash": "000000000019d6689c085ae165831e934ff763ae46a2a6c172b3f1b60a8ce26f",
  5. "ver": 1,
  6. "prev_block":"0000000000000000000000000000000000000000000000000000000000000000",
  7. ...
  8. }
  9. ]
  10. }

第二个接口:通过区块哈希查询区块原始数据。我们还是以创世区块为例,调用这个接口:https://blockchain.info/rawblock/000000000019d6689c085ae165831e934ff763ae46a2a6c172b3f1b60a8ce26f?format=hex,下面是返回的数据(16进制字符串,换行是为了方便展示而人为添加的):​​​​​​

  1. 0100000000000000000000000000000000000000000000000000000000000000
  2. 000000003ba3edfd7a7b12b27ac72c3e67768f617fc81bc3888a51323a9fb8aa
  3. 4b1e5e4a29ab5f49ffff001d1dac2b7c01010000000100000000000000000000
  4. 00000000000000000000000000000000000000000000ffffffff4d04ffff001d
  5. 0104455468652054696d65732030332f4a616e2f32303039204368616e63656c
  6. 6c6f72206f6e206272696e6b206f66207365636f6e64206261696c6f75742066
  7. 6f722062616e6b73ffffffff0100f2052a01000000434104678afdb0fe554827
  8. 1967f1a67130b7105cd6a828e03909a67962e0ea1f61deb649f6bc3f4cef38c4
  9. f35504e51ec112de5c384df7ba0b8d578a4c702b6bf11d5fac00000000

解析:

区块头是前面 80 个字节,最开始第一个字节是版本号,往后 32 个字节是前一个区块的哈希值,由于这是第一个区块,它的前面没有区块,所以 32 个字节都是 0,再往后 32 个字节是交易列表的哈希树,再往后 4 个字节是时间,内容是 29 AB 5F 49,转换成后的时间戳是 1231006505,再往后是当前难度,最后 4 个字节是随机数,如下表:

字段

含义

长度

内容

Version

版本号

4

01

PreviousBlockHash

前一个区块头的哈希值

32

0000000000000000000000000000000000000000000000000000000000000000000000

MerkleRoot

交易列表的哈希树

32

3ba3edfd7a7b12b27ac72c3e67768f617fc81bc3888a51323a9fb8aa4b1e5e4a

Time

时间戳

4

29ab5f49

Bits

挖矿难度

4

ffff001d

Nonce

随机数

4

区块体:第 81 个字节开始是区块体,区块体第一个字节是交易的数量,内容是 01,说明只有一笔交易。往后的字节是交易体,交易体字段如下表,有一个需要注意的地方,Value 字段是 BTC 的数据,这里是小端格式,内容是十六进制值 0x00f2052a01000000 转化为大端格式十六进制值0x000000012a05f200,再转化为十进制值为 5000000000,比特币最小单位是聪,表示该交易输出比特币是 50 亿聪,也就是挖出该区块得到的 50 个比特币奖励。

字段

含义

长度

内容

Version

版本号

4

01000000

InputCount

输入的条数

1

01

UTXOHash

UTXO交易哈希值

32

0000000000000000000000000000000000000000000000000000000000000000

outputIndex

输出索引

4

ffffffff

ScriptLen

脚本长度

1

十六进制 4D,十进制 77

Script

脚本内容

不定

��EThe Times 03/Jan/2009 Chancellor on brink of second bailout for banks

Sequence

字节序列号

4

ffffffff

outputCount

输出索引

1

01

Value

BTC数值

8

00f2052a01000000,转换为 5000000000

lockScriptLen

锁定脚本长度

1

十六进制 43,十进制 67

lockScriptBody

锁定脚本长度

不定

lockScriptTime

锁定时间

4

00000000

ÿÿETime 03/Jan/2009 Chancellor on brink of second bailout for banks这是比特币的创世区块中coinbase交易的文本部分,按照ASCII编码解码后的内容。

为了说明清晰的说明交易内容,可以查看最新的一个区块链的数据块https://blockchain.info/rawblock/00000000000000000001d1ddded79928d137b52784731b17b70ad56a21f7e666

选取其中一笔交易:

  1. {
  2. "hash": "1b7fc239d4c7d04356a90e274a328bb06fb8e32f540bab79778072af1ee27a6a",
  3. "ver": 2,
  4. "vin_sz": 1,
  5. "vout_sz": 1,
  6. "size": 219,
  7. "weight": 465,
  8. "fee": 2206,
  9. "relayed_by": "0.0.0.0",
  10. "lock_time": 0,
  11. "tx_index": 3746432390917712,
  12. "double_spend": false,
  13. "time": 1719985042,
  14. "block_index": 850489,
  15. "block_height": 850489,
  16. "inputs": [
  17. {
  18. "sequence": 4294967295,
  19. "witness": "0340d1811e193217f655131d151c436e9896767101d39812500865f87889261b539951bfb12ca9a609abbdc3d80d6816ecb198914cd5c1f6f16f6d91197262534dbf220063036f7264510a746578742f706c61696e000d3835303438392e6269746d61706821c1c72952c171396617fbb3a4e0dbb8f4e92eb5835738b3ba0a4c6f0c11ef0c920b",
  20. "script": "",
  21. "index": 0,
  22. "prev_out": {
  23. "type": 0,
  24. "spent": true,
  25. "value": 2500,
  26. "spending_outpoints": [
  27. {
  28. "tx_index": 3746432390917712,
  29. "n": 0
  30. }
  31. ],
  32. "n": 404,
  33. "tx_index": 3166247195096694,
  34. "script": "5120f11de4ecaf49d876598ab136dc86d978449dda0af7aa53bea4ad63b2febdc0c6",
  35. "addr": "bc1p7yw7fm90f8v8vkv2kymdepke0pzfmks27749804y443m9l4acrrqau96l9" //这里看到交易from的地址
  36. }
  37. }
  38. ],
  39. "out": [
  40. {
  41. "type": 0,
  42. "spent": false,
  43. "value": 294,
  44. "spending_outpoints": [],
  45. "n": 0,
  46. "tx_index": 3746432390917712,
  47. "script": "00143c8c5b36c1500321291b25b5612f5d8cdb40dba8",
  48. "addr": "bc1q8jx9kdkp2qpjz2gmyk6kzt6a3nd5pkagrd79fx" //这里看到交易to的地址
  49. }
  50. ]
  51. },

结束语:大家参考引用本文时注意加入来源引用

参考

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/知新_RL/article/detail/975191
推荐阅读
相关标签
  

闽ICP备14008679号