本文介绍了智能合同将ERC20令牌从一个地址发送到另一个地址的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我正在尝试实现一个可靠的智能契约,该契约将部署的令牌从地址A发送到地址B。
地址A-应该是调用契约函数的当前用户。地址B-应为外部的自定义钱包地址。
import "https://github.com/OpenZeppelin/openzeppelin-contracts/blob/master/contracts/token/ERC20/IERC20.sol";
contract TokenTransfer {
IERC20 _token;
constructor(address token) public {
_token = IERC20(token);
}
function stake(address to, uint amount) public {
_token.approve(address(this), amount);
require(_token.allowance(msg.sender, address(this)) >= amount, "Token allowance too low");
bool sent = _token.transferFrom(msg.sender, to, amount);
require(sent, "Token transfer failed");
}
}
本次执行退回容差错误:代币津贴太低&qot;
我正在使用MetaMASK(注入的Web3)运行它。我希望MetaMask会使用我的令牌打开一个简单的转账窗口。
推荐答案
为了使用您合同中的transferFrom()
,代币持有者需要直接从他们的地址approve()
消费者(您的合同)。不是通过您的合同。
_token.approve(address(this), amount);
此代码段批准TokenTransfer
(address(this)
)使用TokenTransfer
(approve()
函数调用者)的标记,因为该函数是从TokenTransfer
的地址有效调用的。
这就是require()
条件失败的原因。令牌持有者(msg.sender
)尚未批准您(address(this)
)使用其令牌的合同。如果将条件替换为_token.allowance(address(this), address(this))
,则它将通过(请参阅上一段)。
这篇关于智能合同将ERC20令牌从一个地址发送到另一个地址的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!