Docs

eth_getBlockByNumber - opBNB RPC Method

Retrieve complete block data by block number on opBNB. Perfect for GameFi developers, high-frequency dApp builders, and teams requiring BNB Chain integration building on Binance's high-performance L2 processing 100M+ daily transactions with the lowest L2 gas fees.

Returns information about a block by block number on opBNB.

Why opBNB? Build on Binance's high-performance L2 processing 100M+ daily transactions with the lowest L2 gas fees with sub-$0.0001 gas fees, 5-10K TPS, sub-second block times via Volta/Maxwell upgrades, and OP Stack architecture.

When to Use This Method

eth_getBlockByNumber is essential for GameFi developers, high-frequency dApp builders, and teams requiring BNB Chain integration:

  • Block explorers and analytics dashboards: Display comprehensive block data and chain metrics for end-user interfaces on opBNB
  • Transaction indexers processing block contents: Extract and index every transaction within a block for data pipelines and search backends
  • Cross-chain bridges verifying block data: Validate block headers and transaction proofs for fully on-chain games, high-frequency DeFi, and cost-sensitive applications on BNB Chain
  • Timestamp-based logic: Verify block age and enforce time-dependent contract logic on Binance's high-performance L2 processing 100M+ daily transactions with the lowest L2 gas fees

Common Use Cases

1. Process All Transactions in the Latest Block

Fetch the latest block on opBNB with full transaction objects, then iterate through each transaction to extract sender, receiver, value, and gas data. This pattern powers indexers, analytics dashboards, and event backfill pipelines.

JavaScript
import { JsonRpcProvider, formatEther } from 'ethers';

const provider = new JsonRpcProvider('https://api-opbnb-mainnet.n.dwellir.com/YOUR_API_KEY');

async function processLatestBlock() {
  const block = await provider.getBlock('latest', true);

  if (!block) return;

  console.log(`Block #${block.number}: ${block.transactions.length} transactions`);

  for (const tx of block.prefetchedTransactions) {
    console.log(`  ${tx.hash}`);
    console.log(`    From: ${tx.from}  To: ${tx.to}`);
    console.log(`    Value: ${formatEther(tx.value)}  Gas: ${tx.gasLimit.toString()}`);
  }
}

processLatestBlock();

2. Monitor New Blocks with a Polling Loop

Poll eth_getBlockByNumber at regular intervals to detect new blocks as they are produced on opBNB. This lightweight pattern is suitable for bots, watchers, and notification services that need near-real-time block awareness.

Python
from web3 import Web3
import time

w3 = Web3(Web3.HTTPProvider('https://api-opbnb-mainnet.n.dwellir.com/YOUR_API_KEY'))

last_block = w3.eth.block_number

print(f'Starting from block #{last_block}')

while True:
    current_block = w3.eth.block_number
    if current_block > last_block:
        for block_num in range(last_block + 1, current_block + 1):
            block = w3.eth.get_block(block_num)
            tx_count = len(block.transactions)
            print(f'New block #{block.number}: {tx_count} txns, '
                  f'gas used {block.gasUsed}')
        last_block = current_block
    time.sleep(2)

3. Verify Block Finality on L2 Chains

Layer 2 rollup chains on Binance's high-performance L2 processing 100M+ daily transactions with the lowest L2 gas fees expose additional block tags that indicate settlement confidence. Use safe or finalized tags alongside the base latest tag for use cases requiring strong finality guarantees.

Go
package main

import (
    "context"
    "fmt"
    "log"
    "math/big"

    "github.com/ethereum/go-ethereum/ethclient"
)

func main() {
    client, _ := ethclient.Dial("https://api-opbnb-mainnet.n.dwellir.com/YOUR_API_KEY")

    // Latest block (may be unconfirmed on L2)
    latest, _ := client.BlockByNumber(context.Background(), nil)
    fmt.Printf("Latest block: %d (timestamp: %d)\n",
        latest.Number().Uint64(), latest.Time())

    // Finalized block (settled on L1 for rollups)
    finalized, _ := client.BlockByNumber(context.Background(),
        big.NewInt(int64(RPCLatestBlockNumber-32))) // placeholder: use rpc.FinalizedBlockNumber
    if finalized != nil {
        fmt.Printf("Finalized block: %d\n", finalized.Number().Uint64())
    }
}

Best Practices

  • Cache block data by block number: Blocks are immutable once finalized, so cache results indefinitely keyed by block number to eliminate redundant API calls
  • Use latest tag for most use cases; avoid pending for production: The pending tag returns speculative data that may never be included in the canonical chain
  • For L2 chains, check chain-specific finality tags: Tags like safe and finalized provide settlement guarantees specific to each rollup's proof mechanism
  • Combine with eth_getBlockReceipts for efficient receipt scanning: When you need both block headers and transaction outcomes, use eth_getBlockReceipts alongside this method rather than fetching receipts individually

Code Examples

Error Handling

Error CodeMessageDescription
-32602Invalid paramsInvalid block number or parameter format
-32000Block not foundBlock does not exist