有什么问题吗?
pragma solidity ^0.6.0;
import "https://github.com/OpenZeppelin/openzeppelin-contracts/blob/master/contracts/proxy/Initializable.sol";
import "https://github.com/OpenZeppelin/openzeppelin-contracts/blob/master/contracts/token/ERC20/IERC20.sol";
import "https://github.com/OpenZeppelin/openzeppelin-contracts/blob/master/contracts/math/SafeMath.sol";
contract Test {
using SafeMath for uint256;
IERC20 public toke;
function f(IERC20 _token)public{
toke=_token;
}
function y(address u,uint256 i)public{
toke.approve(msg.sender,i);
toke.transferFrom(msg.sender,u,i);
}
}处理GLDToken.transferFrom错误: VM错误:还原。还原事务已恢复到初始状态。合同提供的理由:"ERC20:转移金额超过备抵额“。调试事务以获得更多信息。
发布于 2020-10-16 07:43:42
使用toke.approve(msg.sender, i),您将批准msg.sender从您的合同中转移令牌。
使用toke.transferFrom(msg.sender, u, i),您将尝试从msg.sender传输令牌。
总之,您应该使用approve(yourContractAddress, i)帐户执行msg.sender。
附带注意:您不希望您的代码工作,因为如果这样做了,那么就意味着任何人都可以从其他任何人那里转移令牌,而整个系统作为一个金融模型将毫无价值。
https://ethereum.stackexchange.com/questions/89393
复制相似问题