首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >隐僵尸transferFrom函数

隐僵尸transferFrom函数
EN

Ethereum用户
提问于 2022-05-19 23:30:56
回答 1查看 62关注 0票数 1

如果函数transferFrom由_tokenId的所有者调用,但具有与msg.sender不同的_from参数,则会发生什么情况?msg.sender ()不是检查_from是否等于_from,所以我可以将任何地址传递给_from,并扰乱ownerZombieCount映射并发出错误的传输事件。

我没观察到什么吗?

代码语言:javascript
复制
pragma solidity >=0.5.0 <0.6.0;

import "./zombieattack.sol";
import "./erc721.sol";

contract ZombieOwnership is ZombieAttack, ERC721 {

  mapping (uint => address) zombieApprovals;

  function balanceOf(address _owner) external view returns (uint256) {
    return ownerZombieCount[_owner];
  }

  function ownerOf(uint256 _tokenId) external view returns (address) {
    return zombieToOwner[_tokenId];
  }

  function _transfer(address _from, address _to, uint256 _tokenId) private {
    ownerZombieCount[_to]++;
    ownerZombieCount[_from]--;
    zombieToOwner[_tokenId] = _to;
    emit Transfer(_from, _to, _tokenId);
  }

  function transferFrom(address _from, address _to, uint256 _tokenId) external payable {
    require (zombieToOwner[_tokenId] == msg.sender || zombieApprovals[_tokenId] == msg.sender);
    _transfer(_from, _to, _tokenId);
  }

  function approve(address _approved, uint256 _tokenId) external payable onlyOwnerOf(_tokenId) {
    zombieApprovals[_tokenId] = _approved;
    emit Approval(msg.sender, _approved, _tokenId);
  }
}

编辑:我刚刚检查了from 721索尔

https://github.com/OpenZeppelin/openzeppelin-contracts/blob/master/contracts/token/ERC721/ERC721.sol

还有require(ERC721.ownerOf(tokenId) == from, "ERC721: transfer from incorrect owner");检查,所以我想密码僵尸的实现仅仅是为了教育目的,并且缺乏安全性,并且有可能妥协。

EN

回答 1

Ethereum用户

发布于 2022-05-20 02:07:52

是的,本合同仅用于教育目的。

但是,如果msg.sender是tokenId的所有者,则可以使用require

代码语言:javascript
复制
require(ownerOf(tokenId) == from, "Transfer from incorrect owner");
票数 0
EN
页面原文内容由Ethereum提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://ethereum.stackexchange.com/questions/128588

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档