链资讯 链资讯
Ctrl+D收藏链资讯

ION:Solidity 及EVM 开发工具介绍_PolkaFoundry

作者:

时间:

Solidity及EVM开发工具介绍

这篇文章将介绍Ethereum开发者的一些实用工具:Foundry除了测试之外的功能及VSCode的SolidityVisualDeveloper插件

Photoby?DanCristianP?dure??on?UnsplashFoundry

Foundry除了提供合约开发、测试和部署,其实还有许多其他实用的功能。

安装Foundry

如果是Linux或macOS,先安装foundryup,接着直接用?foundryup?指令就可以安装。未来要升级foundry也只需要执行?foundryup?就好,非常简单直觉。

//Installfoundryup

curl-Lhttps://foundry.paradigm.xyz|bash

//InstallorupdateFoundry

foundryup

详细可以参考Foundrybook的Installation页面。

AutoCompletion

Foundry安装完后会有forge、cast及?anvil?三个指令,每个指令也都有许多option,这时有AutoCompletion会非常省事。例如产生bash用的AutoCompletionscript:

MagicEden:疑似存在SOL漏洞可窃取Phantom钱包资产,提醒用户撤销可疑链接权限:8月3日消息,Solana生态NFT市场MagicEden发推称,疑似存在一个SOL漏洞可以窃取Phantom钱包内资产。提醒用户进行以下设置保护资产:1.进入Phantom设置;2.受信任的应用程序;3.撤销任何可疑链接的权限。[2022/8/3 2:55:00]

其他Shellscript的产生方式可以参考Foundrybook的ShellAutocompletion页面。

anvil

其实就和Ganache及?hardhatnode?一样:跑起一个节点。可以是全新的一个本地节点,也可以是背后连上ForkedState的节点。如果你平常都是习惯用来跑一个短暂的全新测试节点就直接下?anvil?即可。

如果你会想在一个ForkedState内实验或测试的话,多加上?--fork-url?和?--fork-block-number?的option。另外可以留意?--compute-units-per-second?这个option,它会控制每秒请求的计算量,避免取ForkedState太频繁导致遇到像是AlchemyRateLimit的问题。

Brave发布v1.41版本,添加Brave Wallet与Solana集成:据官方消息,Brave发布v1.41版本,Brave Wallet与Solana集成,使Solana DApp支持桌面版Brave Wallet。[2022/7/13 2:09:13]

更详细的节点设置可以参考Foundrybook的AnvilReference页面。

cast

cast是用来取链上资料非常好用的工具。因为有很多功能,这里我只会列出我常用及觉得实用的功能。

注:要读取链的状态记得要在foundry.toml档里附上endpointurl或透过?--rpc-url$URL?的方式。

首先是抓取交易资讯:

casttx/receipt:抓取交易或receipt资讯castrun:印出一笔已被收入的交易的executiontrace或进行livedebug,为了得到准确的交易前状态,预设会模拟执行同一区块里在该笔交易前面所有的交易,但这可能很耗时,如果只想看交易执行过程且不需要最精准的执行结果的话,可以加上--quickoption,它会跳过前面交易的模拟,直接把该笔交易当作区块的第一笔交易来执行注:castrun--debug的debug介面可能没有那么好读,如果不需要看到执行过程中的memory/stack/storage等细节时可以直接用ethtx.info或Tenderly,好读很多。

NFT项目Okay Bears地板价触及150 SOL,创历史新高:4月29日消息,据 OpenSea 数据显示,Solana 链上 NFT 项目Okay Bears地板价触及 150 SOL,创历史新高。此外,Okay Bears 交易总额已达到 38.83 万枚 SOL。[2022/4/29 2:40:41]

接着是从Etherscan抓取合约资讯:

castetherscan-source:会从Etherscan抓取指定地址的合约,可以加上-doption建立一个新的资料夹来放抓下来的合约们。记得用--etherscan-api-key?附上EtherscanAPIkey

注:如果想直接在浏览器开启VSCode环境来浏览、编辑合约的话,可以使用deth.net。还可以透过书签一键开启,非常方便,请参考这则twitter。

接着是encode/decodeABI的功能:

cast4b/4bd/4be:反查functionselector、calldata或是eventsignature。在手上只有一笔交易或一个event的rawdata时,可以透过这些工具来尝试找出它要执行什么函式或emit了什么eventcastcalldata:用functionsignature及参数组出calldata。在为多签检查或组calldata的时候很方便注:因为functionselector只有4bytes,如果多个functionsignature都是同一个functionselector的话,则反查会回传所有可能functionsignature

以太坊Solidity发布0.8.2版本,可内联少量代码节省Gas:3月3日消息,以太坊编程语言Solidity团队发布0.8.2版本,添加了一个优化阶段,可内联少量代码以节省Gas,并通过导出内联注释并允许自定义natspec标签提供更多的方式来使用代码文档。内联是一种将函数体直接展开到调用处的一种优化技术。[2021/3/3 18:10:21]

最后是一些转换或计算的小工具:

cast—-from-utf8/--to-ascii:在hex或字串之间转换castsig:计算functionselectorcastkeccak:计算keccakhashcastcompute-address:计算CREATE的地址

更多cast功能可以参考Foundrybook的castCommands页面。你可以从中按照你的需求找到对你有帮助的常用指令。

forgeinspect

