日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當(dāng)前位置:首頁(yè) > 物聯(lián)網(wǎng) > 區(qū)塊鏈
[導(dǎo)讀] 本教程將向您展示如何輕松地使用Java應(yīng)用程序訪問KyberNetwork以進(jìn)行代幣交易。 本教程實(shí)現(xiàn)了主要的交易場(chǎng)景: 1. 將以太坊轉(zhuǎn)換為其他代幣 2. 將其他代幣轉(zhuǎn)

本教程將向您展示如何輕松地使用Java應(yīng)用程序訪問KyberNetwork以進(jìn)行代幣交易。

本教程實(shí)現(xiàn)了主要的交易場(chǎng)景:

1. 將以太坊轉(zhuǎn)換為其他代幣

2. 將其他代幣轉(zhuǎn)換為以太坊

3. 不同代幣之間的轉(zhuǎn)換

關(guān)于Kyber Network和KyberDAO

KyberNetwork是一個(gè)無須信任的去中心化交易所,它可以促進(jìn)加密資產(chǎn)間的即時(shí)轉(zhuǎn)換/兌換。

kyberNetwork是基于以太坊平臺(tái)建立的去中心化金融應(yīng)用。

KyberNetwork支持兌換以太坊代幣,類似于傳統(tǒng)的外匯交易,還支持兌換其他法定貨幣。主要的區(qū)別在于根本不涉及任何中心交易所!KyberNetwork的基礎(chǔ)代幣是以太坊(ETH),而不是任何法定貨幣。

作為“ KyberDAO”社區(qū)實(shí)驗(yàn)的一部分,該網(wǎng)絡(luò)于6月啟動(dòng)了其基于DAOstack的DAO(在Aragon平臺(tái)上進(jìn)行了首次實(shí)驗(yàn)之后),并為其提供了約17,000 KNC(約合4500美元)的資金。社區(qū)中的任何人都可以提交提案,并提出資金申請(qǐng),以獲取部分或全部贈(zèng)款(請(qǐng)參見公告)。

接口的角度來看,KyberNetwork除了提供直接的智能合約abi之外,kyberNetwork還提供了restful api,它為用戶(沒有太多智能合約知識(shí))提供了與其合約交互的能力。

關(guān)于Kyber Java客戶端庫(kù)

現(xiàn)在讓我們深入了解KyberNetwork的Java客戶端庫(kù)。首先,讓我們運(yùn)行Java教程應(yīng)用程序。

準(zhǔn)備步驟:在機(jī)器上安裝java、git和gradle。

很明顯,您的機(jī)器上安裝了java和git,還要使用gradle構(gòu)建環(huán)境,這樣您就可以從命令行輕松運(yùn)行教程代碼。在您的計(jì)算機(jī)上安裝所有這三個(gè)依賴項(xiàng)。

準(zhǔn)備步驟:使用web3j命令創(chuàng)建一個(gè)ropsten測(cè)試錢包

在我們的例子中,我們必須在ropsten測(cè)試網(wǎng)絡(luò)上創(chuàng)建一個(gè)測(cè)試錢包,用于我們的代幣交換場(chǎng)景。命令行工具可以使用各種安裝程序。

如果是Windows,請(qǐng)使用ZIP文件分發(fā)并提取到目錄中,然后運(yùn)行web3j.bat文件。

使用錢包工具創(chuàng)建一個(gè)錢包?!皐allet create”將創(chuàng)建wallet.json文件。

查看錢包文件中創(chuàng)建的以太坊地址,然后轉(zhuǎn)移一些以太坊到該地址上。

· 您可以使用Ropsten水龍頭創(chuàng)建以太坊測(cè)試幣:https://faucet.ropsten.be/

· 檢查您的地址、交易和任何其他區(qū)塊鏈信息,使用https://ropsten.etherscan.io/

· 在我們的教程應(yīng)用程序中,需要為錢包選擇密碼才能加載必要的憑據(jù)。

準(zhǔn)備步驟:創(chuàng)建infura測(cè)試節(jié)點(diǎn)帳戶

要將Kyber交換交易寫入以太坊區(qū)塊鏈,您需要一個(gè)infura測(cè)試節(jié)點(diǎn)帳戶。

· 在infura上設(shè)置帳戶

· 創(chuàng)建一個(gè)新項(xiàng)目,您將使用Infura秘密代幣(Project Secret)連接到Ropsten Test網(wǎng)絡(luò)。

