1. ERC20标准

https://github.com/ethereum/EIPs/blob/master/EIPS/eip-20.md

pragma solidity ^0.4.;

//定义接口
contract ERC20Interface{
string public name;
string public symbol;
uint8 public decimals;
uint256 public totalSupply; /* function balanceOf(address _owner) view returns (uint256 balance); */
function transfer(address _to, uint256 _value) returns (bool success);
function transferFrom(address _from, address _to, uint256 _value) returns (bool success);
function approve(address _spender, uint256 _value) returns (bool success);
function allowance(address _owner, address _spender) view returns (uint256 remaining); event Transfer(address indexed _from, address indexed _to, uint256 _value);
event Approval(address indexed _owner, address indexed _spender, uint256 _value); } contract ERC20 is ERC20Interface{
mapping(address => uint256) public balanceOf;
//委托,允许他人操作的金额数
mapping(address => mapping(address => uint256)) allowed; //构造方法
constructor() public {
name = "MyToken";
symbol = "weixuexi";
decimals = ;
totalSupply = ;
balanceOf[msg.sender] = totalSupply;
} /* function balanceOf(address _owner) view returns (uint256 balance){
return balanceOf[_owner];
} */
function transfer(address _to, uint256 _value) returns (bool success){
require(_to != address());
require(balanceOf[msg.sender] >= _value);
require(balanceOf[_to] + _value > balanceOf[_to]); balanceOf[msg.sender] -= _value;
balanceOf[_to] += _value;
emit Transfer(msg.sender, _to, _value);
}
function transferFrom(address _from, address _to, uint256 _value) returns (bool success){ require(_from != address());
require(_to != address());
require(balanceOf[_from] >= _value);
require(allowed[msg.sender][_from] >= _value); //当前合约能操作_from的钱数要大于_value
require(balanceOf[_to] + _value > balanceOf[_to]); balanceOf[_from] -= _value;
balanceOf[_to] += _value;
emit Transfer(_from, _to, _value); success = true;
}
function approve(address _spender, uint256 _value) returns (bool success){
//当前账户允许—_spender操作的金额数
allowed[msg.sender][_spender] = _value;
emit Approval(msg.sender, _spender, _value);
success = true;
}
function allowance(address _owner, address _spender) view returns (uint256 remaining){
return allowed[_owner][_spender];
}
}

2.DAPP去中心化应用开发【web项目】

  web3.js

  solidity

  truffle  https://truffleframework.com/docs/truffle/getting-started/installation

  ganache

开发流程:

  • 新建项目【初始化】
  • 编写合约
  • 合约编译、部署、测试
  • 与合约交互

安装truffle:

npm install -g truffle
查看版本:truffle.cmd version

创建项目:

  下载基本文件:

      cd pet-shop

    truffle init  【安装项目】

  下载pet-shop包文件:

    cd pet-shop

    truffle unbox pet-shop

编写智能合约:Adoption.sol

pragma solidity ^0.4.;

contract Adoption {
address[] public adoptors; //领养这地址 function adopt(uint petId) public returns(uint) {
adoptors[petId] = msg.sender;
return petId;
} function getAdoptors() public view returns (address[]) {
return adoptors;
}
}

编译: truffle.cmd compile【方式一,结合使用ganache】

  truffle develop 【方式二,truffle集成了testrpc】; compile;

部署合约:migrate

  部署合约脚本: 1_migration.js   改文件用于监听合约文件的动向,是否更新,变化

var MyContract = artifacts.require("MyContract");

module.exports = function(deployer) {
// deployment steps
deployer.deploy(MyContract);
};

  truffle.js:

module.exports = {
// See <http://truffleframework.com/docs/advanced/configuration>
// to customize your Truffle configuration!
networks: {
development: {
host: "127.0.0.1", //主机
port: 7545, //端口,和ganache对应
network_id: "*" // Match any network id
}
}
};

  部署合约:[truffle] migrate

输出结果:Adoption.json  [编译出的文件做出了更新]

这时,ganache中可以发现,已经出来了4个区块:

还有交易信息:

获取合约实例,调用函数:

pragma solidity ^0.4.;

contract Hello {
//如果使用pure修饰,可以通过合约对象直接调用,否则需要使用call方法调用
function test() pure public returns (string) {
return "hello world";
}
}

Hello.sol

/migrations/3_deploy_hello.js

var Hello = artifacts.require("./Hello.sol");

module.exports = function(deployer) {
deployer.deploy(Hello);
};

  使用web3获取合约实例: 

>truffle: let contract;   //声明contract变量

    contract = Hello.deployed().then(instance => contract=instance)             //Hello 是上面迁移文件的合约实例

pragma solidity ^0.4.;

