Неперехваченный (в обещании) ReferenceError: Буфер не определен. Использование Phantom Wallet, Solana и React для совершения транзакции

Я создал простое приложение CRA, чтобы выяснить, как использовать кошелек Phantom для совершения транзакций Solana (я до сих пор не знаю, возможно ли это вообще). Я сослался на два источника и источник вопросов Stackoverflow и придумал несколько работающий код, поскольку в раздаче работает отлично, а основная транзакция - нет.

Это мой код:

      import "./App.css";
import { useEffect, useState } from "react";
const web3 = require("@solana/web3.js");

function App() {
  const [provider, setProvider] = useState(null);
  const [walletKey, setWalletKey] = useState(null);

  const getProvider = () => {
    if ("solana" in window) {
      const provider = window.solana;
      if (provider.isPhantom) {
        return provider;
      }
    }
  };

  const connectWallet = async () => {
    const provider = getProvider();
    if (provider) {
      try {
        const response = await provider.connect();
        const pubKey = await provider.publicKey;
        console.log(pubKey);
        setProvider(provider);
        setWalletKey(response.publicKey.toString());
      } catch (err) {
        // { code: 4001, message: 'User rejected the request.' }
      }
    }
  };

  useEffect(() => connectWallet, []);

  const airDropSol = async (connection, publicKey) => {
    try {
      const airdropSignature = await connection.requestAirdrop(
        publicKey,
        web3.LAMPORTS_PER_SOL
      );

      const latestBlockHash = await connection.getLatestBlockhash();

      // Confirming that the airdrop went through
      await connection.confirmTransaction({
        blockhash: latestBlockHash.blockhash,
        lastValidBlockHeight: latestBlockHash.lastValidBlockHeight,
        signature: airdropSignature,
      });
      console.log("Airdropped");
    } catch (error) {
      console.error(error);
    }
  };

  async function transferSOL() {
    //Changes are only here, in the beginning
    const phantomProvider = provider;
    if (!phantomProvider) {
      console.log("No provider found", phantomProvider);
    }
    const pubKey = await phantomProvider.publicKey;
    console.log("Public Key: ", pubKey);

    // Establishing connection
    var connection = new web3.Connection(web3.clusterApiUrl("devnet"));

    // I have hardcoded my secondary wallet address here. You can take this address either from user input or your DB or wherever
    var recieverWallet = new web3.PublicKey(
      "Wallet Key I want to send SOL to here"
    );

    // Airdrop some SOL to the sender's wallet, so that it can handle the txn fee
    airDropSol(connection, pubKey);

    console.log("WORKED 1");
    const transaction = new web3.Transaction();
    const instructions = web3.SystemProgram.transfer({
      fromPubkey: pubKey,
      toPubkey: recieverWallet,
      lamports: web3.LAMPORTS_PER_SOL, //Investing 1 SOL. Remember 1 Lamport = 10^-9 SOL.
    });
    transaction.add(instructions);
    console.log("WORKED 2");
    // Setting the variables for the transaction
    transaction.feePayer = pubKey;
    let blockhashObj = await connection.getLatestBlockhash();
    transaction.recentBlockhash = blockhashObj.blockhash;

    const signature = await phantomProvider.signAndSendTransaction(
      connection,
      transaction,
      [pubKey]
    );
    await connection.confirmTransaction(signature);
    console.log(signature);
  }

  return (
    <div className="App">
      <header className="App-header">
        <h2>Tutorial: Connect to Phantom Wallet</h2>

        {provider && walletKey && <p>Connected account {walletKey}</p>}
        {provider && walletKey && <button onClick={transferSOL}>TEST</button>}

        {!provider && (
          <p>
            No provider found. Install{" "}
            <a href="https://phantom.app/">Phantom Browser extension</a>
          </p>
        )}
      </header>
    </div>
  );
}

export default App;

Это ошибка, сгенерированная в, и я не знаю, как ее исправить. Кто-нибудь может помочь? Ошибка в консоли браузера

Также, когда я запускаю npm start, эта ошибка также отображается в консоли vcode .

Все, что я хочу сделать, это просто отправить SOL с одного фантомного кошелька на другой, как отправку денег в реальной жизни, я потратил много времени, пытаясь понять это, кто-нибудь, пожалуйста, укажите на проблему и помогите

2 ответа

С Webpack 5 вам нужно полифиллBuffer.

Вот учебник о том, как это сделать https://viglucci.io/how-to-polyfill-buffer-with-webpack-5 .

А вот пример конфигурации веб-пакета пользовательского интерфейса Solana dApp, созданного с помощью CRA https://github.com/Bonfida/serverless-merch/blob/master/ui/config-overrides.js .

Используйте @solana/web3.js версии 1.30.2 Для новых версий библиотек web3 требуются некоторые зависимости и конфигурации веб-пакетов.

Вы можете использовать код, которым я делюсь:-

Обратитесь к моему коду по этой ссылке

Другие вопросы по тегам