準(zhǔn)備步驟:復(fù)制github目錄并創(chuàng)建一個(gè)secret目錄

· 使用本教程復(fù)制github目錄:https://github.com/talfco/clb-kyber-java-tutorial

· 在clb-kyber-java-tutorial中創(chuàng)建一個(gè)secret目錄,然后復(fù)制wallet.json文件。

· 創(chuàng)建secret.properties文件并添加錢包密碼和infura代幣添加條目。

運(yùn)行教程應(yīng)用程序

只需輸入gradle run即可啟動(dòng)教程應(yīng)用程序。

應(yīng)用程序?qū)⒄{(diào)用三種功能:

1. 首先,它將部分測(cè)試以太幣轉(zhuǎn)換為兩個(gè)DAI令牌(eth2token)。需要Kyber購(gòu)買費(fèi)率才能確定所需的以太坊的數(shù)量。

2. 其次,它將一個(gè)DAI代幣轉(zhuǎn)換回以太坊(token2eth)。為了確定支付的以太坊數(shù)量,需要Kyber銷售率。

3. 第三,它將一個(gè)DAI代幣轉(zhuǎn)換為一個(gè)BAT代幣(token2token)。 對(duì)于此交易,同時(shí)需要Kyber的購(gòu)買率和銷售率,以確定可以購(gòu)買多少個(gè)BAT代幣。

public staTIc void main(String[] args) throws ExcepTIon {

ApplicaTIon app = new ApplicaTIon();

log.info(“》》》 SCENARIO: ETH2TOKEN”);

Thread.sleep(3000);

app.eth2token(“DAI”,“2”);

log.info(“》》》 SCENARIO: TOKEN2ETH”);

Thread.sleep(3000);

app.token2eth(“DAI”,“1”);

log.info(“》》》 SCENARIO: TOKEN2TOKEN”);

Thread.sleep(3000);

app.token2token(“DAI”,“BAT”,“0.5”);

}

檢查控制臺(tái)輸出中已創(chuàng)建的交易哈希和其他信息。

教程生成的以太坊交易

該教程應(yīng)用程序?qū)⑸?個(gè)以太坊交易,您可以通過etherscan.io Web應(yīng)用程序進(jìn)行結(jié)帳。

1. https://ropsten.etherscan.io/address/ 《yourTestWalletAddress》

2. 您將看到由我們的三個(gè)功能觸發(fā)的三筆交易

您現(xiàn)在也是Ropsten網(wǎng)絡(luò)上DAI和BAT代幣的所有者。將來,您可以使用這個(gè)簡(jiǎn)單的java應(yīng)用程序生成任何類型的測(cè)試代幣(只要kyber測(cè)試網(wǎng)絡(luò)支持它)

例如下面的屏幕截圖是來自eth2token轉(zhuǎn)換(購(gòu)買了2個(gè)dai代幣)的詳細(xì)事務(wù)信息。現(xiàn)在,您可以深入了解并研究與此交易相關(guān)的kyber合約。

實(shí)施方面-Kyber API功能設(shè)計(jì)為web3j模塊

本教程是我對(duì)Ethereum的第一篇Java編程文章,我發(fā)現(xiàn)Ethereum網(wǎng)絡(luò)的一個(gè)不錯(cuò)的Java庫(kù)。Web3實(shí)驗(yàn)室的web3j是一個(gè)著名的例子。它主要側(cè)重于智能合約(主要受到Kyber Restful API的保護(hù)),并將具有必要的工具包來加載錢包憑證和簽署交易,這在Kyber Restful API中也發(fā)揮著作用。

引入的java類和接口繼承自web3j的核心類,并以類似的方式實(shí)現(xiàn)。這讓我一方面可以利用來自web3j的大量代碼;另一方面,使用web3j的開發(fā)人員將發(fā)現(xiàn)類似的模式。

為了符合web3j(圍繞JSON-RPC接口構(gòu)建),我引入了JsonRpc2_0Kyber類,該類充當(dāng)協(xié)議轉(zhuǎn)換器并為Kyber REST API準(zhǔn)備請(qǐng)求。

Kyber Java API接口支持以下功能。

package net.cloudburo.kyber.tutorial.protocol;

import net.cloudburo.kyber.tutorial.methods.request.GasPriceRange;

import net.cloudburo.kyber.tutorial.methods.request.SingleRate;