import "truffle/Assert.sol";
import "truffle/DeployedAddresses.sol";
import "../contracts/Adoption.sol"; contract TestAdoption {
Adoption adoption = Adoption(DeployedAddresses.Adoption()); function testUserCatAdoptPet() public {
uint returnId = adoption.adopt(); uint expect = ;
Assert.equal(returnId, expect, "Adoption of pet Id 8 should be recorded");
} function testGetAdoptorAddByPetId() public {
address expect = this;
address adoptor = adoption.adoptors();
Assert.equal(expect, adoptor, "get adopt by pet id");
}
}

  注意:修改完合约文件后,重新编译【compile】后,重新部署命令【migrate --reset】

  调用合约方法:contract.test();

  使用断言测试:Assert

同时会多出很多新的区块和交易

3.web3.js api的使用

官网

  进入truffle开发环境:truffle.cmd develop

  获取账户余额:web3.eth.getBalace("").toString();

truffle(develop)> web3.eth.getBalance("0x627306090abab3a6e1400e9345bc60c78a8bef57").toString()
   ''

  获取所有账户:web3.eth.accounts;

truffle(develop)> null [
'0x627306090abab3a6e1400e9345bc60c78a8bef57',
'0xf17f52151ebef6c7334fad080c5704d77216b732',
'0xc5fdf4076b8f3a5357c5e395ab970b5b54098fef',
'0x821aea9a577a9b44299b9c15c88cf3087f3b5544',
'0x0d1d4e623d10f9fba5db95830f7d3839406c6af2',
'0x2932b7a2355d6fecc4b5c0b6bd44cc31df247a2e',
'0x2191ef87e392377ec08e7c08eb105ef5448eced5',
'0x0f4f2ac550a1b4e2280d04c21cea7ebd822934b5',
'0x6330a553fc93768f612722bb8c2ec78ac90b3bbc',
'0x5aeda56215b167893e80b4fe645ba6d5bab767de' ]

  获取当前账号:【数组中的第0个账号】

truffle(develop)> web3.eth.coinbase;
  '0x627306090abab3a6e1400e9345bc60c78a8bef57'

  web3.fromWei(num, 单位);

truffle(develop)> web3.fromWei(, 'ether')
'0.000000000000000005'

  web3.toWei(num,单位)

  默认的区块:

truffle(develop)> web3.eth.defaultBlock
  'latest'

  交易:

truffle(develop)> web3.eth.sendTransaction({from:account1, to:account2, value:})
  '0xb5065a9a03d75f08d7e704d352d08de5c8c4f8f19cc654cb1261d254f6194d90'
truffle(develop)> web3.eth.getBalance(account1)
  BigNumber { s: , e: , c: [ , ] }
truffle(develop)> web3.eth.getBalance(account2)
  BigNumber { s: , e: , c: [ ] }
truffle(develop)> web3.eth.getBalance(account1).toString()
  ''
truffle(develop)> web3.eth.getBalance(account2).toString()
  ''
truffle(develop)> web3.fromWei(web3.eth.getBalance(account1).toString(), 'ether')
  '99.899999999999979'
truffle(develop)> web3.fromWei(web3.eth.getBalance(account2).toString(), 'ether')
  '100.1'
truffle(develop)> web3.fromWei(web3.eth.getBalance(web3.eth.accounts[]).toString(), 'ether')
  ''

  

4. 代币合约的概念

pragma solidity ^0.4.;

contract EncryptedToken {
uint256 INITAL_SUPPLY = ;
mapping(address => uint) public balanceOf;
constructor() {
balanceOf[msg.sender] = INITAL_SUPPLY;
}
function transfer(address _to, uint256 _value) public {
require(_to != address());
require(balanceOf[msg.sender] >= _value);
require(balanceOf[_to] + _value > balanceOf[_to]); balanceOf[msg.sender] -= _value;
balanceOf[_to] += _value;
}
}

EncryptedToken.sol

var EncryptedToken = artifacts.require("./EncryptedToken.sol");

module.exports = function(deployer) {
deployer.deploy(EncryptedToken);
};

1_deploy_encryptedToken.js

部署:

  truffle.cmd develop

  compile

  migate

  let c;

  EncryptedToken.deployed().then(inc => c=inc);

  c.balanceOf("0x627306090abab3a6e1400e9345bc60c78a8bef57") ;  ->10000   //钱包地址

默认部署到第一个测试钱包中:

转账:c.transfer("0xf17f52151ebef6c7334fad080c5704d77216b732",1000)

truffle(develop)> c.balanceOf("0x627306090abab3a6e1400e9345bc60c78a8bef57")
       BigNumber { s: 1, e: 3, c: [ 9000 ] }

5. web端

4.1 使用npm管理项目

  npm init

  安装web server:npm install lite-server

配置文件:bs-config.json

{
"server" : {
"baseDir":["./src", "./build/contracts"]
}
}

package.json:

启动服务:npm run dev

