阅读etherscan上所有的合约转账代码

自从出了智能合约溢出攻击事件之后,大家纷纷讨论发现了智能合约漏洞了之后怎么自由之类的,整天意淫着能找到一个合约漏洞自此自由后逍遥人间。。。

当然这只是玩笑了,玩笑之余,想着看看众多合约中是否还有漏洞。当然如果真有漏洞基本上已经被黑客默默的利用了(或者等待机会利用),等我来发现黄花菜都凉了去了。

怎么分析呢,想着从etherscan上看一个个合约代码吧,笨办法来搞吧。

刚开始是找了一个小交易所,然后一个个在etherscan上搜,再查看合约代码,想着上小交易所的合约被人盯的机会比较小,看了几十个没发现问题

再从etherscan上市值倒数来看,也是基于低市值合约黑客暂不去攻击的想法去看看能不能发现新的攻击。在看了一两百个智能合约后,发现了一个合约有问题,但是这个未上市,就watch一下吧😑

看了一两百个也晕了,还是怎么能省点功夫吧,一个个去点,点的累,还有时候看重了,最好是把合约代码下载下来本地搜索出transfer关键函数看一看好了。

抓包工具web scraper

恰好之前同事用过一个web scraper的chrome插件,就拿来用用,还真方便使用,一下就把etherscan上的501个合约地址找到了(后面发现可能不止501个,但是从这个地址只能找到501个)

https://etherscan.io/tokens
安装了web scraper之后,可以很方便的把tokens的所有地址抓下来,具体使用规则可以搜索到

比如EOS的token地址是:https://etherscan.io/token/0x86fa049857e0209aa7d9e616f7eb3b3b78ecfdb0

那么EOS的合约地址就是https://etherscan.io/address/0x86fa049857e0209aa7d9e616f7eb3b3b78ecfdb0#code

抓取智能合约代码用web scraper比较麻烦,一则它只能抓取可见框区域的代码,二则一个个合约的遍历也不方便,之前接触过python代码抓取网页内容,所以就写了个python脚本去抓取合约代码。

python脚本抓取合约代码

过程如下:

1 根据web scraper抓取到的所有的token地址保存到一个文件

2 python脚本做一下事情:

    a: 读取所有的token地址,循环处理

    b: 把token地址更改为code地址

    c: 通过查看code地址的源代码找到定位合约地址的规则,把合约代码抓取下来保存在文件(可以使用token地址来命令)

3 总共抓取到了501个合约地址的文件,有的合约没有上传源代码就没有抓取下来

4 然后grep出transfer函数后的10行代码来看有没有问题,这个也是人肉看,也是比较痛苦的过程,不过比etherscan上一个个点好多了,保存的文件如下如所示:

这默认图片也搞的有点大了吧。。。

最后又发现了一个合约有问题,但是目前市值太小,估计黑客也关注到了,我也同样watch吧😁

总结一下

在我前一篇分析合约漏洞的文章有提到,有些合约作者不知道为什么不按照规范来写,非要自己写transfer函数,导致出现各种漏洞,给黑客以可乘之机,希望合约创建者以后能避免类似低级错误,不要给黑产以割韭菜的机会,我也是被割的欲哭无泪啊,说好的价值投资呢😢

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,445评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,889评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,047评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,760评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,745评论 5 367
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,638评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,011评论 3 398
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,669评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,923评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,655评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,740评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,406评论 4 320
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,995评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,961评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,197评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,023评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,483评论 2 342

推荐阅读更多精彩内容

  • 本文翻译自:https://github.com/ConsenSys/smart-contract-best-pr...
    tolak阅读 4,897评论 4 21
  • 斯里兰卡的维纳部族用树枝数目表示椰子数量。有些民族用“我”或者“月亮”表示“1”,用“眼睛”、“耳朵”或“...
    尽人事u听天命阅读 672评论 0 0
  • 1、小组成员在课题的选择以及自身团体的奉献态度相当积极,为了自己小组的荣誉争分夺秒的提出团队组合以及分工; 2、在...
    黑化大白阅读 190评论 0 1
  • 昨天学校让一年级出黑板报,当然这项工作也是落在家长的身上,从放学到板报画完天已经黑了。 没有交通...
    崇熙阅读 217评论 0 0
  • 爱真的需要勇气来面对流言蜚语只要你一个眼神肯定我的爱就有意义我们都需要勇气去相信会在一起人潮拥挤我能感觉你放...
    知否z阅读 419评论 1 1