Verkkoon kirjoittaminen

Edellisessä osiossa opit lukemaan dataa Solana-verkosta. Nyt opit kirjoittamaan siihen dataa. Solana-verkkoon kirjoittaminen edellyttää transaktioiden lähettämistä, jotka sisältävät yhden tai useamman ohjeen.

Ohjelmat määrittelevät liiketoimintalogiikan sille, mitä kukin ohje tekee. Kun lähetät transaktion, Solana-ajonaikaympäristö suorittaa jokaisen ohjeen järjestyksessä ja atomisesti. Tämän osion esimerkit näyttävät, miten rakennetaan ja lähetetään transaktioita Solana-ohjelmien kutsumiseksi, ja ne sisältävät:

  1. SOL:n siirtäminen tilien välillä
  2. Uuden tokenin luominen

SOL:n siirtäminen

Alla oleva esimerkki siirtää SOL:ia kahden tilin välillä. Jokaisella tilillä on omistaja- ohjelma, joka on ainoa ohjelma, joka voi vähentää tilin SOL-saldoa.

Kaikki lompakkotilit ovat System Program -ohjelman omistuksessa. SOL:n siirtämiseksi sinun on kutsuttava System Program -ohjelman transfer- ohjetta.

Transfer SOL
import {
LAMPORTS_PER_SOL,
SystemProgram,
Transaction,
sendAndConfirmTransaction,
Keypair,
Connection
} from "@solana/web3.js";
const connection = new Connection("http://localhost:8899", "confirmed");
const sender = new Keypair();
const receiver = new Keypair();
const signature = await connection.requestAirdrop(
sender.publicKey,
LAMPORTS_PER_SOL
);
await connection.confirmTransaction(signature, "confirmed");
const transferInstruction = SystemProgram.transfer({
fromPubkey: sender.publicKey,
toPubkey: receiver.publicKey,
lamports: 0.01 * LAMPORTS_PER_SOL
});
const transaction = new Transaction().add(transferInstruction);
const transactionSignature = await sendAndConfirmTransaction(
connection,
transaction,
[sender]
);
console.log("Transaction Signature:", `${transactionSignature}`);
const senderBalance = await connection.getBalance(sender.publicKey);
const receiverBalance = await connection.getBalance(receiver.publicKey);
console.log("Sender Balance:", `${senderBalance}`);
console.log("Receiver Balance:", `${receiverBalance}`);
Console
Click to execute the code.

Luo Connection transaktioiden lähettämisen ja tilitietojen hakemisen käsittelyyn.

Tässä esimerkissä yhdistämme paikalliseen testivalidatoriin, joka toimii osoitteessa localhost:8899.

Connection
const connection = new Connection("http://localhost:8899", "confirmed");

Luo uudet avainparit käytettäväksi lähettäjä- ja vastaanottajatileinä.

Generate keypairs
const sender = new Keypair();
const receiver = new Keypair();

Lisää SOL lähettäjätilille. Muissa verkoissa kuin mainnetissä voit käyttää requestAirdrop -metodia saadaksesi SOL-tokeneita testausta varten.

Airdrop
const signature = await connection.requestAirdrop(
sender.publicKey,
LAMPORTS_PER_SOL
);
await connection.confirmTransaction(signature, "confirmed");

SystemProgram.transfer() -metodi luo ohjeen, joka siirtää SOL-tokeneita fromPubkey -tililtä toPubkey -tilille määritetyn lamports -määrän verran.

Transfer instruction
const transferInstruction = SystemProgram.transfer({
fromPubkey: sender.publicKey,
toPubkey: receiver.publicKey,
lamports: 0.01 * LAMPORTS_PER_SOL
});

Luo transaktio ja lisää ohje transaktioon. Tässä esimerkissä luomme transaktion, jossa on yksi ohje. Voit kuitenkin lisätä useita ohjeita yhteen transaktioon.

Transaction
const transaction = new Transaction().add(transferInstruction);

Allekirjoita ja lähetä transaktio verkkoon. Lähettäjän keypair vaaditaan allekirjoittajien taulukkoon SOL:n siirron valtuuttamiseksi heidän tililtään.

