0

如果黑客可以调用或调用某些程序功能,我如何在 Solana Anchor 中进行测试?

是否通过更改签名者数组中的第一个元素:

await program.rpc.initializeProgram(
 arg1, arg2, ... {
 accounts: {...}
 signers: [keypair1, keypair2, ... keypairN],
)

但是在某些教程案例中,这个签名者数组被省略了......我可以在 Anchor 的哪里设置用于签署交易的调用者的密钥对?

请参阅https://project-serum.github.io/anchor/tutorials/tutorial-1中的示例锚代码

关键词:智能合约,安全测试

4

1 回答 1

2

对于您的锚点测试,它将使用 provider.wallet 作为付款人,因此会自动使用 provider.wallet 作为签名者。

您还可以通过签名者数组字段将签名者添加到您的 javascript 调用中,以防您的程序要求他们成为签名者。

教程 1 在这里不是一个现实的例子,因为任何人都可以进来修改帐户。

默认情况下,锚测试使用 provider.wallet 作为交易的付款人和签名人。如果你想使用另一个钱包,你必须创建另一个锚程序实例,按照下面的函数。

import * as anchor from '@project-serum/anchor';
import { provider, program } from '../config';

export function programPaidBy(payer: anchor.web3.Keypair): anchor.Program {
  const newProvider = new anchor.Provider(provider.connection, new anchor.Wallet(payer), {});

  return new anchor.Program(program.idl as anchor.Idl, program.programId, newProvider)
}
于 2021-08-13T05:52:07.063 回答