合约实战,代币合约,DAPP开发的更多相关文章

  1. 以太坊ERC20代币合约案例

    一.ERC20代币合约与web3调用 ERC20代币合约在小白看来觉得很高大上,但其实就是一个代币的定义标准,方便其他dapp统一调用各种代币的方法.如图: 二.ERC20合约标准 [官方链接] co ...

  2. erc20代币合约

    看这篇文章需要对以太坊,智能合约,代币等概念有基本的了解. 什么是ERC20 可以把ERC20简单理解成以太坊上的一个代币协议,所有基于以太坊开发的代币合约都遵守这个协议.遵守这些协议的代币我们可以认 ...

  3. 一步步教你创建自己的数字货币(代币)进行ICO

    本文从技术角度详细介绍如何基于以太坊ERC20创建代币的流程. 写在前面 本文所讲的代币是使用以太坊智能合约创建,阅读本文前,你应该对以太坊.智能合约有所了解,如果你还不了解,建议你先看以太坊是什么 ...

  4. 用solidity语言开发代币智能合约

    智能合约开发是以太坊编程的核心之一,而代币是区块链应用的关键环节,下面我们来用solidity语言开发一个代币合约的实例,希望对大家有帮助. 以太坊的应用被称为去中心化应用(DApp),DApp的开发 ...

  5. Go-Ethereum 1.7.2 结合 Mist 0.9.2 实现代币智能合约的实例

    目录 目录 1.什么是 Mist 2.Mist 在哪里下载? 3.Mist 有哪些依赖? 4.如何安装 Mist? 4.1.安装 Mist 依赖工具包 4.2.安装 Mist 4.3.启动 Mist, ...

  6. Solidity合约间的调用 -Solidity通过合约转ERC20代币

    Solidity通过合约转ERC20代币   ERC20代币并不能像Ether一样使用sendTo.transfer(amt)来转账,ERC20代币只能通过token中定义的transfer方法来转账 ...

  7. Solidity通过合约转ERC20代币

    ERC20代币并不能像Ether一样使用sendTo.transfer(amt)来转账,ERC20代币只能通过token中定义的transfer方法来转账,每个账户的余额信息也只保存在token合约的 ...

  8. 以太坊ERC20代币开发

    以太坊ERC20代币开发首先需要对以太坊,代币,ERC20,智能合约等以太坊代币开发中的基本概念有了解.根据我们的示例代码就可以发行自己的以太坊代币. 什么是ERC20 可以把ERC20简单理解成以太 ...

  9. 以太坊智能合约[ERC20]发币记录

    以太坊被称为区块链2.0,就是因为以太坊在应用层提供了虚拟机,使得开发者可以基于它自定义逻辑,通常被称为智能合约,合约中的公共接口可以作为区块链中的普通交易执行.本文就智能合约发代币流程作一完整介绍( ...

随机推荐

  1. { "result": null, "log_id": 304592860300941982, "error_msg": "image check fail", "cached": 0, "error_code": 222203, "timestamp": 1556030094 }

    这个是人脸识别时无法检测到图片报的错,有时候我们检测一张图片是否在库里面,当一张图片明显在里面,还检测不到,如下面是我的代码 package Test1; import java.io.IOExcep ...

  2. Python——requests的安装及入门-贴吧爬虫

    一.windows平台下requests的安装 1.win+R,输入cmd,打开命令行窗口,输入命令:pip install requests ,即可自动安装库成功 2.输入命令:pip list,即 ...

  3. Qt Creator使用多线程编辑,增加编译速度

  4. [o.e.b.ElasticsearchUncaughtExceptionHandler] [unknown] uncaught exception in thread [main] org.elasticsearch.bootstrap.StartupException: java.lang.RuntimeException: can not run elasticsearch as root

    这是因为不知从哪个版本后,elasticsearch为了安全性,是不能用root用户启动的. 解决的办法:当然是创建一个用户,用创建的用户启动啦,注意权限的问题,目录也应该改为创建的用户权限! 我是用 ...

  5. Android RecyclerView组件和 Spinner(下拉列表框)

    1.RecyclerView <1>知识点介绍 RecyclerView 比 ListView 更高级且更具灵活性. 它是一个用于显示庞大数据集的容器,可通过保持有限数量的视图进行非常有效 ...

  6. 007 Android 单击事件、toast使用

    第一种按钮点击事件(最常用): button=findViewById(R.id.button); button2=findViewById(R.id.button2); button.setOnCl ...

  7. win 10 问题

    1.  windows 10 已联网 ,但 访问应用商店 提示 未连接网络. step1:  打开网络和 internet 设置.. step2: 取消 打圈的 两个选择..!就好.

  8. centos上安装theano和Lasagne

    1.安装theano所需的包 sudo yum install python-devel python-nose python-setuptools gcc gcc-gfortran gcc-c++ ...

  9. 【原创】SpringMVC同一RequestMapping返回不同的类型

    曾经在工作中遇到过导出文件时,需要根据不同情况返回不同的数据的情况. 例如: 如果没有数据,弹框提示"没有数据" 导出报错,弹框提示"系统错误" 正常情况下,下 ...

  10. 使用xcode测量ios8.1机型时的项目兼容问题

    打开xcode,创建一个新项目 点击左上角的三角形打开模拟器,打开模拟器中的safari,把项目链接输入,即可测试 下面为切换机型的方法: