4

我正在以太坊区块链上试验智能合约。假设我有一个合同,类似于Solidity 文档中的SimpleStorage.sol ,它具有任何人都可以访问的存储状态。如链接所述,

任何人都可以使用不同的值再次调用 set 并覆盖您的号码

这会导致问题,并且将该功能的可访问性限制为特定帐户的解决方案不适合我的用例。在我的合同中,我希望每个帐户设置的数据以后可以由不同的预定帐户访问(考虑这样一种关系,其中人 A->B 所以 B 只使用来自 A 的数据,而 x->y 使用数据完全来自 x。在 y 可以使用 A 的数据的情况下不存在重叠)。据我了解,该问题有两种解决方案:

  1. 将地址相互映射并跟踪此单个智能合约中的所有数据。
  2. 拥有一个初始账户可以访问的智能合约“模板”,并为每个新账户生成一个单独的智能合约,以简单地保存与模板交互的数据。

当账户之间的关系变得更加复杂(映射单独的结构?)或大量人试图将他们的信息存储在合约中时,就会出现1的问题。

2的问题是冗余。我真的需要为每个试图访问主模板的人制作一份单独的“合同”吗?

如果我的问题含糊不清,我可以解释更多,但我主要是在寻找一个概念性的答案。我发现的大多数智能合约示例要么非常简单,要么过于复杂,并且没有提供具体的用例。

4

1 回答 1

2

您可以在智能合约中创建访问列表。最简单的想法是设置所有者:

contract example {

    // Define variable owner of the type address
    address owner;

    // this function is executed at initialization and sets the owner of the contract
    function example() {
        owner = msg.sender; 
    }

    function doSomething() {
        if (msg.sender == owner) {
            // only the owner can do something, like storage access
        }
    }
}

这个逻辑可以根据您的需要进行扩展,您可以创建包含允许的用户帐户列表的结构或数组,或者您可以创建一个允许动态添加和删除特权用户的逻辑。这完全取决于你。

如果您只希望每个用户都可以访问自己的数据,您可以将该数据存储在具有专用所有者帐户的结构中,如1中所述,或者,我建议每个用户创建自己的存储合同,这将是关于可访问性的最干净的方式。

主合约只需要维护一个外部合约的引用列表,所以如果你有一个主合约,它为每个必须存储数据的用户保存存储逻辑和专用合约,那么2中并没有真正的冗余。

于 2016-06-30T08:37:16.487 回答