当前位置:首页 > 物联网 > 区块链
[导读] 智能合约本身没有访问区块链外部数据的能力。而外部的数据对于大多数智能合约应用场景来说都是至关重要的,所以这一功能的缺失限制了智能合约的更进一步的发展。比如涉及金融,供应链,保险,安全等诸多领域的

智能合约本身没有访问区块链外部数据的能力。而外部的数据对于大多数智能合约应用场景来说都是至关重要的,所以这一功能的缺失限制了智能合约的更进一步的发展。比如涉及金融,供应链,保险,安全等诸多领域的智能合约都依赖于外部事件。智能合约无法获取关键的链下事件信息,比如价格变动,物流日期,以及支付能力。没有这些外部的信息,大多数智能合约的应用都是没有实际应用价值的。

为什么智能合约无法自主获取外部数据?

因为区块链网络是确定性的。智能合约在区块链这种去中心化的,自我调节的基础设施上运行,其中的任何信息都是确定的,可验证的。区块链可以正常运行,必须在各个参与方之间达成共识。为了实现这个目标,人们设计了[各种]*共识机制*,比如工作量证明(Proof of Work),权益证明(Proof of Stake),行动证明(Proof of Activity)。这些共识机制使得区块链这一分布式的系统形成一个统一的状态。

有了这些共识机制,就可以验证网络上的交易,确定统一公开账本的状态。这种设计允许区块链以公平和安全的方式运行,而无需使用集中式身份验证。因此,区块链整体上是*确定性状态机*。

但是区块链外部的数据是非确定性的,因为从某种意义上说,它是通过区块链的历史无法验证的值。外部数据会受各种因素的影响动态变化。价格的频繁变化,公司实时更新物流信息,物流变化的更新,等等。因为这些信息是不确定的,智能合约没有一种方式可以验证这些数据进而达成共识。因此,无法确认为真实的数据对区块链没有任何意义。

如何把外部数据提供给智能合约?

通过区块链中间件,特别是安全可靠的预言机可以实现。预言机扮演者数据代理人的角色,连接外部数据与智能合约。它充当区块链数据API之间的中间层,将数据转换为区块链可以读取的格式。此外,预言机还负责验证外部数据的正确性,因此可信赖的来源(信任最小化)至关重要。

但是,在中心化的预言机服务中,预言机会有被攻击的可能性(被黑客攻击,服务停机,数据篡改等),这导致智能合约丢失了确定性和可靠性这一最关键的特性,从而使大多数基于现实场景的智能合约用例的不可用。如何解决这一问题呢,答案是去中心化的预言机网络。或者说是Chainlink。

Chainlink通过提供与智能合约开发者的安全性和可靠性相匹配的去中心化的预言机网络来解决联通性问题。通过外部适配器(也被称为chainlinks),区块链可以安全地与chainlinked API连接。开发人员可以方便地将他们自己的智能合约与预先编写的Chainlink API套件连进行连接,从而建立一个链下的预言机连接。

例如,假设您开发了一个智能合约,可以把代币发送到一个地址。Chainlink(输出预言机)通过PayPal发送离线支付。然后,预言机可以基于离线支付在链上提供收据,从而完成区块链系统中的交易循环。

有了Chainlink,智能合约现在能够通过一个去中心化的预言机网络在大多数现实世界的应用场景中正常运行。Chainlink通过安全可靠得方式满足智能合约的预设条件,因此所有相关方都可以从智能合约生态系统的巨大潜力中受益。

代码层面,预言机是如何工作的?

使用预言机需要由足够数量的LINK代币,以及一些基本的Solididy知识,Solidity是编写智能合约的语言。请参考Chainlink的[Solidity接口文档]来了解Chainlink的所有方法。最后,wield能从Chainlink的预言机请求数据,你需要首先在你的合约中继承ChainlinkClient合约。你可以通过[这里]的例子作为指导来创建合约,也可以参考[文档]。

预言机可以帮助智能合约请求和获取区块链的外部数据。我们通过jobs来执行预言机任务来完成请求。这些jobs有与预言机地址相对应的JobID。这些Job由一系列任务,或称为[适配器],所组成,在指定JobID发送请求时, 这些任务或适配器定义了要完成的工作。

为了更好地展示预言机如何在代码层面运行,我们通过一个请求以太网价格的示例智能合约来解释:

contract MyContract is ChainlinkClient {

address owner;

constructor() public {

// Set the address for the LINK token on the public network

// 设置公共网络的LINK代币发行地址

setPublicChainlinkToken();

owner = msg.sender;

}

// AddiTIonal funcTIons here.。.

// 其他的函数。..

}

首先,为了能使用Chainlink网络,你需要在你的合约中继承ChainlinkClient合约。这是一个测试网和正式网通用的构造函数体。这是因为我们使用了setPublicChainlinkToken()方法,这个方法会根据合约部署的网络环境,自动的获取LINK代币的发行地址。

所有当前的预言机和LINK代币地址都可以在[这里]。存储LINK代币地址后,您可以指定预言机合约地址及其相应的JobID来创建请求。

// Creates a Chainlink request to the specified oracle with a given Job ID

// 通过给定预言机地址和JobID来创建Chainlink请求

funcTIon requestEthereumPrice(address _oracle, bytes32 _jobId)

public

onlyOwner

