solidity经典案例----拍卖

Solidity经典合约案例----拍卖

1. 案例分析

在这里插入图片描述

2. 具体的代码

pragma solidity^0.6.1;

contract aution_demo{
    address payable public seller; //卖方
    address payable public buyer; //卖方
    uint256 public highAmount; //最高价
    address public admin; //管理员(平台方)
    string autionName; //拍卖物品
    bool isFinshed; //是否拍卖结束
    uint256 outTime; //拍卖截止时间
    mapping (address => uint256) pendingReturns; // 用于取回之前的出价

    //最高出价变动时调用事件
    event HighestBidIncreased(address _bidder,uint256 _amount);
    
    //拍卖结束时调用事件
    event End_Auction(address _winner,uint256 _amount);

    //创建一个拍卖对象,初始化卖方、拍卖物品、拍卖时间
    constructor(address payable _seller,string memory _name)public{
        seller=_seller;
        autionName=_name;
        admin=msg.sender; //管理员为部署该合约的账户
        outTime=now+120; //拍卖时长为2分钟
        isFinshed=false; 
        highAmount=0; 
    }
    // 拍卖
    function aution(uint256 amount)public payable{
        require(amount>highAmount,"amount must>highAmount");
        require(amount==msg.value,"amount must==msg.value");
        require(now<=outTime,"must not time out");
        require(!isFinshed,"must not finshed");
        pendingReturns[buyer]+=highAmount;
        //buyer.transfer(highAmount); //每一次买方出价前返回上笔金额
        buyer=msg.sender; //最终买方的账户地址为本次调用合约的账户地址
        highAmount=amount;
        emit HighestBidIncreased(msg.sender,msg.value);
    }

    // 未拍卖成功者取回之前的金额
    function withdraw() public returns (bool){
        uint256 amount = pendingReturns[msg.sender];
        if (amount > 0){
            // 需要提前设置为0,因为接收者可以在这个函数结束前再次调用它
            pendingReturns[msg.sender] = 0;
            if (!msg.sender.send(amount)){
                // 不需要throw,直接重置代币数量即可
                pendingReturns[msg.sender] = amount;
                return false;
            }
        }
        return true;
    }
    
    //结束拍卖
    function endAuction()public payable{
      require(msg.sender==admin,"only admin can do this");
      require(now>outTime,"time is not ok");
      require(!isFinshed,"must not finshed");
      isFinshed=true;
      emit End_Auction(buyer, highAmount);
      seller.transfer(highAmount*90/100); //支付90%的价格给卖方
    }
}

3.测试之前的账户地址准备

在这里插入图片描述

4. 管理员(平台方部署合约,并初始化)

在这里插入图片描述

5. 卖方调用智能合约

模拟3个卖家,调用aution()函数分别支付1000000wei,2000000wei,3000000wei

在这里插入图片描述

6. 管理员(平台方结束拍卖)

管理员通过调用endAuction()函数结束拍卖,并将抽取10%的利益,剩余的90%的钱发送给卖家。

在这里插入图片描述

7. 未拍卖成功的卖方取回金钱

拍卖结束后,卖方调用withdarw()函数取回金钱。
以下为整体的测试结果图(顺序为从左到右,从上到下)
在这里插入图片描述

  • 7
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

菜鸟逆袭之路

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

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

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

打赏作者

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

抵扣说明:

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

余额充值