链资讯 链资讯
Ctrl+D收藏链资讯
首页 > ETH > 正文

ENC:智能合约安全系列文章反汇编·上篇_UENC

作者:

时间:

智能合约安全系列文章反汇编·上篇

前言

通过上一篇反编译文章的学习,我们对智能合于opcode的反编译有了基础的学习,对于初学者来说,要想熟练运用还得多加练习。本篇我们来一块学习智能合约反汇编,同样使用的是OnlineSolidityDecompiler在线网站,智能合约反汇编对于初学者来说,较难理解,但对于智能合约代码来说,只要能读懂智能合约反汇编,就可以非常清晰的了解到合约的代码逻辑,对审计合约和CTF智能合约都有非常大的帮助

反汇编内容

由于solidity智能合约的opcode经过反汇编后,指令较多,我们本篇分析简明要义,以一段简单合约代码来分析其反汇编后的指令内容

合约源码如下:

?pragma?solidity?^0.4.24;

?contract?Tee?{

?????

?????uint256?private?c;

?????function?a()?public?returns?(uint256)?{?self(2);?}

?????

?????function?b()?public?{?c++;?}

?????function?self(uint?n)?internal?returns?(uint256)?{

?????????

API3推出智能合约随机数生成器,可在Avalanche、Moonbeam等区块链上使用:5月3日消息,一种依赖量子力学来生成由区块链技术支持的智能合约驱动数据集的随机数生成器已经在十几个加密货币协议上推出。

API3与澳大利亚国立大学量子光学组的一组研究人员合作,将其新产品ANU GRNG称为第一个“真正的”智能合约随机数生成器。

API3表示,公司正在启动的13个区块链中,有10个还没有可用的随机数生成器。其中一些协议使用不使用量子技术的随机数生成器,这意味着它们的数据集是有限的,或者用行业术语来说是“伪随机数”。

新服务可在包括Avalanche、Fantom、Moonbeam、Polygon和RSK在内的区块链上使用,并计划在未来进行更多集成。

该公司并不靠随机数生成器盈利,而是将其引入其他产品线,比如预言机解决方案和数据集成服务,包括一个依赖于质押原生代币运行的验证池。(Blockworks)[2022/5/4 2:48:24]

?????????if?(n?<=?1)?{?return?1;?}

?????????return?n?*?self(n?-?1);

?????}

?}

合约部署后生成的opcode:

?0x6080604052600436106049576000357c0100000000000000000000000000000000000000000000000000000000900463ffffffff1680630dbe671f14604e5780634df7e3d0146076575b600080fd5b348015605957600080fd5b506060608a565b6040518082815260200191505060405180910390f35b348015608157600080fd5b5060886098565b005b60006094600260ab565b5090565b6000808154809291906001019190505550565b600060018211151560be576001905060cd565b60c86001830360ab565b820290505b9190505600a165627a7a7230582003f585ad588850fbfba4e8d96684e2c3fa427daf013d4a0f8e78188d4d475ee80029

OneCash 稳定币 HKC 已完成在 PlatON 公链部署智能合约:据官方信息,OneCash 稳定币 HKC 已完成在 PlatON 公链部署智能合约。此前 HKC 已在 TRON、ETH 部署且上线 Okcoin 交易所。HKC 是 OneCash 发行的合规港币稳定币。双方将不断发挥各自技术优势,促进全面生态合作,提升产品隐私保护能力,并在Defi、元宇宙等领域开展应用探索。[2022/1/19 8:58:42]

通过在线网站OnlineSolidityDecompiler反汇编后结果如下:

反汇编分析

我们从第一部分指令label_0000开始

??0000????60??PUSH1?0x80

??0002????60??PUSH1?0x40

??0004????52??MSTORE

??0005????60??PUSH1?0x04

??0007????36??CALLDATASIZE

??0008????10??LT

??0009????60??PUSH1?0x49

??000B????57??*JUMPI

push指令是将字节压入栈顶,push1-push32依次代表将1字节-32字节推压入栈顶,这里PUSH10x80和PUSH10x40表示将0x80和0x40压入栈顶,故目前栈的布局如下:

智能合约钱包Argent Layer2版本正式上线zkSync:12月24日,智能合约钱包Argent宣布其Layer2版本正式上线zkSync,目前已与zkSync网络内DEX平台ZigZag完成集成,用户现可通过1美元的固定费用使用Argent在Layer2上的交易服务。该服务目前仅支持ETH、USDT、USDC、WBTC、DAI和FRAX。[2021/12/24 8:02:18]

?1:?0x40

?0:?0x80