import net.cloudburo.kyber.tutorial.methods.response.*;

import org.web3j.protocol.core.Request;

import java.math.BigInteger;

public interface KyberAPI {

public Request《?, Currencies》 currencies();

public Request《?, BuyRate》 buyRate(String id, String qty,boolean onlyOfficialReserve);

public Request《?, SellRate》 sellRate(String id, String qty, boolean onlyOfficialReserve);

public Request《?, TradeData》 tradeData(String userAddress, SingleRate rate, GasPriceRange gasPrice);

public Request《?, TradeData》 tradeData(String userAddress, SingleRate rate, GasPriceRange gasPrice, BigInteger nonce);

public Request《?, TradeData》 tradeData(String userAddress, String srcId, String dstId, Float srcQty,F(xiàn)loat minDstQty,

GasPriceRange gasPrice, String walletId, boolean onlyOfficialReserve);

public Request《?,EnabledTokensForWallet》 enabledTokensForWallet(String userAddress);

public Request《?, EnableTokenTransfer》 enableTokenTransfer(String userAddress, String id, GasPriceRange gasPrice);

}

可以看到,主要部分是Java strong類型。JSON數(shù)據(jù)請(qǐng)求通過Jackson XML解析支持自動(dòng)轉(zhuǎn)換為Java類。

第二篇文章將深入探討構(gòu)建的客戶端庫(kù)的各個(gè)設(shè)計(jì)方面。

交易場(chǎng)景代碼

結(jié)束本教程;提供了這三種情況的代碼序列。 如您所見,代碼非常緊湊,易讀且易于理解。 如果您查看基本的web3j以太坊事務(wù)示例,您將看到代碼的相似性。

場(chǎng)景:ETH2TOKEN

只要認(rèn)識(shí)到使用kyber api交換ethereum上的代幣是多么容易!

private void eth2token(String tokenSymbol, String tokenQuantity) {

Kyber3j kyber3j = Kyber3j.build(new KyberService(KyberService.KYBER_ROPSTEN));

log.info(“Connected to Kyber Network: ”+KyberService.KYBER_ROPSTEN);

// ETH2《Token》 Swap

try {

// Check if token is supported

Currencies currencies = kyber3j.currencies().send();

log.info(“Exists Currency”+tokenSymbol+“: ” + currencies.existsCurreny(tokenSymbol));

if (!checkForError(currencies) && currencies.existsCurreny(tokenSymbol)) {

// Get buy rates

BuyRate buyRate = kyber3j.buyRate(currencies.getCurrency(tokenSymbol).getId(),tokenQuantity,

false).send();

if (!checkForError(buyRate)) {

Rates rates = buyRate.getData().get(0);

SingleRate singleRate = rates.getSingleRate(0);

log.info(“Conversion Rate: ” + singleRate.getSrc_qty());

// Get tradeData

// Adjust conversion rates to 97%

singleRate.approximateReceivableToken(0.97);

TradeData tradeData = kyber3j.tradeData(credentials.getAddress(), singleRate, GasPriceRange.medium,nonce).send();

if (!checkForError(tradeData)) {

executeEthereumTransaction(tradeData.getData().get(0));

}

}

}

} catch (Exception e) { e.printStackTrace(); }

}

場(chǎng)景:TOKEN2ETH

private void token2eth(String tokenSymbol, String tokenQuantity){

Kyber3j kyber3j = Kyber3j.build(new KyberService(KyberService.KYBER_ROPSTEN));

log.info(“Connected to Kyber Network: ”+KyberService.KYBER_ROPSTEN);

try {

// Check if token is supported

Currencies currencies = kyber3j.currencies().send();

if (!checkForError(currencies) && currencies.existsCurreny(tokenSymbol)) {

EnabledTokensForWallet tokens = kyber3j.enabledTokensForWallet(credentials.getAddress()).send();

if (!checkForError(tokens)){

// Check if wallet is enabled for token

String tokenId = currencies.getCurrency(tokenSymbol).getId();

EnabledTokensForWallet.EnabledTokenStatus tokenStatus = tokens.getEnabledTokenStatus(tokenId);

if ( tokenStatus.isEnabled()) {

if (tokenStatus.getTxs_required() == 1) {

// Enable Token Transfer

EnableTokenTransfer tokenData = kyber3j.enableTokenTransfer(credentials.getAddress(), tokenId,

GasPriceRange.medium).send();

executeEthereumTransaction(tokenData.getData());

}

SellRate sellRate = kyber3j.sellRate(currencies.getCurrency(tokenSymbol).getId(), tokenQuantity,

false).send();

if (!checkForError(sellRate)) {

Rates rates = sellRate.getData().get(0);

SingleRate singleRate = rates.getSingleRate(0);

log.info(“Conversion Rate: ” + singleRate.getSrc_qty());

singleRate.approximateReceivableToken(0.97);

TradeData tradeData = kyber3j.tradeData(credentials.getAddress(), singleRate, GasPriceRange.medium,nonce).send();

if (!checkForError(tradeData)) {

executeEthereumTransaction(tradeData.getData().get(0));

}

}

}

}

}

} catch (Exception e){ e.printStackTrace(); }

}

