zoukankan      html  css  js  c++  java
  • 061孤荷凌寒从零开始学区块链第61天DAPP016

    孤荷凌寒自学第147天

    区块链061天DAPP016

    【主要内容】

    今天继续学习实战,做一个真正的依托于智能合约的DAPP。今天继续独立完善一个众筹的合约。共耗时44分钟。

    (此外整理作笔记花费了约82分钟)

    详细学习过程见文末学习过程屏幕录像。

    【成功测试了智能合约回退函数的写法】

    经过反复多次尝试,终于有一次按以下回退函数的写法成功:

    ```

    pragma solidity ^0.4.25;

     

    //20190901最后一次发布成功的https://ropsten.etherscan.io/tx/0x332d170aa7afc5e0ca269957df9bc77e233fda67f4d17cde4cf9cbdf97e9b535

    //limit: 93364

    //value 10

     

    contract ZongChouCeshi{

        address owner; //此变量记录下合约部署者(拥有者)的地址

        uint goal; //要众筹的目标金额(当然这儿指的是eth)

        uint endtime; //是指此众筹的时长(是一个无符号整数,单位是秒),如果在从部署合约之日加上此天数后的日期期限内达到目的金额,则说明众筹目标达到,合约部署者可以取走所有众筹金额,否则就由参与众筹者自己退回自己那份钱。

        uint total=0; //这是实际众筹到的金额

        uint giftcount=0; //记录下有多少节点参与了,不知道怎么检查去重。对映射类型的变量了解不够

        address[] alladd=new address[](1); //这儿必须写上(1),不然报错如下:

        //Type function (uint256) returns (address[] memory) is not implicitly convertible to expected type address[] storage ref.

        mapping(address=>uint) gift;

        constructor() public{

            owner = msg.sender;

            goal = 50000000;

            endtime = now + 100800;

            //变量 now 将返回当前的unix时间戳(自1970年1月1日以来经过的秒数)。

            //来自博文:https://www.jianshu.com/p/4b8e943ce7f2

        }

     

        //直接使用回退函数来接收

        //调用合约的用户节点参与众筹,向合约地址转账一定数量的eth

        //这个函数给我的疑惑是,没有体现(像自己发的代币合约中的那样)登记eth余额双方的变化

        //初步理解是:

        //因为使用的代币正是eth本身,因此当调用此合约的节点在进行转移eth操作时,eth网络本身已经记录并广播完成了eth代币余额在两个节点之间的移动

        function () public payable{

            require(now < endtime,"");

            require(total < goal,"");

            require(msg.data.length == 0,""); //只接收没有数据传输的纯发送代币的事务调用,此语句检查数据部分是否 为空

            require(msg.value > 0,"");

            //assert(gift[msg.sender]>=0);

            //每个节点至少捐赠大于0个eth

            //if(gift[msg.sender]==0){ //判断此节点是否之前已经捐过款项

            //    giftcount+=1; //统计已经有多少节点参与捐助,而且要去重节点。

            //    alladd[alladd.length++] = msg.sender; //在地址数组中记录下当前地址,

            //    alladd.push(msg.sender);

            //}

            uint a = msg.value;

            gift[msg.sender] += a;

            total += a;

     

        }

     

        //如果众筹成功,即在规定的时间内,众筹了大于等于goal预设数量金额的eth,那么证明成功,则合约的部署节点可以取走这笔eth到合约部署节点的账户上。

        function draw() public{

            //首先要保证本次调用合约及调用本函数的节点是合约部署者。

            //确实判断众筹目标已经达成。

            require(msg.sender == owner);

            require(total >= goal);

            require(now>endtime);

            owner.transfer(address(this).balance); //执行转账,从合约地址转到部署合约的节点地址

            //eth代币的转账书写方法是非常简洁的:

            //接收转账金额的节点.transfer(转账金额)

            //这样指定【转账金额】的eth就会转移给【接收转账金额的节点】

        }

       

        //如果众筹失败,则参与众筹的节点可以调用合约的本方法来取回自己的捐赠

        function withdraw() public{

            //只有当众筹时间已过,本函数才可被调用

            //确定判断众筹已经失败。

            require(total < goal);

            require(now>endtime);

            uint amount = gift[msg.sender]; //获取当前调用合约的节点之前总共捐赠的eth的总金额

            total -= amount; //从总金额中减少当前调用合约节点准备取回的eth金额

            gift[msg.sender] = 0; //在gift表中,登记当前调用合约节点新的捐赠金额为0

            address(msg.sender).transfer(amount); //当前调用合约的节点之前总共捐赠的eth的总金额转移回当前调用合约的节点           

     

        }

     

        //查询当前已筹集资金总额:

        function getTotal() public constant returns(uint){

            return total;

        }

     

        //查询当前合约节点自己的余额(这实际上就是total的数量,不过额外增加一个函数来查询)

        function getContractBalance() public constant returns(uint){

            return address(this).balance;

        }

     

        //查询截止日期,返回的是结束 日期那天的时间戳的一个无符号整数(32位的),需要调用此合约函数的调用方自己用前端 语言来进行处理

        function getEndTimeStamp() public constant returns(uint){

            return endtime;

        }

     

        //查询当前调用合约的节点已经总共捐助了多少eth

        function getGiftBalance() public constant returns(uint){

            return gift[msg.sender];

        }

     

        //查询已经有多少人捐助

        function getGiftCount() public constant returns(uint){

            return giftcount;

        }

     

        //查询指定的节点已经总共捐助了多少eth

        function getGiftBalanceFrom(address a) public constant returns(uint){

            return gift[a];

        }

     

        //返回已参与节点的数组

        function getalladdress() public constant returns(address[]){

            return alladd;

        }

     

    }

     

    ```

    此合约发布后的地址是:

    0x1a7923e7fe36e4ea312855989e642093c66cd2ab

    唯一成功的一次是这样的记录:

    from

    0x5227C3EF48B5A1bcF784593e46D9579D26a3b592

    to

    0x1a7923e7FE36e4eA312855989E642093c66CD2aB

    Transaction

    数量

    0.001ETH

    Gas Limit (Units)

    93364

    Gas Used (Units)

    62243

    Gas Price (GWEI)

    10

    总量

    0.001622ETH

    不过接下来后续测试又无一成功。

    github: https://github.com/lhghroom/Self-learning-blockchain-from-scratch

    原文地址:https://www.941xue.com/content.aspx?id=1604  

    【欢迎大家加入[就是要学]社群】

    如今,这个世界的变化与科技的发展就像一个机器猛兽,它跑得越来越快,跑得越来越快,在我们身后追赶着我们。

    很多人很早就放弃了成长,也就放弃了继续奔跑,多数人保持终身不变的样子,原地不动,成为那猛兽的肚中餐——当然那也不错,在猛兽的逼迫下,机械的重复着自我感觉还良好地稳定工作与生活——而且多半感觉不到这有什么不正常的地方,因为在猛兽肚子里的是大多数人,就好像大多数人都在一个大坑里,也就感觉不出来这是一个大坑了,反而坑外的世界显得有些不大正常。

    为什么我们不要做坑里的大多数人?

    因为真正的人生,应当有百万种可能 ;因为真正的一生可以有好多辈子组成,每一辈子都可以做自己喜欢的事情;因为真正的人生,应当有无数种可以选择的权利,而不是总觉得自己别无选择。因为我们要成为一九法则中为数不多的那个一;因为我们要成为自己人生的导演而不是被迫成为别人安排的戏目中的演员。

    【请注意】

    就是要学社群并不会告诉你怎样一夜暴富!也不会告诉你怎样不经努力就实现梦想!

    【请注意】

    就是要学社群并没有任何可以应付未来一切变化的独门绝技,也没有值得吹嘘的所谓价值连城的成功学方法论!

    【请注意】

    社群只会互相帮助,让每个人都看清自己在哪儿,自己是怎样的,重新看见心中的梦想,唤醒各自内心中的那个英雄,然后勇往直前,成为自己想要成为的样子!

    期待与你并肩奔赴未来!

    www.941xue.com

    QQ群:646854445 (【就是要学】终身成长)

    【同步语音笔记】

    https://www.ximalaya.com/keji/19103006/336996141

    【学习过程屏幕录屏】

    https://www.bilibili.com/video/BV1i5411Y7sL/

    欢迎大家添加我为好友: QQ: 578652607
  • 相关阅读:
    数据库添加字段的默认值
    Map中存放数组
    JSON字符串转换为Map
    java中Object转换成int或String类型方法
    Max_connect_errors – MySQL性能参数详解
    查看已经安装的软件
    eclipse远程调试tomcat
    eclipse控制台不限制显示的行数
    栈和堆(Stack && Heap)
    一道题引发的self和super
  • 原文地址:https://www.cnblogs.com/lhghroom/p/13741668.html
Copyright © 2011-2022 走看看