BEC、SMT智能合约安全漏洞,YEE团队独家解析

YeeCall团队·2018-04-26 16:13
BEC、SMT接连暴露智能合约漏洞,YEE技术团队独家解析如何避免此类漏洞
mt
股权融资广东省2016-08
GK俱乐部是一家电竞俱乐部。
我要联系

今天,BEC、SMT的智能合约漏洞给很多区块链从业者带来了恐慌。我们先来看看案发现场

黑客利用BEC漏洞创造出巨额token

黑客利用SMT漏洞创造出巨额token

YEE区块链团队第一时间查阅了BEC、SMT的代码,BEC的合约漏洞是BatchTransfer漏洞中的数据溢出,SMT的合约漏洞是代理转账逻辑中没有进行大数保护,造成大数溢出,这两个问题的根本原因是没有使用library SafeMath,使用了普通的加减乘除。

比如BEC漏洞中这个乘法没有使用library SafeMath,而是用了“*”,这就造成了数据溢出。

BEC代码直接使用“*”

同样道理,SMT的智能合约的错误代码没有使用官方的library SafeMath,而使用了普通的“+”,这造成了在代理转账逻辑中没有进行大数保护,最终造成大数溢出。

SMT代码使用了“+”

正确的方式应该像YEE智能合约的这段代码,使用library SafeMath函数来编写智能合约代码,这样可以保证代码的安全稳定。

YEE使用SafeMath函数的代码

现在发现的漏洞中有很多代码是因为直接使用普通的加减乘除符合,同时缺少溢出判断,这就造成数据溢出的隐患,而使用library SafeMath可以彻底解决数据溢出的问题。因此,解决方案也很简单,彻查智能合约代码,把“+”“-”“*”“/”换成library SafeMath,这可以彻底解决数据溢出的问题。

YEE也在这里希望所有区块链从业者在关注出席会议、媒体曝光的同时,应将更多注意力关注到技术层面,只有安全的技术才能保障区块链产品的正常运行,让更多人享受到区块链带来的各种服务。YEE落地产品YeeCall这个产品本身就面临着巨大的技术挑战,我们在全球布网,从零建设起了一张拥有5个数据中心、400多个中继节点的覆盖全球的通讯网络,这张网络一度被AWS、澳洲电信称之为全球通讯网络的“最后一公里”。为了解决手机端通讯的复杂环境和超多终端支持问题,我们除了一行一行代码敲出了完全拥有自主知识产权的通讯协议,还创造性采用人工智能的方法来解决噪音消除问题,所有这一切,都是为了让广大的YeeCall用户体验更好,与家人和朋友的沟通更紧密。我们热爱技术,拥抱区块链,也欢迎Java、服务器、Android、iOS、区块链技术方面的有识之士加入YEE团队,共同打造区块链的美好未来,邮箱:dream@yeecall.com


+1
3

好文章,需要你的鼓励

参与评论
评论千万条,友善第一条
后参与讨论
提交评论0/1000

作者有点忙,还没写简介

报道的项目

mt
我要联系
GK俱乐部是一家电竞俱乐部。

下一篇

谁该对矿难负责,谁在监管面前虚晃一枪,谁又在背离或曲解区块链的精神?

2018-04-26

36氪APP让一部分人先看到未来
36氪
鲸准
氪空间

推送和解读前沿、有料的科技创投资讯

一级市场金融信息和系统服务提供商

聚焦全球优秀创业者,项目融资率接近97%,领跑行业