場(chǎng)景:Token2Token

private void token2token(String tokenSymbolFrom, String tokenSymbolTo, String tokenQuantity) {

//Suppose we want to convert 100 BAT to DAI tokens, which is a token to token conversion.

// Note that ETH is used as the base pair i.e. BAT -》 ETH -》 DAI.

Kyber3j kyber3j = Kyber3j.build(new KyberService(KyberService.KYBER_ROPSTEN));

log.info(“Connected to Kyber Network: ”+KyberService.KYBER_ROPSTEN);

try {

Currencies currencies = kyber3j.currencies().send();

if (!checkForError(currencies) && currencies.existsCurreny(tokenSymbolFrom)

&& currencies.existsCurreny(tokenSymbolTo) ) {

EnabledTokensForWallet tokens = kyber3j.enabledTokensForWallet(credentials.getAddress()).send();

if (!checkForError(tokens)) {

// Check if wallet is enabled for tokens

String tokenId = currencies.getCurrency(tokenSymbolFrom).getId();

EnabledTokensForWallet.EnabledTokenStatus tokenStatus = tokens.getEnabledTokenStatus(tokenId);

if ( tokenStatus.isEnabled()) {

// Check if the sell token is already enabled to be sold by the network on behalf of this user

if (tokenStatus.getTxs_required() == 1) {

EnableTokenTransfer tokenData = kyber3j.enableTokenTransfer(credentials.getAddress(), tokenId,

GasPriceRange.medium).send();

executeEthereumTransaction(tokenData.getData());

} else if (tokenStatus.getTxs_required() == 2) {

// TODO Implement validation

log.error(“Not implemented for getTxs_required = 2”);

}

} else {

log.error(“Curreny not supported”);

return;

}

// Get Sell Rate in ETH: 《fromTokenQuantity》 -》 ETH ?

SellRate sellRate = kyber3j.sellRate(currencies.getCurrency(tokenSymbolFrom).getId(), tokenQuantity,

false).send();

if (!checkForError(sellRate)) {

Rates rates = sellRate.getData().get(0);

SingleRate singleRateFromToken = rates.getSingleRate(0);

Float sellQty = singleRateFromToken.getDst_qty();

log.info(tokenSymbolFrom+“ Sell Rate: ” + singleRateFromToken.getSrc_qty());

// Get Buy Rate for 1 toToken: ETH ? -》 1 《toToken》

BuyRate buyRate = kyber3j.buyRate(currencies.getCurrency(tokenSymbolTo).getId(),“1”,

false).send();

if (!checkForError(buyRate)) {

rates = buyRate.getData().get(0);

SingleRate singleRateToToken = rates.getSingleRate(0);

Float buyQty = singleRateToToken.getSrc_qty();

Float expectedAmountWithoutSlippage = sellQty / buyQty; // * Float.valueOf(tokenQuantity);

Float expectedAmountWithSlippage = expectedAmountWithoutSlippage * 0.97f;

singleRateFromToken.setDst_id(singleRateToToken.getDst_id());

singleRateFromToken.setDst_qty(expectedAmountWithSlippage);

TradeData tradeData = kyber3j.tradeData(credentials.getAddress(), singleRateFromToken, GasPriceRange.medium, nonce).send();

if (!checkForError(tradeData)) {

executeEthereumTransaction(tradeData.getData().get(0));

}

}

}

}

}

} catch (Exception e){e.printStackTrace();}

}

最后一點(diǎn)

我希望本教程對(duì)您有用,將代碼加載到j(luò)ava ide中并開始使用它。您將認(rèn)識(shí)到在以太坊網(wǎng)絡(luò)上執(zhí)行和交換代幣事務(wù)是多么容易一件事。
來源: 區(qū)塊鏈研究實(shí)驗(yàn)室?

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

