智能合约如何处理多个用户和不同的存储?
How do Smart Contracts handle multiple users and different storage?
我正在以太坊区块链上试验智能合约。假设我有一个合同,比如 SimpleStorage.sol found in the Solidity documentation ,它有一个任何人都可以访问的存储状态。正如 link 所描述的那样,
anyone could just call set again with a different value and overwrite your number
这会导致问题,并且限制该功能对特定帐户的可访问性的解决方案不适合我的用例。在我的合同中,我希望每个帐户设置的数据以后可以由不同的预定帐户访问(想想这样一种关系,其中 A->B 所以 B 使用专门来自 A 的数据,而 x->y 其中 y 使用数据完全来自 x。在 y 可以使用 A 的数据的地方不存在重叠)。据我了解,问题有2种解决方案:
- 相互映射地址并跟踪这个单一智能合约中的所有数据。
- 拥有一个初始帐户可以访问的智能合约"template",并为每个新帐户生成一个单独的智能合约来简单地保存与模板交互的数据。
1 的问题发生在账户之间的关系变得更加复杂(映射单独的结构?)或者大量的人试图将他们的信息存储在合约中时。
2 的问题是冗余。我真的需要为每个试图访问主模板的人制作一个单独的 "contract" 吗?
如果我的问题含糊不清,我可以解释更多,但我主要是在寻找概念性的答案。我发现的大多数智能合约示例要么非常简单,要么过于复杂,并且没有提供具体的用例。
您可以在智能合约中创建访问列表。最简单的想法是设置所有者:
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 中并没有真正的冗余每个必须存储数据的用户的专用合同。
我正在以太坊区块链上试验智能合约。假设我有一个合同,比如 SimpleStorage.sol found in the Solidity documentation ,它有一个任何人都可以访问的存储状态。正如 link 所描述的那样,
anyone could just call set again with a different value and overwrite your number
这会导致问题,并且限制该功能对特定帐户的可访问性的解决方案不适合我的用例。在我的合同中,我希望每个帐户设置的数据以后可以由不同的预定帐户访问(想想这样一种关系,其中 A->B 所以 B 使用专门来自 A 的数据,而 x->y 其中 y 使用数据完全来自 x。在 y 可以使用 A 的数据的地方不存在重叠)。据我了解,问题有2种解决方案:
- 相互映射地址并跟踪这个单一智能合约中的所有数据。
- 拥有一个初始帐户可以访问的智能合约"template",并为每个新帐户生成一个单独的智能合约来简单地保存与模板交互的数据。
1 的问题发生在账户之间的关系变得更加复杂(映射单独的结构?)或者大量的人试图将他们的信息存储在合约中时。
2 的问题是冗余。我真的需要为每个试图访问主模板的人制作一个单独的 "contract" 吗?
如果我的问题含糊不清,我可以解释更多,但我主要是在寻找概念性的答案。我发现的大多数智能合约示例要么非常简单,要么过于复杂,并且没有提供具体的用例。
您可以在智能合约中创建访问列表。最简单的想法是设置所有者:
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 中并没有真正的冗余每个必须存储数据的用户的专用合同。