MSTORE指令表示从栈中依次出栈两个值arg0和arg1,并把arg1存放在内存的arg0处。目前来说栈中已无数据,这里将0x80存放在内存0x40处。

PUSH10x04将0x04压入栈中,CALLDATASIZE指令表示获取msg.data调用数据,目前栈的布局如下:

?1:?calldata

?0:?0x04

LT指令表示将两个栈顶的值取出,如果先出栈的值小于后出栈的值则把1入栈,反之把0入栈。这里如果calldata调用数据小于0x04字节,就将1入栈;如果calldata调用数据大于等于0x04字节,就将0入栈。目前栈的布局为:0:0或0:1。

继续分析,PUSH10x49指令将0x49压入栈顶,目前栈的布局为:

?1:0x49

?0:?0?或者?1

下面一条指令JUMPI指令表示从栈中依次出栈两个值arg0和arg1,如果arg1的值为真则跳转到arg0处,否则不跳转。如果arg1值为1,则指令会跳转到0x49处;如果arg1值为0,则会顺序执行下一条指令。具体执行过程如下:

波卡核心开发者为Wasm智能合约发布全新测试网:10月15日晚间,波卡官方发推称,波卡核心开发者Robin Freyler已为Wasm智能合约发布了全新的Canvas UI、测试网和接口。[2020/10/15]

这里我们先来分析顺序执行的内容label_000C,指令如下

??000C????60??PUSH1?0x00

??000E????35??CALLDATALOAD

??000F????7C??PUSH29?0x0100000000000000000000000000000000000000000000000000000000

??002D????90??SWAP1

??002E????04??DIV

??002F????63??PUSH4?0xffffffff

??0034????16??AND

??0035????80??DUP1

??0036????63??PUSH4?0x0dbe671f

??003B????14??EQ

??003C????60??PUSH1?0x4e

??003E????57??*JUMPI

DAML被选为区块链服务网络BSN的专用智能合约语言:9月14日,北京红枣科技和Digital Asset宣布了关于DAML智能合约技术和区块链服务网络(BSN) 集成的合作协议。作为协议的一部分,由Digital Asset创建的智能合约编程语言DAML,将成为BSN生态内分布式应用(DApp)编写的标准语言。

BSN是由国家信息中心顶层规划,联合中国移动、中国银联和北京红枣科技共同发起的全球性区块链基础设施,旨在让开发者和企业在统一的标准下更高效地创建和访问新一代分布式应用程序。四家发起方早在2018年便启动了BSN项目,目前BSN是中国最大的区块链基础设施网络。[2020/9/15]

目前经过上一步运算栈中布局为空,PUSH10x00指令将0压入栈中。CALLDATALOAD指令接受一个参数,该参数可以作为发往智能合约的calldata数据的索引,然后从该索引处再读取32字节数,由于前一个指令传入的索引值为0,所以这一步指令会弹出栈中的0,将calldata32字节压入栈中。PUSH29指令将29个字节压入栈中。目前栈的布局如下:

?1:0x0100000000000000000000000000000000000000000000000000000000

?0:calldata值

SWAP1指令表示将堆栈顶部元素与之后的第一个元素进行交换,也就是0x0100000000000000000000000000000000000000000000000000000000和calldata值进行交换。接下来DIV指令表示取a//b的值,这里也就是calldata的32字节除29字节,由于除法的运算关系,这里进行除法运算后的字节为4位,估计大家也可以想到,这就是函数标识符4字节。那么目前栈的布局如下:

0:函数标识符4字节

PUSH4指令将0xffffffff压入栈中。AND指令表示将取栈中前两个参数进行AND运算,也就是函数标识符前四位0xffffffff进行AND操作,最终得到前四位的函数标识符及后28位为空补0的数值。下一条指令DUP1表示复制当前栈中第一个值到栈顶,目前栈中布局如下:

1:调用参数中的函数标识符?0:调用参数中的函数标识符

下一个指令PUSH4指令继续将函数标识符0x0dbe671f压入栈中,这里的标识符为a()函数,函数标识符我们可以在https://www.4byte.directory/在线网站查看。目前栈中布局如下:

2:0x0dbe671f?1:调用参数中的函数标识符?0:调用参数中的函数标识符

EQ指令表示取两个栈顶值,如果两值相等就将1入栈,反之将0入栈。下一步PUSH1将0x4e压入栈顶。之后JUMPI指令从栈中依次出栈两个值arg0和arg1,如果arg1的值为真则跳转到arg0处,否则不跳转。目前栈中布局如下:

2:0x4e?1:1?或?0??0:调用参数中的函数标识符

