Loading...
Loading...
Compare original and translation side by side
@aptos-labs/ts-sdk@aptos-labs/ts-sdkAccount.generate()Account.fromPrivateKey()process.env.PRIVATE_KEYaccount.accountAddressaptos.signAndSubmitTransaction({ signer: account, transaction })Account.generate()Account.fromPrivateKey()process.env.PRIVATE_KEYaccount.accountAddressaptos.signAndSubmitTransaction({ signer: account, transaction })Account.generate()AccountAccountaptos.account.*AccountAccount.fromPrivateKeyAccount.generate()AccountAccountaptos.account.*AccountAccount.fromPrivateKey| Type | Class | Use case |
|---|---|---|
| Ed25519 (legacy) | | Single Ed25519 key, legacy auth |
| SingleKey | | Ed25519 or Secp256k1, unified auth |
| MultiKey | | Multi-sig |
| Keyless | | Keyless (e.g. OIDC) |
| Federated Keyless | | Federated keyless |
| 类型 | 类 | 使用场景 |
|---|---|---|
| Ed25519(传统版) | | 单个Ed25519密钥,传统认证 |
| SingleKey | | Ed25519或Secp256k1,统一认证 |
| MultiKey | | 多签 |
| Keyless | | 无密钥(如OIDC) |
| Federated Keyless | | 联邦无密钥 |
import { Account, SigningSchemeInput } from "@aptos-labs/ts-sdk";
// Default: Ed25519 legacy
const ed25519Account = Account.generate();
// SingleKey (unified) with Ed25519
const singleKeyAccount = Account.generate({ scheme: SigningSchemeInput.Ed25519, legacy: false });
// SingleKey with Secp256k1
const secpAccount = Account.generate({ scheme: SigningSchemeInput.Secp256k1 });
// Access address and public key
const address = ed25519Account.accountAddress;
const pubKey = ed25519Account.publicKey;import { Account, SigningSchemeInput } from "@aptos-labs/ts-sdk";
// 默认:Ed25519传统版
const ed25519Account = Account.generate();
// 采用Ed25519的SingleKey(统一版)
const singleKeyAccount = Account.generate({ scheme: SigningSchemeInput.Ed25519, legacy: false });
// 采用Secp256k1的SingleKey
const secpAccount = Account.generate({ scheme: SigningSchemeInput.Secp256k1 });
// 获取地址和公钥
const address = ed25519Account.accountAddress;
const pubKey = ed25519Account.publicKey;import { Account, Ed25519PrivateKey, Secp256k1PrivateKey } from "@aptos-labs/ts-sdk";
// Ed25519 legacy (default)
const privateKeyHex = process.env.PRIVATE_KEY!; // e.g. "0x..." or AIP-80 prefixed
const privateKey = new Ed25519PrivateKey(privateKeyHex);
const account = Account.fromPrivateKey({ privateKey });
// Ed25519 SingleKey (unified)
const accountSingle = Account.fromPrivateKey({
privateKey: new Ed25519PrivateKey(privateKeyHex),
legacy: false,
});
// Secp256k1 (always SingleKey)
const secpKey = new Secp256k1PrivateKey(process.env.SECP_KEY!);
const accountSecp = Account.fromPrivateKey({ privateKey: secpKey });
// Optional: fixed address (e.g. after key rotation)
const accountWithAddr = Account.fromPrivateKey({
privateKey,
address: "0x...",
});import { Account, Ed25519PrivateKey, Secp256k1PrivateKey } from "@aptos-labs/ts-sdk";
// Ed25519传统版(默认)
const privateKeyHex = process.env.PRIVATE_KEY!; // 例如:"0x..." 或AIP-80前缀格式
const privateKey = new Ed25519PrivateKey(privateKeyHex);
const account = Account.fromPrivateKey({ privateKey });
// Ed25519 SingleKey(统一版)
const accountSingle = Account.fromPrivateKey({
privateKey: new Ed25519PrivateKey(privateKeyHex),
legacy: false,
});
// Secp256k1(始终为SingleKey)
const secpKey = new Secp256k1PrivateKey(process.env.SECP_KEY!);
const accountSecp = Account.fromPrivateKey({ privateKey: secpKey });
// 可选:固定地址(如密钥轮换后)
const accountWithAddr = Account.fromPrivateKey({
privateKey,
address: "0x...",
});import { Account } from "@aptos-labs/ts-sdk";
const mnemonic = "word1 word2 ... word12";
const path = "m/44'/637'/0'/0'/0'"; // Aptos BIP-44 path
// Ed25519 legacy
const acc = Account.fromDerivationPath({ mnemonic, path });
// Ed25519 SingleKey
const accSingle = Account.fromDerivationPath({ mnemonic, path, legacy: false });
// Secp256k1
const accSecp = Account.fromDerivationPath({
scheme: SigningSchemeInput.Secp256k1,
mnemonic,
path,
});import { Account } from "@aptos-labs/ts-sdk";
const mnemonic = "word1 word2 ... word12";
const path = "m/44'/637'/0'/0'/0'"; // Aptos BIP-44路径
// Ed25519传统版
const acc = Account.fromDerivationPath({ mnemonic, path });
// Ed25519 SingleKey
const accSingle = Account.fromDerivationPath({ mnemonic, path, legacy: false });
// Secp256k1
const accSecp = Account.fromDerivationPath({
scheme: SigningSchemeInput.Secp256k1,
mnemonic,
path,
});const authKey = Account.authKey({ publicKey: account.publicKey });
// Use authKey.derivedAddress() for address derivation; useful for multi-account lookupconst authKey = Account.authKey({ publicKey: account.publicKey });
// 使用authKey.derivedAddress()派生地址;适用于多账户查询import { Account, AccountUtils } from "@aptos-labs/ts-sdk";
const account = Account.generate();
// Serialize to hex (includes private key – treat as secret)
const hex = AccountUtils.toHexString(account);
// Deserialize back
const restored = AccountUtils.fromHex(hex);
// Typed deserialize
const edAccount = AccountUtils.ed25519AccountFromHex(hex);
const singleAccount = AccountUtils.singleKeyAccountFromHex(hex);
const multiAccount = AccountUtils.multiKeyAccountFromHex(hex);
const keylessAccount = AccountUtils.keylessAccountFromHex(hex);import { Account, AccountUtils } from "@aptos-labs/ts-sdk";
const account = Account.generate();
// 序列化为十六进制字符串(包含私钥——需视为机密信息)
const hex = AccountUtils.toHexString(account);
// 反序列化恢复账户
const restored = AccountUtils.fromHex(hex);
// 类型化反序列化
const edAccount = AccountUtils.ed25519AccountFromHex(hex);
const singleAccount = AccountUtils.singleKeyAccountFromHex(hex);
const multiAccount = AccountUtils.multiKeyAccountFromHex(hex);
const keylessAccount = AccountUtils.keylessAccountFromHex(hex);// Sign message (returns Signature)
const sig = account.sign(messageHex);
// Sign transaction (returns Signature; for submit use aptos.transaction.sign + submit)
const txSig = account.signTransaction(rawTransaction);
// With authenticator (used by SDK internally for submit)
const auth = account.signWithAuthenticator(messageHex);// 签名消息(返回Signature)
const sig = account.sign(messageHex);
// 签名交易(返回Signature;提交需使用aptos.transaction.sign + submit)
const txSig = account.signTransaction(rawTransaction);
// 带认证器的签名(SDK内部提交时使用)
const auth = account.signWithAuthenticator(messageHex);const ok = account.verifySignature({ message: messageHex, signature: sig });
// Async (if key type needs on-chain state)
const okAsync = await account.verifySignatureAsync({
aptosConfig: aptos.config,
message: messageHex,
signature: sig,
});const ok = account.verifySignature({ message: messageHex, signature: sig });
// 异步验证(若密钥类型需要链上状态)
const okAsync = await account.verifySignatureAsync({
aptosConfig: aptos.config,
message: messageHex,
signature: sig,
});// Returns list of accounts owned by this key on chain
const accounts = await aptos.deriveOwnedAccountsFromSigner({
signer: account,
});
// Prefer wallet or explicit address for production; this is for scripts/tooling// 返回该密钥在链上拥有的所有账户列表
const accounts = await aptos.deriveOwnedAccountsFromSigner({
signer: account,
});
// 生产环境优先使用钱包或显式地址;此方法仅适用于脚本/工具| Mistake | Correct approach |
|---|---|
Using | Use wallet adapter; generate only in server/script |
| Hardcoding private key | Load from |
Using | |
| Expecting account to exist on-chain after generate | Fund with faucet or transfer first |
| 错误做法 | 正确做法 |
|---|---|
在前端使用 | 使用钱包适配器;仅在服务器/脚本中生成账户 |
| 硬编码私钥 | 从 |
将 | |
| 认为生成Account后链上账户就已存在 | 需先通过水龙头或转账为其充值 |
src/account/Account.tssrc/account/Ed25519Account.tssrc/account/AccountUtils.tssrc/api/account.tssrc/account/Account.tssrc/account/Ed25519Account.tssrc/account/AccountUtils.tssrc/api/account.ts