forge的inspect指令则是用来挖出一个合约更进阶的资讯。它不是去拉链上的资料,而是作用在本地端的档案,所以如果你需要分析其他合约,你需要先把它下载下来。

P2P Validator推出支持SOL以及SPL代币的非托管开源钱包:非托管质押网络P2P Validator发推称,基于Solana、Serum和Bonfida推出支持SOL以及SPL代币的非托管、低门槛和高速开源钱包。[2020/11/16 20:56:58]

forgeinspectMyContract...

注:在分析前?forge?会先编译合约,会花一些时间。

首先是列出合约基本资料的功能:

forgeinspectMyContractabi/bytecode/deployedBytecode:列出?MyContract的ABI/编译完的bytecode/实际部署到链上后的bytecode,方便exportABI或是比对部署在链上的bytecodeforgeinspectMyContractmethods/gas:列出?MyContract的function列表/每个function的预估gas消耗。用?cast4b/4bd?其实就能反查特定functionselector,这个功能比较像是能看到一个合约完整的function资讯forgeinspectMyContractstorage:列出?MyContract的storage,包含每个变数的storageslot和offset。但呈现的资料比较丑一点,可以改用slither来分析合约storage或读取合约变数的值,它还可以拉链上的合约来分析,不需要先下载合约下来。接下来是比较进阶的使用:irOptimized,主要是你想再优化你合约的gas消耗时可以采用的方式。

forgeinspectMyContractirOptimized

它会呈现你的合约编译成Yul后的长相。Yul就像assembly,它介于Solidity和EVMopcode之间,它可以让你看到你写的Solidityfunction背后实际上还做了哪些事情,如此你就可以开始删去一些不需要的检查。

这个工具是从这两则twitter发现到的,这边直接引用里面的范例和图片来搭配说明。以一个简单的将?number?变数递增的?Counter?合约为例,里面有一个?setNumber?函式用来设置?number?的值及一个?increment?函式用来把?number?加1。右边则是执行?forgeinspectCounterirOptimized?后所输出Yul版本的?Counter?合约:

source:?https://twitter.com/w1nt3r_eth/status/1579486967963693057

可以看到一个简单的Solidity合约编译完后变得复杂许多。接下来以?increment?函式为例:

source:?https://twitter.com/w1nt3r_eth/status/1579486967963693057

可以发现一个?number++?里面其实包含了很多检查,例如notpayable和overflow。但其实我们知道它只会以一次加?1?的方式递增所以几乎不可能会overflow,然后如果这个函式是可以接受ether的话,那就可以再省掉notpayable的检查:

source:?https://twitter.com/w1nt3r_eth/status/1579486967963693057

可以发现省去了许多执行步骤。

比起原地把Solidity程式码替换成assembly程式码这种比较冒险的优化方式,这是一个新的管道让你能重新完整地检视你的合约,并且可以看出修改前后的对比。但要注意还是以安全为优先,不要为了省一点的gas而拿掉你没有把握的程式码或检查。

其他forgeinspect功能可以参考Foundrybook的forgeinspect页面。

VSCode

最后是介绍一个在review合约时很实用的VSCode插件:SolidityVisualDeveloper

注:以下介绍会是个人使用心得,所以会有特色或功能是没有介绍到的。可以自己下载来试用看看,看能不能发现适合你的用途的功能。

SolidityVisualDeveloper-VisualStudioMarketplace

标签:IONUNDNDRFoundryaion币行情SOUND币rndr币是什么币PolkaFoundry

币赢交易所热门资讯
PROT:在加密圈如何薅羊毛?七个渠道帮助发现更多的空投机会_einsteinium

加密圈子中有许多赚钱的方式,而薅空投羊毛毫无疑问是成本最低且最容易白手起家的方式。那么,有些哪些途径能够帮助我们发现早期空投机会?这里我列举了7个路径.

MOV:对手抢跑,新生公链Sui按下加速键_digifinextoke

10月18日,Aptos宣布「上线主网、发行Token」当日,Sui区块链网络仿佛按下了加速键,将官方账号更名为SuiNetwork并以此作为新品牌亮相。此后,一系列动作出现.

ETA:Maker史上最大规模重组,DAI未来或与美元脱钩_MetaDoctor

MakerDAO??向其“EndgamePlan”又近了一步,MakerDAO已经通过了一项治理提案,开始向其“终极计划”过渡,将推进其历史上最大规模的重组.

ION:如何在加密世界营销?送给初创项目创始人的5点建议_FOR

注:本文作者为Matti,全文概述其对初创项目创始人如何在加密市场营销所提的5点建议。最近,我与一位创始人通了电话,他正在努力营销.

DUC:币安用户 APTOS 来源分析与女巫攻击预警_APT

概述:X-explore对所有价值到币安的APTOS进行了成本来源分析,其中65%的资金为女巫地址入金,累积超过630WAPTToken,这给币安带来了严重抛压,造成了价格一路上涨走低关系.

UCE:各自精彩:Aptos、Sui、Caduceus三大公链新势力横评_TOKEN

在越来越快的行业周期循环中,我们见证了一批又一批新老玩家的登场与退场。依托于上一波牛市的热度和以太坊生态溢出的效应,那些埋伏了一轮熊市的公链新秀得以崭露头角,并且作为市场不断膨胀预期的「落脚点」.