Неперехваченный (в обещании) 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 требуются некоторые зависимости и конфигурации веб-пакетов.
Вы можете использовать код, которым я делюсь:-