Send transaction
const transactionSignature = await sendAndConfirmTransaction(
connection,
transaction,
[sender]
);

Transaktion allekirjoitus on yksilöllinen tunniste, jota voidaan käyttää transaktion etsimiseen Solana Explorerista.

Luo Connection transaktioiden lähettämisen ja tilitietojen hakemisen käsittelyyn.

Tässä esimerkissä yhdistämme paikalliseen testivalidatoriin, joka toimii osoitteessa localhost:8899.

Connection
const connection = new Connection("http://localhost:8899", "confirmed");

Luo uudet avainparit käytettäväksi lähettäjä- ja vastaanottajatileinä.

Generate keypairs
const sender = new Keypair();
const receiver = new Keypair();

Lisää SOL lähettäjätilille. Muissa verkoissa kuin mainnetissä voit käyttää requestAirdrop -metodia saadaksesi SOL-tokeneita testausta varten.

Airdrop
const signature = await connection.requestAirdrop(
sender.publicKey,
LAMPORTS_PER_SOL
);
await connection.confirmTransaction(signature, "confirmed");

SystemProgram.transfer() -metodi luo ohjeen, joka siirtää SOL-tokeneita fromPubkey -tililtä toPubkey -tilille määritetyn lamports -määrän verran.

Transfer instruction
const transferInstruction = SystemProgram.transfer({
fromPubkey: sender.publicKey,
toPubkey: receiver.publicKey,
lamports: 0.01 * LAMPORTS_PER_SOL
});

Luo transaktio ja lisää ohje transaktioon. Tässä esimerkissä luomme transaktion, jossa on yksi ohje. Voit kuitenkin lisätä useita ohjeita yhteen transaktioon.

Transaction
const transaction = new Transaction().add(transferInstruction);

Allekirjoita ja lähetä transaktio verkkoon. Lähettäjän keypair vaaditaan allekirjoittajien taulukkoon SOL:n siirron valtuuttamiseksi heidän tililtään.

Send transaction
const transactionSignature = await sendAndConfirmTransaction(
connection,
transaction,
[sender]
);

Transaktion allekirjoitus on yksilöllinen tunniste, jota voidaan käyttää transaktion etsimiseen Solana Explorerista.

Transfer SOL
import {
LAMPORTS_PER_SOL,
SystemProgram,
Transaction,
sendAndConfirmTransaction,
Keypair,
Connection
} from "@solana/web3.js";
const connection = new Connection("http://localhost:8899", "confirmed");

Luo token

Alla oleva esimerkki luo uuden tokenin Solanaan käyttäen Token Extensions Programia. Tämä vaatii kaksi instruktiota:

  1. Kutsu System Programia luodaksesi uuden tilin.
  2. Kutsu Token Extensions Programia alustamaan kyseinen tili Mintiksi.
Create mint account
import {
Connection,
Keypair,
SystemProgram,
Transaction,
sendAndConfirmTransaction,
LAMPORTS_PER_SOL
} from "@solana/web3.js";
import {
MINT_SIZE,
TOKEN_2022_PROGRAM_ID,
createInitializeMint2Instruction,
getMinimumBalanceForRentExemptMint,
getMint
} from "@solana/spl-token";
const connection = new Connection("http://localhost:8899", "confirmed");
const wallet = new Keypair();
// Fund the wallet with SOL
const signature = await connection.requestAirdrop(
wallet.publicKey,
LAMPORTS_PER_SOL
);
await connection.confirmTransaction(signature, "confirmed");
// Generate keypair to use as address of mint account
const mint = new Keypair();
// Calculate lamports required for rent exemption
const rentExemptionLamports =
await getMinimumBalanceForRentExemptMint(connection);
// Instruction to create new account with space for new mint account
const createAccountInstruction = SystemProgram.createAccount({
fromPubkey: wallet.publicKey,
newAccountPubkey: mint.publicKey,
space: MINT_SIZE,
lamports: rentExemptionLamports,
programId: TOKEN_2022_PROGRAM_ID
});
// Instruction to initialize mint account
const initializeMintInstruction = createInitializeMint2Instruction(
mint.publicKey,
2, // decimals
wallet.publicKey, // mint authority
wallet.publicKey, // freeze authority
TOKEN_2022_PROGRAM_ID
);
// Build transaction with instructions to create new account and initialize mint account
const transaction = new Transaction().add(
createAccountInstruction,
initializeMintInstruction
);
const transactionSignature = await sendAndConfirmTransaction(
connection,
transaction,
[
wallet, // payer
mint // mint address keypair
]
);
console.log("Transaction Signature:", `${transactionSignature}`);
const mintData = await getMint(
connection,
mint.publicKey,
"confirmed",
TOKEN_2022_PROGRAM_ID
);
);
Console
Click to execute the code.

