📢 Gate廣場 #创作者活动第一期# 火熱開啓,助力 PUMP 公募上線!
Solana 爆火項目 Pump.Fun($PUMP)現已登入 Gate 平台開啓公開發售!
參與 Gate廣場創作者活動,釋放內容力量,贏取獎勵!
📅 活動時間:7月11日 18:00 - 7月15日 22:00(UTC+8)
🎁 活動總獎池:$500 USDT 等值代幣獎勵
✅ 活動一:創作廣場貼文,贏取優質內容獎勵
📅 活動時間:2025年7月12日 22:00 - 7月15日 22:00(UTC+8)
📌 參與方式:在 Gate 廣場發布與 PUMP 項目相關的原創貼文
內容不少於 100 字
必須帶上話題標籤: #创作者活动第一期# #PumpFun#
🏆 獎勵設置:
一等獎(1名):$100
二等獎(2名):$50
三等獎(10名):$10
📋 評選維度:Gate平台相關性、內容質量、互動量(點讚+評論)等綜合指標;參與認購的截圖的截圖、經驗分享優先;
✅ 活動二:發推同步傳播,贏傳播力獎勵
📌 參與方式:在 X(推特)上發布與 PUMP 項目相關內容
內容不少於 100 字
使用標籤: #PumpFun # Gate
發布後填寫登記表登記回鏈 👉 https://www.gate.com/questionnaire/6874
🏆 獎勵設置:傳播影響力前 10 名用戶,瓜分 $2
Solana Web3.js 2.x發布:模塊化設計提升性能和安全性
Solana Web3.js 2.x 版本:功能更強大,性能更優化
Solana Web3.js 作爲一個功能豐富的 JavaScript 庫,在今年 11 月正式推出了 2.x 版本。這個新版本相較於 1.x 版本有了較大的變化,本文將對其主要變化進行概括。
雖然 2.x 版本剛剛發布,使用量還不高,許多廣泛使用的庫也尚未切換,但了解這些變化對未來的遷移工作將有所幫助。
版本對比
1.x 版本使用起來較爲簡單,只有一個包:@solana/web3.js,所有功能都集中在其中。它基於類的設計,封裝了大量常用操作。例如,Connection 類就提供了幾十種方法,幾乎涵蓋了開發者所需的所有功能。
然而,這種設計也帶來了一些問題。盡管開發者實際使用的功能可能只佔很小一部分,但整個代碼庫都會被下載到用戶設備上,由於代碼量龐大,可能會導致一定的加載時間。
相比之下,2.x 版本將原有代碼庫拆分爲多個小型模塊,如 @solana/accounts、@solana/codecs、@solana/rpc、@solana/signers、@solana/transactions 等。同時,新版本放棄了基於類的實現,更多地採用單個函數的方式。這種設計有利於 JavaScript 代碼構建時的優化,未使用的代碼將被刪除,不會被下載到用戶設備上。官方文檔統計顯示,使用新版本的 DApp 通常能獲得 30% 的大小優化,如果只使用了少量功能,優化比例可能更高。
這種變化對 Solana 團隊的文檔編寫提出了新的挑戰,如何讓開發者快速找到所需功能成爲一個重要問題。不過,目前看來,各個包的命名具有良好的語義性,從名稱就能大致了解它們的用途,這在一定程度上降低了開發者遷移的難度。
由於新版本剛發布不久,許多項目還未進行遷移。Solana Cookbook 上關於 2.x 版本的示例也較少。此外,新版本傾向於使用運行時內置功能(如生成密鑰對),但文檔中對這些部分的描述不足,可能會讓開發者感到困惑。
2.x 版本的另一個重要特點是零依賴。這一點對許多用戶來說可能不太重要,但從今年 12 月初發生在 @solana/web3.js 1.95.5 和 1.95.6 版本上的供應鏈攻擊來看,更多的外部輸入和依賴會大大增加安全事件發生的可能性。隨着 2.x 版本的發布,Web3.js 的開發團隊決定更多地使用本機功能,取消外部依賴和 Polyfills 的引入。雖然未來可能會有變化,但目前 2.x 版本已經消除了所有外部依賴。
重要變更點
連接
在 1.x 版本中,Connection 提供了大量方法。但其主要功能還是通過配置 RPC 請求地址創建一個請求發送器,然後通過它發送各種請求。
2.x 版本採用了更加函數式的方式實現:
javascript import { createSolanaRpc } from "@solana/web3.js";
const rpc = createSolanaRpc("");
當調用 sendAndConfirmTransaction 發送交易時,會自動發起 HTTPS 請求,並建立 WSS 連接訂閱交易狀態,在交易被確認後返回交易哈希。
密鑰對
公鑰和私鑰相關的部分也有重大變化。1.x 版本中常用的 Keypair 和 PublicKey 兩個類不再存在,被一些函數替代。
例如,現在可以使用 await generateKeyPair() 生成密鑰對,而之前是直接通過 Keypair.generate() 生成。
值得注意的是,新的 generateKeyPair 返回 Promise,而不是直接返回密鑰對。這是因爲新實現盡可能利用了 JavaScript 的 Web Crypto API,使用了原生的 Ed25519 實現。Web Crypto API 的許多方法都是異步的。不過,這種變化並非不可接受,在 2024 年即將結束的今天,JavaScript 開發者已經非常熟悉 Promise 了。
發送交易
1.x 版本中的 Transaction 和 VersionedTransaction 兩個類在 2.x 版本中不再存在。
舊版本中提供的 System Program 相關方法也不再存在,所以 SystemProgram 類上的靜態方法都需要從其他地方引入。
例如,transfer 指令現在需要調用 @solana-program/system 中的 getTransferSolInstruction 函數。
由於不再提供類,Web3.js 提供了函數式編程中常用的 pipe 形式。以下是使用 pipe 函數實現原本 1.x 的轉帳功能的示例:
javascript import { pipe } from "@solana/web3.js"; import { getTransferSolInstruction } from "@solana-program/system";
const transaction = pipe( createTransaction({ version: 0 }), addInstruction( getTransferSolInstruction({ fromPublicKey, toPublicKey, lamports, }) ) );
可以看出,交易不再通過 Connection 發起,而是通過我們定義的 RPC Provider 生成一個特有的函數,然後調用該函數來發起交易。相對 1.x 版本,代碼量有所增加,但可定制性更強了。
交易通過 HTTPS RPC 發起,然後通過訂閱 WSS RPC 來確認交易結果。可以感受到新的方式非常依賴 WSS,相信未來 WSS 的應用將會越來越廣泛,這也確實對 RPC 供應商的服務穩定性提出了更高的要求。
React
值得一提的是,@solana/web3.js 項目中還包含了一個名爲 @solana/react 的庫,提供了一些 React Hook,內置了諸如 signIn 等功能。
總結
@solana/web3.js 2.x 版本的發布充分體現了 Solana 團隊對不斷發展和改進的承諾。它爲開發人員提供了一個高效、靈活、可定制的與 Solana 網路交互的方式,有助於推動該平台的採用和發展。