当前位置:首页 > 物联网 > 区块链
[导读] 在上一篇《从一笔交易来看ETH与BTC之异同》中,我们从一笔交易来概略说明了ETH与BTC转帐交易的不同之处,本篇文章我们要来谈以太坊智能合约。不会谈到实作部分,而是希望能从实际应用场景切入来说

在上一篇《从一笔交易来看ETH与BTC之异同》中,我们从一笔交易来概略说明了ETH与BTC转帐交易的不同之处,本篇文章我们要来谈以太坊智能合约。不会谈到实作部分,而是希望能从实际应用场景切入来说明,让阅读完本文的读者都能充分理解智能合约的技术运作原理。

好!那本文便开始啰!我们直接开门见山地来谈谈:

何谓智能合约?

智能合约本质上是一段部署 ( Deploy,即发布) 到区块链上的程式码,因为区块链上的程式码(严格来说是二进位码)可以被检视,所以具备公开透明的特性。智能合约被部署到链上后会产生一个合约地址,永久存在于链上的区块之中。以下用Pelith开发部署之CryptoCow智能合约为范例做解说。

如何部署智能合约?

我们从智能合约的诞生谈起。

开发者将程式码开发完成后,要透过发送一笔接收地址为“0x0”开头的交易(一般交易的接收地址为0x开头,后面接一串字),并在交易的 Input Data内放上开发完成的程式码。矿工看到接收地址为0x0的交易就会知道交易的发送者想要部署智能合约,随后便会将Input Data内的程式码部署到区块链上,并生成一个合约地址。

然而我们会发现Input Data充满了看不懂的文字,似乎跟我们印象中的程式码不太一样,原因是在以太坊上储存的合约逻辑是以Bytecode 的形式,所以开发者以Solidity开发的原始码必须先被编译成Bytecode 才能部署上链。

目前大多数开发者使用的开发工具,如:Remix 本身都具备编译的功能,开发者开发完原始码后只要一键进行编译的动作便能取得Bytecode 。

至此,我们来整理一下部署智慧合约上链的流程:

1. 开发者以Solidity 编写完成合约

2. 原始码编译为Bytecode

3. 放入交易的Input Data 中

4. 接收地址部分留空(0x0)

5. 节点(矿工) 判定为要发送合约上链

6. 矿工执行,并部署上链生成智慧合约

7. 合约拥有自己的「合约地址」,永久存在链上

什么是合约地址?

在合约生成之后,会创造出一个合约地址,让合约(Contract Account)和个人帐户(Externally Owned Account)一样都有一个地址,会纪录追踪nonce(帐户的交易次数)和balance(帐户余额)。

不过合约因为是「被」创造出来的,不像个人帐户一样可以「主动操作」来发送交易给别人,所以我们如果要使用智慧合约的功能,必须要以个人帐户发送一笔「接收地址为合约地址」的交易,来主动触发合约,让合约执行动作。

因此,任何一笔交易的起点都必须是个人帐户。

接着,我们来实际看看一笔和智能合约互动的交易,下方是一笔很常见的操作合约交易,内容是将一颗透过智能合约创造出来的ERC-20 代币,从一个地址转移到另一个地址中。而这些操作,必须透过交易发起者将这些操作以程式原始码撰写,编译后放到Input Data 中。

上方红框中其实是Etherscan 解码(Decode)后呈现的样式,而Solidity 原始码编译后其实是长得像下列这样,以hex(16进位制)的方式表示。

对照上下两种不同表现形式的图,我们可以发现下图红底线的部分(0x93316cdf)在上图中被以 MethodID 标示出来。其实0x后的前8码表示的是 我们要呼叫合约中的什么 function(在智慧合约撰写时我们会规划有哪些功能是可以使用的),后面接的则是该功能的其它参数。

而这个 MethodID(0x93316cdf)其实也有许多其它的别名,这边列举一些比较常听到的:HashID、FuncTIon Hash、FuncTIon Signature 等。

因此,知道这个之后,未来我们在操作DAPP 时,便能去检视背后的操作,也可以直接上以太坊区块链浏览器Etherscan 去追踪交易(TransacTIon),看是否智慧合约真的有按照DAPP 应用程式介面显示的状态去执行功能。

如果不确定这个MethodID是什么功能或会做什么,可以到Ethereum FuncTIon Signature Database 上查询:

把0x93316cdf 贴上并搜寻后,便能得知这个MethodID 对应的是什么function,可以再以这个function 到智慧合约的程式码中去确认到底操作了什么。

结论

智能合约是一段部署到区块链上的程式码,可以有各式各样的功能。因为区块链公开透明的特性,所以可以被任何人检视和验证。

合约部署完成后会生成「合约帐户」,有自己的合约地址。但所有的交易与操作都必须「个人帐户」发起,去呼叫合约中的function来执行。

想要确认操作合约的交易到底做了什么,可以检视Input Data内0x后的前八码 MethodID,并查询这是什么 function,再到合约帐户中去检视原始码来确认。

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

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 信息技术
关闭
关闭