Tokenin luominen vaatii sekä @solana/web3.js- että @solana/spl-token -kirjastojen käyttöä. Alla olevan esimerkin koodi:

  • Luo yhteyden
  • Luo keypair transaktion maksamiseen
  • Pyydä airdrop keypair-parin rahoittamiseen
Connection & wallet setup
const connection = new Connection("http://localhost:8899", "confirmed");
const wallet = new Keypair();
const signature = await connection.requestAirdrop(
wallet.publicKey,
LAMPORTS_PER_SOL
);
await connection.confirmTransaction(signature, "confirmed");

Luo keypair mint-tilille. Julkista avainta käytetään mint-tilin osoitteena.

Mint keypair
const mint = new Keypair();

Laske mint-tilille vaadittavien lamport-yksiköiden vähimmäismäärä. getMinimumBalanceForRentExemptMint -funktio laskee, kuinka monta lamportia on varattava mint-tilin datalle.

Rent exemption
const rentExemptionLamports =
await getMinimumBalanceForRentExemptMint(connection);

Ensimmäinen käsky kutsuu System Programin createAccount -käskyä seuraavasti:

  1. Varaa tarvittava määrä tavuja mint-datan tallentamiseen.
  2. Siirrä lamportteja lompakosta uuden tilin rahoittamiseksi.
  3. Määritä tilin omistajuus Token Extensions -ohjelmalle.
Create account instruction
const createAccountInstruction = SystemProgram.createAccount({
fromPubkey: wallet.publicKey,
newAccountPubkey: mint.publicKey,
space: MINT_SIZE,
lamports: rentExemptionLamports,
programId: TOKEN_2022_PROGRAM_ID
});

Toinen käsky kutsuu Token Extensions Programin createInitializeMint2Instruction -käskyä mint-tilin alustamiseksi seuraavilla tiedoilla:

  • 2 desimaalia
  • Lompakko sekä mint-valtuutena että jäädytysvaltuutena
Initialize mint instruction
const initializeMintInstruction = createInitializeMint2Instruction(
mint.publicKey,
2,
wallet.publicKey,
wallet.publicKey,
TOKEN_2022_PROGRAM_ID
);

Lisää molemmat käskyt yhteen transaktioon. Tämä varmistaa, että tilin luominen ja alustaminen tapahtuvat atomaarisesti. (Joko molemmat käskyt onnistuvat tai kumpikaan ei onnistu.)

Tämä lähestymistapa on yleinen monimutkaisia Solana-transaktioita rakennettaessa, sillä se takaa, että kaikki käskyt suoritetaan yhdessä.

Transaction
const transaction = new Transaction().add(
createAccountInstruction,
initializeMintInstruction
);

Allekirjoita ja lähetä transaktio. Kaksi allekirjoitusta vaaditaan:

  • Lompakko-tili allekirjoittaa maksajana transaktiomaksuille ja tilin luomiselle
  • Mint-tili allekirjoittaa valtuuttaakseen osoitteensa käytön uudelle tilille
Send transaction
const transactionSignature = await sendAndConfirmTransaction(
connection,
transaction,
[
wallet,
mint
]
);

Palautettua transaktion allekirjoitusta voidaan käyttää transaktion tarkasteluun Solana Explorerissa.

