如何解决来自以太坊智能合约的交易
当我们有合同时,我们转移货币
签名是怎么做的???
比如我给合约发了 10 个以太币,合约分给了 5 个人
这笔交易是怎样的?我的私钥从哪里来签署所有 5 笔交易?
解决方法
我向合约发送了 10 个以太币,合约被 5 个人瓜分
所以可能是这样的:
pragma solidity ^0.8;
contract MyContract {
function redistribute(address[5] memory otherPeople) external payable {
for(uint i = 0; i < 5; i++) {
payable(otherPeople[i]).transfer(msg.value / 5);
}
}
}
您向合约发送一笔交易(价值 10 ETH),执行 redistribute()
函数。
合约执行 5 次内部交易,有效地将 2 ETH 转移到每个 otherPeople
地址。
在这种情况下,您只需要使用“主”交易发送方的私钥,因为其他交易都是内部交易,由主交易包裹。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。