从前面三个指令可看出,EQ对函数标识符进行判断后,下一步压入0x4e是为了JUMPI进行判断并跳转。也就是说如果EQ判断a()函数标识符相等,JUMPI执行后就会跳转到0x4e的偏移位置;反之如果EQ判断a()函数标识符不相等,JUMPI执行后就会顺序执行下一条语句。目前栈中布局如下:

0:调用参数中的函数标识符

具体执行过程如下:

目前我们对label_0000和label_000C已进行分析,从上图来看,该流程中除了顺序执行外,label_0000处0x49,label_003F处0x76和label_000C处0x4e都有相应的跳转条件。本篇我们继续分析顺序执行部分指令。首先来看第一部分label_003F:

?003F????80??DUP1?0040????63??PUSH4?0x4df7e3d0?0045????14??EQ?0046????60??PUSH1?0x76?0048????57??*JUMPI

由于目前栈中只有一条数据

DUP1指令表示复制栈中第一个值到栈顶。PUSH4指令将0x4df7e3d0函数标识符压入栈顶,这里函数标识符代表b()函数,故目前栈中布局如下:

2:0x4df7e3d0?1:调用参数中的函数标识符?0:调用参数中的函数标识符

接下来三个指令会进行栈中值进行运算和偏移量跳转设置,EQ指令把栈顶的两个值出栈,如果0x4df7e3d0和调用参数中的函数标识符相等则把1入栈,否则把0入栈。PUSH1指令将偏移量0x76压入栈中。JUMPI指令从栈中依次出栈两个值:0x76和EQ指令判断的值,如果EQ指令判断的值为真则跳转到0x76处,否则按顺序执行不跳转。故目前栈中布局如下:

2:0x76?1:1?或?0??0:调用参数中的函数标识符

我们假设EQ指令判断的值为0,那么通过JUMPI指令条件判断后,会按照顺序继续执行下一条指令。执行后,栈中依然只有一条指令。

我们继续进行顺序执行,label_0049:

?0049????5B??JUMPDEST?004A????60??PUSH1?0x00?004C????80??DUP1?004D????FD??*REVERT

JUMPDEST指令在该上下文中表示跳转回来,也就是label_0000处0x49的跳转。之后的两条指令PUSH1和DUP1总体意思为将0压入栈顶并复制,没有实际意义。REVERT指令则表示并未有函数签名匹配,从而停止执行,回滚状态。

总结

由于反汇编内容过多,我们分为两篇分享给大家,本篇我们对反汇编的内容进行了详细讲解,下篇我们将会继续分析并串联所有指令,梳理代码逻辑。

来源:金色财经

标签:ENCUENCCODELICINFLUENCEcode币的发行价Chalice Finance

ETH热门资讯
OUD:老山说币:比特币创历史新高机构是否会退出?_Cloud

各位朋友们,你们好,我是老山说币。在这个市场,如果你处于一直亏损的状态,不如换个环境。也许正是你的一次改变,会给你带来不一样的结果.

OUD:MEGAZONE CLOUD融资创新高-美越遵云计算(上海)有限公司_cloudstorage

融资超过8亿2千万人民币,同行业B轮融资创历史新高韩国最大规模的云管理企业(MSP)MEGAZONECLOUD株式会社(代表LEEJOOWAN)继去年A轮融资超过约2.9亿人民币后.

UENC:简讯:UENC公链节点数持续上涨_POW

目前公链UENC的节点数已达到5369台。UENC主网已稳定运行46天,该区块链浏览器显示,近期点数发生大幅度上涨且持续稳定在线,在线规模已达5369台节点.

BTC:12月16日行情分析:BTC会以何种走势突破20000呢?_togetherbnb换装都有什么衣服

BTC小幅上涨,创新高,当前的的走势突破左侧的峰顶,但这里是小阳小突破,同时量能并没有放大,今天的重点在于24点收盘是否能收在19500的上方,这样日线的走势是一个A构造.

以太坊:雷凯趋势:比特币重回1900上方,日内以震荡思路操作即可_BTCRED币

大仓做趋势,小仓做波段,自己控制好比例。逆市做单轻仓止损走,顺势做单加注需死守。没有不赚钱的炒币,只有不赚钱的操作,炒币是对正确心态的一种考验!祝各位炒币朋友都能找到自己的交易方法,稳健赚钱.

SDT:phic黄金分割最新动态_以太坊官网钱包下载教程

接实验室通知,12月31日起,省级节点和市级节点将进行调整,调整具体细则如下:1、省级节点捐赠usdt数量由10000usdt上调为25000usdt.