做SOL交易机器人拆解步骤,其实没有那么复杂。

时间:2024-12-07 08:18:11

做SOL交易机器人拆解步骤,其实并没有那么复杂,对于有一定技术基础的人来说,完全可以按部就班地进行。

在踏入这个领域之前,许多人可能会因为听到“机器人拆解”这样的词汇而感到心生畏惧,担心其中涉及的技术门槛过高,难以逾越。然而,事实并非如此。只要我们掌握了正确的方法和步骤,就能够逐步揭开SOL交易机器人的神秘面纱,了解其内在的工作原理和构造。接下来,本文将为大家详细介绍SOL交易机器人的拆解步骤,帮助大家轻松入门,一探究竟。

其实,Solana交易机器人的核心功能,简而言之,就是如何高效、精准地执行下单操作。这一步骤是整个交易流程中的关键环节,直接关系到交易的成败与效益。一旦下单逻辑设计得当,后续诸如订单管理、风险控制、数据分析等环节,相对来说就会变得非常直接和简单。因为核心问题解决后,其他模块都可以围绕这一核心进行构建和优化,确保整个交易系统的流畅运行。

require('dotenv').config();
const bs58 = require('bs58');
const fetch = require('cross-fetch');
const web3 = require('@solana/web3.js');
const { Connection, Keypair, VersionedTransaction, PublicKey } = web3;
const { Wallet } = require('@project-serum/anchor');
const { getMint } = require('@solana/spl-token');

// 初始化钱包和连接
const wallet = new Wallet(Keypair.fromSecretKey(bs58.decode(process.env.PRIVATE_KEY || '')));
const connection = new Connection('https://api.mainnet-beta.solana.com/');

// 获取代币精度的函数
async function getDecimals(mintAddress) {
  const mint = await getMint(connection, new PublicKey(mintAddress));
  return mint.decimals;
}

/**
 * swap 兑换
 * @param {string} inputMint - 给出资产地址
 * @param {string} outputMint - 获得资产地址
 * @param {number} amountIn - 给出数量
 * @param {number} slippageBps - 滑点,默认值 50
 */
async function swap({ inputMint, outputMint, amountIn, slippageBps = 50 }) {
  // 获取输入代币的精度
  const inputMintDecimals = await getDecimals(inputMint);

  // 获取报价
  const quoteResponse = await (
    await fetch(`https://quote-api.jup.ag/v6/quote?inputMint=${inputMint}&outputMint=${outputMint}&amount=${amountIn * 10 ** inputMintDecimals}&slippageBps=${slippageBps}`)
  ).json();

上面代码就是下单代码,并且我这边有给出注释。

首先我们通过getDecimals函数,计算出下单的小数点是多少,并且给他赋值一个变量,然后把这个变量复制到await fetch 的URL这里来。

接下来我们还要把这个兑换进去的及兑换出来的这个币的地址写在这个URL里面来,包括数量等等。

// 获取交换事务序列化数据
  const { swapTransaction } = await (
    await fetch('https://quote-api.jup.ag/v6/swap', {
      method: 'POST',
      headers: {
        'Content-Type': 'application/json',
      },
      body: JSON.stringify({
        // 从 /quote API 获取的响应
        quoteResponse,
        // 用户的钱包公钥
        userPublicKey: wallet.publicKey.toString(),
        // 自动处理 SOL 的包装和解包,默认是 true
        wrapAndUnwrapSol: true,
      }),
    })
  ).json();

  // 将交换事务数据解码为 Buffer
  const swapTransactionBuf = Buffer.from(swapTransaction, 'base64');

  // 反序列化交易数据
  const transaction = VersionedTransaction.deserialize(swapTransactionBuf);

  // 签署交易
  transaction.sign(wallet.payer);

  // 序列化交易数据
  const rawTransaction = transaction.serialize();

  // 发送原始交易
  const txid = await connection.sendRawTransaction(rawTransaction, {
    skipPreflight: true,
    maxRetries: 2,
  });

  console.log('Transaction ID:', txid);
  return txid;
}

生成JOSN后,我们用POST方法去请求JUP的API。它会给我们生成一个哈希

接下来SwapTransaction我们通过buffer编译后进行签名,在然后广播上链。

最后确保上链成功。

超时设置这里我们可以设置120秒。

成功上链之后呢, 它会返还给我们一个哈希对应的区块链地址。

欢迎对Solana感兴趣的小伙伴来讨论。