Solana主网使用自定义的RPC进行转账

1、引言

如果用 browser 连接主网的 RPC server 会收到 error code 403 message 為 Access forbidden, contact your app developer or support@rpcpool.com. 错误,因为主网的 RPC server 会检查 HTTP Header 如果判断出來是 browser 就会报告 403 錯誤。

要解決这个问题就是换一个 RPC server ,可以注册免费的 RPC server 。

2、免费RPC Server

Solana RPC Server 是让开发者存取区块链数据的 Server , Solana 主网有提供一个(Solana Cluster RPC Endpoints (opens new window)),但是为了避免滥用,有设定一些网路存取的限制,存取太快会产生 HTTP 429 的错误。

所以要开发 Solana 应用程式最好还是有个自己的 RPC Server ,不过要建立自己的 RPC Server 代价相当高,根据 How to run a Solana RPC node (opens new window)这篇文章, CPU 要 32 core ,记忆体要 250 GB ,这样的硬体规格租下来可是相当花钱。

于是就有一些公司提供 RPC Server 服务,然后只要注册就可以使用到一些免费额度,这些免费额度对于开发 Solana 应用程式就相当够用了,以下几个是博主试过有免费额度又稳定的 Solana RPC server

Chainstack

一个月免费额度 300 万个 request

QuickNode

一个月免费额度 1000 万个 request

3、sol转账代码

复制代码
import { useWallet } from 'solana-wallets-vue'
import {Connection, clusterApiUrl, Keypair, SystemProgram, Transaction, PublicKey} from '@solana/web3.js';

const { publicKey, connected, sendTransaction } = useWallet();

const onClick = async () => {
        if (!publicKey) {
            console.log('error', `Send Transaction: Wallet not connected!`);
            return;
        }

        let signature = '';
        try {
            // send 1 lamport to random account
            // https://solanacookbook.com/references/basic-transactions.html#how-to-send-sol

            const account = Keypair.generate();
            const transaction = new Transaction().add(
                SystemProgram.transfer({
                    fromPubkey: publicKey.value,
                    toPubkey: new PublicKey("接收地址"),
                    lamports: 1_000_000,
                })
            );

            //const connection = new Connection(clusterApiUrl('devnet'));
            const connection = new Connection(
                "https://solana-mainnet.core.chainstack.com/xxx", //替换rpc链接
                {
                  wsEndpoint:'wss://solana-mainnet.core.chainstack.com/ws/xxx' //替换rpc链接
                }
            );
            signature = await sendTransaction(transaction, connection);
            await connection.confirmTransaction(signature, 'confirmed');
            console.log("successs")
        } catch (error) {
            console.log('error', `Transaction failed! ${error?.message}`, signature);
            return;
        }
    }

4、转账结果查询

相关推荐
superlls1 天前
(微服务)Dubbo 服务调用
笔记·rpc·dubbo
_BugMan1 天前
【k8s】基础概念+下载安装教程
容器·rpc·kubernetes
岁岁岁平安2 天前
Java+SpringBoot+Dubbo+Nacos快速入门
java·spring boot·nacos·rpc·dubbo
努力的小郑2 天前
有了TCP为什么还需要HTTP?再用RPC?这次彻底讲明白了
http·微服务·rpc
编啊编程啊程2 天前
兼职管理平台
java·spring boot·rpc·dubbo·nio
会开花的二叉树3 天前
分布式文件存储 RPC 服务实现
c++·分布式·网络协议·rpc
眠りたいです7 天前
基于脚手架微服务的视频点播系统-脚手架开发部分-brpc中间件介绍与使用及二次封装
c++·微服务·中间件·rpc·架构·brpc
锋风Fengfeng8 天前
基于Binder的4种RPC调用
网络协议·rpc·binder
编啊编程啊程8 天前
gRPC从0到1系列【20】
java·rpc·kafka·dubbo·nio
编啊编程啊程8 天前
gRPC从0到1系列【19】
java·spring boot·rpc·dubbo·nio