我创建了一个基础合约。但是不知道提现功能。请帮帮我。谢谢大家 我尝试创建一个基本功能,但它不起作用
function withdraw() public {
msg.sender.transfer(address(this).balance);
}
答案 0 :(得分:1)
msg.sender.transfer(address(this).balance);
此行提取本机余额(如果您的合约在以太坊网络上,则为 ETH)。
要提取代币余额,您需要在代币合约上执行 transfer()
函数。因此,为了提取所有代币,您需要对所有代币合约执行 transfer()
函数。
您可以创建一个函数,根据您作为输入传递的代币合约地址提取任何 ERC-20 代币。
pragma solidity ^0.8;
interface IERC20 {
function transfer(address _to, uint256 _amount) external returns (bool);
}
contract MyContract {
function withdrawToken(address _tokenContract, uint256 _amount) external {
IERC20 tokenContract = IERC20(_tokenContract);
// transfer the token from address of this contract
// to address of the user (executing the withdrawToken() function)
tokenContract.transfer(msg.sender, _amount);
}
}
请注意此代码是不安全的 - 任何人都可以执行 withdrawToken()
函数。如果您想在生产中运行它,请添加某种形式的身份验证,例如 Ownable 模式。
不幸的是,由于代币标准(以及一般的以太坊网络)的设计方式,没有简单的方法可以“一次转移所有代币”,因为没有简单的方法来获得“非零代币余额”地址”。您在区块链浏览器中看到的(例如,一个地址包含代币 X、Y 和 Z)是无法在链上执行的聚合的结果。
答案 1 :(得分:1)
假设您的合约是 ERC20,EIP 20 中定义的 transfer
函数表示:
将 _value 数量的代币转移到地址 _to,并且必须触发 转移事件。该函数应该抛出如果消息调用者的 帐户余额中没有足够的代币可以消费。
注意 0 值的传输必须被视为正常传输,并且 触发 Transfer 事件。
function transfer(address _to, uint256 _value) 公开返回 (bool 成功)
当您调用 transfer
的实现时,您基本上是在更新调用者和接收者的余额。它们的余额通常保存在映射/查找表数据结构中。