LED驅(qū)動(dòng)電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: 驅(qū)動(dòng)電源

在工業(yè)自動(dòng)化蓬勃發(fā)展的當(dāng)下,工業(yè)電機(jī)作為核心動(dòng)力設(shè)備,其驅(qū)動(dòng)電源的性能直接關(guān)系到整個(gè)系統(tǒng)的穩(wěn)定性和可靠性。其中,反電動(dòng)勢(shì)抑制與過流保護(hù)是驅(qū)動(dòng)電源設(shè)計(jì)中至關(guān)重要的兩個(gè)環(huán)節(jié),集成化方案的設(shè)計(jì)成為提升電機(jī)驅(qū)動(dòng)性能的關(guān)鍵。

關(guān)鍵字: 工業(yè)電機(jī) 驅(qū)動(dòng)電源

LED 驅(qū)動(dòng)電源作為 LED 照明系統(tǒng)的 “心臟”,其穩(wěn)定性直接決定了整個(gè)照明設(shè)備的使用壽命。然而,在實(shí)際應(yīng)用中,LED 驅(qū)動(dòng)電源易損壞的問題卻十分常見,不僅增加了維護(hù)成本,還影響了用戶體驗(yàn)。要解決這一問題,需從設(shè)計(jì)、生...

關(guān)鍵字: 驅(qū)動(dòng)電源 照明系統(tǒng) 散熱

根據(jù)LED驅(qū)動(dòng)電源的公式,電感內(nèi)電流波動(dòng)大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。

關(guān)鍵字: LED 設(shè)計(jì) 驅(qū)動(dòng)電源

電動(dòng)汽車(EV)作為新能源汽車的重要代表,正逐漸成為全球汽車產(chǎn)業(yè)的重要發(fā)展方向。電動(dòng)汽車的核心技術(shù)之一是電機(jī)驅(qū)動(dòng)控制系統(tǒng),而絕緣柵雙極型晶體管(IGBT)作為電機(jī)驅(qū)動(dòng)系統(tǒng)中的關(guān)鍵元件,其性能直接影響到電動(dòng)汽車的動(dòng)力性能和...

關(guān)鍵字: 電動(dòng)汽車 新能源 驅(qū)動(dòng)電源

在現(xiàn)代城市建設(shè)中,街道及停車場(chǎng)照明作為基礎(chǔ)設(shè)施的重要組成部分,其質(zhì)量和效率直接關(guān)系到城市的公共安全、居民生活質(zhì)量和能源利用效率。隨著科技的進(jìn)步,高亮度白光發(fā)光二極管(LED)因其獨(dú)特的優(yōu)勢(shì)逐漸取代傳統(tǒng)光源,成為大功率區(qū)域...

關(guān)鍵字: 發(fā)光二極管 驅(qū)動(dòng)電源 LED

LED通用照明設(shè)計(jì)工程師會(huì)遇到許多挑戰(zhàn),如功率密度、功率因數(shù)校正(PFC)、空間受限和可靠性等。

關(guān)鍵字: LED 驅(qū)動(dòng)電源 功率因數(shù)校正

在LED照明技術(shù)日益普及的今天,LED驅(qū)動(dòng)電源的電磁干擾(EMI)問題成為了一個(gè)不可忽視的挑戰(zhàn)。電磁干擾不僅會(huì)影響LED燈具的正常工作,還可能對(duì)周圍電子設(shè)備造成不利影響,甚至引發(fā)系統(tǒng)故障。因此,采取有效的硬件措施來解決L...

關(guān)鍵字: LED照明技術(shù) 電磁干擾 驅(qū)動(dòng)電源

開關(guān)電源具有效率高的特性,而且開關(guān)電源的變壓器體積比串聯(lián)穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機(jī)重量也有所下降,所以,現(xiàn)在的LED驅(qū)動(dòng)電源

關(guān)鍵字: LED 驅(qū)動(dòng)電源 開關(guān)電源

LED驅(qū)動(dòng)電源是把電源供應(yīng)轉(zhuǎn)換為特定的電壓電流以驅(qū)動(dòng)LED發(fā)光的電壓轉(zhuǎn)換器,通常情況下:LED驅(qū)動(dòng)電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: LED 隧道燈 驅(qū)動(dòng)電源
關(guān)閉