【ERC20安全审计】——21、返回值未检查漏洞

文章前言

随着区块链技术的不断发展智能合约已经成为了区块链世界中不可或缺的重要组成部分,智能合约的安全问题一直备受关注,其中返回值未检查是一种常见的漏洞类型,本文将从实际案例入手介绍返回值未检查漏洞的危害和防范措施以帮助读者更好地理解智能合约安全问题

基础知识

Solidity中的<address>.transfer()、<address>.send()、<address>.gas().call.vale()()函数都可以用于向某一地址发送ether,其差别如下:

transfer转账

transfer函数是最常用的转账函数,它的作用是将合约中的以太币或代币转移到指定的地址,如果转账失败该函数将抛出异常并回滚所有更改,其语法如下:

function transfer(address payable recipient, uint256 amount) public returns (bool)

其中recipient是接收方的地址,amount是要转移的金额,函数返回值为bool类型,表示转账是否成功,需要注意的是transfer函数的gas消耗为2300 units且这个消耗是固定的,无论转移的金额是多少都不会变更,如果转移的金额超过了合约的余额,那么转账会失败并且所有更改都将被回滚,以下是一个示例代码

pragma solidity ^0.8.0;

contract TransferExample {
    function transferEther(address payable recipient, uint256 amount) public {
        require(address(this).balance >&#
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

FLy_鹏程万里

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值