{

// newRequest takes a JobID, a callback address, and callback funcTIon as input

// 新的请求需要JobID,回调地址和回调函数作为输入

Chainlink.Request memory req = buildChainlinkRequest(_jobId, this, this.fulfill.selector);

// Adds a URL with the key “get” to the request parameters

// 添加一个URL设置“get”作为key来请求参数

req.add(“get”, “https://min-api.cryptocompare.com/data/price?fsym=ETH&tsyms=USD”);

// Uses input param (dot-delimited string) as the “path” in the request parameters

// 使用点分隔的字符串作为请求参数中的path

req.add(“path”, “USD”);

// Adds an integer with the key “times” to the request parameters

// 为请求参数设置倍数

req.addInt(“times”, 100);

// Sends the request with 1 LINK to the oracle contract

// 向预言机还有发送1 LINK

sendChainlinkRequestTo(_oracle, req, ORACLE_PAYMENT);

}

请求通过buildChainlinkRequest()方法创建,接受相应的参数填写到Chainlink.Request结构体中作为负载。你可以使用req.add()向请求添加参数,比如URL。一旦你准备好了所有的必须参数,可以通过sendChainlinkRequestTo()方法发送到特定的预言机合约地址,并支付1 LINK的代币,作为给节点运营方的奖励。请注意,在主网上,支付金额是各不相同的,但是为了方便大家理解,我们目前设置了为每次请求花费1 LINK。由于测试网络上这些代币没有任何价值,所以我们可以通过[水龙头]来获取。

uint256 constant private EXPECTED_RESPONSES = 3;

uint256[] private prices;

uint256 public avgPrice;

function fulfillEthereumPrice(bytes32 _requestId, uint256 _price)

public

recordChainlinkFulfillment(_requestId)

{

if(prices.push(_price) == EXPECTED_RESPONSES) {

uint256 sum;

for(uint i = 0; i 《 prices.length; i++) {

sum = sum.add(prices[i]);

delete prices[i];

}

avgPrice = sum.div(EXPECTED_RESPONSES);

}

}

当Chainlink节点从指定的端点取回结果后,预言机合约会调用回填方法(fulfillment method)。回填方法应该通过recordChainlinkFulfillment()修改器或validateChainlinkCallback()方法保护起来。这样可以防止无关的人调用该方法,并且只能根据你的请求填写相应的结果。

将所有这些组合到一起,就可以完成一个可以在以太坊测试网络上可以获取外部数据的预言机合约了。完整代码见[这里]。

我如何开始使用Chainlink?

想要快速上手,你可以通过[这里]的帮助,通过Truffle部署智能合约。如果你已熟悉智能合约开发,欢迎您随时查看我们最新的博客文章“[44种通过Chainlink增强您的智能合约的方法]”。

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

9月2日消息,不造车的华为或将催生出更大的独角兽公司,随着阿维塔和赛力斯的入局,华为引望愈发显得引人瞩目。

关键字: 阿维塔 塞力斯 华为

加利福尼亚州圣克拉拉县2024年8月30日 /美通社/ -- 数字化转型技术解决方案公司Trianz今天宣布,该公司与Amazon Web Services (AWS)签订了...

关键字: AWS AN BSP 数字化

伦敦2024年8月29日 /美通社/ -- 英国汽车技术公司SODA.Auto推出其旗舰产品SODA V,这是全球首款涵盖汽车工程师从创意到认证的所有需求的工具,可用于创建软件定义汽车。 SODA V工具的开发耗时1.5...

关键字: 汽车 人工智能 智能驱动 BSP

北京2024年8月28日 /美通社/ -- 越来越多用户希望企业业务能7×24不间断运行,同时企业却面临越来越多业务中断的风险,如企业系统复杂性的增加,频繁的功能更新和发布等。如何确保业务连续性,提升韧性,成...

关键字: 亚马逊 解密 控制平面 BSP

8月30日消息,据媒体报道,腾讯和网易近期正在缩减他们对日本游戏市场的投资。

关键字: 腾讯 编码器 CPU

8月28日消息,今天上午,2024中国国际大数据产业博览会开幕式在贵阳举行,华为董事、质量流程IT总裁陶景文发表了演讲。

关键字: 华为 12nm EDA 半导体

8月28日消息,在2024中国国际大数据产业博览会上,华为常务董事、华为云CEO张平安发表演讲称,数字世界的话语权最终是由生态的繁荣决定的。

关键字: 华为 12nm 手机 卫星通信

要点: 有效应对环境变化,经营业绩稳中有升 落实提质增效举措,毛利润率延续升势 战略布局成效显著,战新业务引领增长 以科技创新为引领,提升企业核心竞争力 坚持高质量发展策略,塑强核心竞争优势...

关键字: 通信 BSP 电信运营商 数字经济

北京2024年8月27日 /美通社/ -- 8月21日,由中央广播电视总台与中国电影电视技术学会联合牵头组建的NVI技术创新联盟在BIRTV2024超高清全产业链发展研讨会上宣布正式成立。 活动现场 NVI技术创新联...

关键字: VI 传输协议 音频 BSP

北京2024年8月27日 /美通社/ -- 在8月23日举办的2024年长三角生态绿色一体化发展示范区联合招商会上,软通动力信息技术(集团)股份有限公司(以下简称"软通动力")与长三角投资(上海)有限...

关键字: BSP 信息技术
关闭
关闭