Verkkoon kirjoittaminen

Edellisessä osiossa opit lukemaan tietoja Solana-verkosta. Nyt opit kirjoittamaan tietoja verkkoon. Solana-verkkoon kirjoittaminen tapahtuu lähettämällä transaktioita, 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-ajoympä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, mukaan lukien:

  1. SOL-tokenien siirtäminen tilien välillä
  2. Uuden tokenin luominen

SOL-tokenien siirtäminen

Alla oleva esimerkki siirtää SOL-tokeneita 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 omistamia. SOL-tokenien siirtämiseksi sinun täytyy kutsua 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ämistä ja tilitietojen hakemista varten.

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än ja vastaanottajan tileinä.

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

Lisää SOL lähettäjän tilille. Muilla verkoilla kuin pääverkolla 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 määrän lamports -yksiköitä.

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ä transaktioon useita ohjeita.

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

Allekirjoita ja lähetä transaktio verkkoon. Lähettäjän keypair vaaditaan allekirjoittajien taulukossa valtuuttamaan SOL:n siirto 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 Explorerissa.

Luo Connection transaktioiden lähettämistä ja tilitietojen hakemista varten.

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än ja vastaanottajan tileinä.

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

Lisää SOL lähettäjän tilille. Muilla verkoilla kuin pääverkolla 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 määrän lamports -yksiköitä.

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ä transaktioon useita ohjeita.

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

Allekirjoita ja lähetä transaktio verkkoon. Lähettäjän keypair vaaditaan allekirjoittajien taulukossa valtuuttamaan SOL:n siirto 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 Explorerissa.

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

Tokenin luominen

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

  1. Kutsu System Programia uuden tilin luomiseksi.
  2. Kutsu Token Extensions Programia kyseisen tilin alustamiseksi mint-tiliksi.
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 oleva esimerkkikoodi:

  • Luo yhteyden
  • Generoi keypair transaktion maksamiseksi
  • Pyytää airdropin keypair-avaimen rahoittamiseksi
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");

Generoi keypair mint-tiliä varten. Julkista avainta käytetään mint-tilin osoitteena.

Mint keypair
const mint = new Keypair();

Laske mint-tilille tarvittavien lamport-yksiköiden vähimmäismäärä. getMinimumBalanceForRentExemptMint -funktio laskee, kuinka monta lamport-yksikköä täytyy varata mint-tilin dataa varten.

Rent exemption
const rentExemptionLamports =
await getMinimumBalanceForRentExemptMint(connection);

Ensimmäinen ohje kutsuu System Program -ohjelman createAccount -ohjetta:

  1. Varaa tavujen määrä, joka tarvitaan mint-tietojen tallentamiseen.
  2. Siirrä lamportseja lompakosta uuden tilin rahoittamiseksi.
  3. Määritä omistajuus tilille Token Extensions program -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 ohje kutsuu Token Extensions Program -ohjelman createInitializeMint2Instruction -ohjetta mint-tilin alustamiseksi seuraavilla tiedoilla:

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

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

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

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

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

  • Lompakko -tili allekirjoittaa maksajana transaktiomaksuja ja tilin luomista varten
  • Mint -tili allekirjoittaa valtuuttaakseen osoitteensa käytön uutta tiliä varten
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 oleva esimerkkikoodi:

  • Luo yhteyden
  • Generoi keypair transaktion maksamiseksi
  • Pyytää airdropin keypair-avaimen rahoittamiseksi
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");

Generoi keypair mint-tiliä varten. Julkista avainta käytetään mint-tilin osoitteena.

Mint keypair
const mint = new Keypair();

Laske mint-tilille tarvittavien lamport-yksiköiden vähimmäismäärä. getMinimumBalanceForRentExemptMint -funktio laskee, kuinka monta lamport-yksikköä täytyy varata mint-tilin dataa varten.

Rent exemption
const rentExemptionLamports =
await getMinimumBalanceForRentExemptMint(connection);

Ensimmäinen ohje kutsuu System Program -ohjelman createAccount -ohjetta:

  1. Varaa tavujen määrä, joka tarvitaan mint-tietojen tallentamiseen.
  2. Siirrä lamportseja lompakosta uuden tilin rahoittamiseksi.
  3. Määritä omistajuus tilille Token Extensions program -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 ohje kutsuu Token Extensions Program -ohjelman createInitializeMint2Instruction -ohjetta mint-tilin alustamiseksi seuraavilla tiedoilla:

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

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

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

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

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

  • Lompakko -tili allekirjoittaa maksajana transaktiomaksuja ja tilin luomista varten
  • Mint -tili allekirjoittaa valtuuttaakseen osoitteensa käytön uutta tiliä varten
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

© 2025 Solana Foundation.
Kaikki oikeudet pidätetään.