Tokenin luominen vaatii sekä @solana/web3.js- että @solana/spl-token -kirjastojen käyttöä. Alla olevan esimerkin koodi:

  • Luo yhteyden
  • Luo keypair transaktion maksamiseen
  • Pyydä airdrop keypair-parin rahoittamiseen
Connection & wallet setup
const connection = new Connection("http://localhost:8899", "confirmed");
const wallet = new Keypair();
const signature = await connection.requestAirdrop(
wallet.publicKey,
LAMPORTS_PER_SOL
);
await connection.confirmTransaction(signature, "confirmed");

Luo keypair mint-tilille. Julkista avainta käytetään mint-tilin osoitteena.

Mint keypair
const mint = new Keypair();

Laske mint-tilille vaadittavien lamport-yksiköiden vähimmäismäärä. getMinimumBalanceForRentExemptMint -funktio laskee, kuinka monta lamportia on varattava mint-tilin datalle.

Rent exemption
const rentExemptionLamports =
await getMinimumBalanceForRentExemptMint(connection);

Ensimmäinen käsky kutsuu System Programin createAccount -käskyä seuraavasti:

  1. Varaa tarvittava määrä tavuja mint-datan tallentamiseen.
  2. Siirrä lamportteja lompakosta uuden tilin rahoittamiseksi.
  3. Määritä tilin omistajuus Token Extensions -ohjelmalle.
Create account instruction
const createAccountInstruction = SystemProgram.createAccount({
fromPubkey: wallet.publicKey,
newAccountPubkey: mint.publicKey,
space: MINT_SIZE,
lamports: rentExemptionLamports,
programId: TOKEN_2022_PROGRAM_ID
});

Toinen käsky kutsuu Token Extensions Programin createInitializeMint2Instruction -käskyä mint-tilin alustamiseksi seuraavilla tiedoilla:

  • 2 desimaalia
  • Lompakko sekä mint-valtuutena että jäädytysvaltuutena
Initialize mint instruction
const initializeMintInstruction = createInitializeMint2Instruction(
mint.publicKey,
2,
wallet.publicKey,
wallet.publicKey,
TOKEN_2022_PROGRAM_ID
);

Lisää molemmat käskyt yhteen transaktioon. Tämä varmistaa, että tilin luominen ja alustaminen tapahtuvat atomaarisesti. (Joko molemmat käskyt onnistuvat tai kumpikaan ei onnistu.)

Tämä lähestymistapa on yleinen monimutkaisia Solana-transaktioita rakennettaessa, sillä se takaa, että kaikki käskyt suoritetaan yhdessä.

Transaction
const transaction = new Transaction().add(
createAccountInstruction,
initializeMintInstruction
);

Allekirjoita ja lähetä transaktio. Kaksi allekirjoitusta vaaditaan:

  • Lompakko-tili allekirjoittaa maksajana transaktiomaksuille ja tilin luomiselle
  • Mint-tili allekirjoittaa valtuuttaakseen osoitteensa käytön uudelle tilille
Send transaction
const transactionSignature = await sendAndConfirmTransaction(
connection,
transaction,
[
wallet,
mint
]
);

Palautettua transaktion allekirjoitusta voidaan käyttää transaktion tarkasteluun Solana Explorerissa.

Create mint account
import {
Connection,
Keypair,
SystemProgram,
Transaction,
sendAndConfirmTransaction,
LAMPORTS_PER_SOL
} from "@solana/web3.js";
import {
MINT_SIZE,
TOKEN_2022_PROGRAM_ID,
createInitializeMint2Instruction,
getMinimumBalanceForRentExemptMint,
getMint
} from "@solana/spl-token";
const connection = new Connection("http://localhost:8899", "confirmed");
const wallet = new Keypair();
const signature = await connection.requestAirdrop(
wallet.publicKey,
LAMPORTS_PER_SOL
);
await connection.confirmTransaction(signature, "confirmed");

Is this page helpful?

Sisällysluettelo

Muokkaa sivua

Hallinnoi

© 2026 Solana Foundation.
Kaikki oikeudet pidätetään.
Yhdistä