我正在为NFT令牌使用ERC721实现。
我正在测试ERC721中的传输功能。
`transferFrom(address _from, address _to, uint256 _tokenId)`
`safeTransferFrom(address _from, address _to, uint256 _tokenId)`
`safeTransferFrom(address _from, address _to, uint256 _tokenId, bytes data)`我尝试过以_to地址作为帐户地址的令牌传输场景。
我正在尝试使用_to地址作为契约地址来执行令牌传输场景。
我已经写了一个接收器合同来测试这个功能。
pragma solidity ^0.4.22;
import "./standard/ERC721TokenReceiver.sol";
contract ValidReceiver is ERC721TokenReceiver {
event LOGTokenFallBack(address from,bytes4 value);
function onERC721Received(address _operator, address _from, uint256 _tokenId, bytes _data) external returns(bytes4 value) {
emit LOGTokenFallBack(_from, bytes4(keccak256("onERC721Received(address,address,uint256,bytes)")));
return 0x150b7a02;
}
} 更新了safeTranferFrom功能如下:
function safeTransferFrom(address _from, address _to, uint256 _tokenId, bytes data) public {
transferFrom(_from, _to, _tokenId);
//Get size of "_to" address, if 0 it's a wallet
uint32 size;
assembly {
size := extcodesize(_to)
}
if(size > 0){
ERC721TokenReceiver receiver = ERC721TokenReceiver(_to);
require(receiver.onERC721Received(msg.sender,_from,_tokenId,data) == bytes4(keccak256("onERC721Received(address,address,uint256,bytes)")));
}似乎转移被恢复了。
我已经通过删除返回类型来更新ERC721TokenReceiver,如下所示。
function onERC721Received(address _operator, address _from, uint256 _tokenId, bytes _data) external ;并按以下方式更新ValidReceiver。
合约ValidReceiver是ERC721TokenReceiver {
event LOGTokenFallBack(address from,bytes4 value);
function onERC721Received(address _operator, address _from, uint256 _tokenId, bytes _data) external {
emit LOGTokenFallBack(_from, bytes4(keccak256("onERC721Received(address,address,uint256,bytes)")));
}
} 通过发出LOGTokenFallBack事件,这似乎是一个成功的传输。
在接收合同中,我曾尝试过多种方式进行退货类型的转让。
是否有人面对与刚才所提及的问题类似的问题?
任何帮助都是非常感谢的。
发布于 2019-08-05 07:43:05
尝试我们的官方方721实现。这里还有一个在我们的测试用例中描述的工作示例。还请参阅指向拟721接收机模拟的链接和指向safeTransferFrom实现的直接链接。
顺便说一句,使用0xcert框架可以使事情变得简单得多。它隐藏了复杂性,您根本不必编写稳健性,只需使用Javascript方法即可。
https://ethereum.stackexchange.com/questions/73533
复制相似问题