区块链:安全为心 浅谈LGC公链是如何应对黑客攻击的

随着智能合约飞速发展,越来越多的项目基于以太坊发行Token,链上资产的类别和规模呈指数级增长,“虚拟世界”中的数字资产也点燃了黑客们的“热情”。以太坊区块链被认为是区块链的2.0时代,各种各样新的数字资产都基于以太坊发行早期代币甚至实现部分功能,虽然国外区块链社区甚至认为以太坊体量变得太大,已经不可轻易战胜,但以太坊也是数字货币历史上产生最多安全问题的币种。

从2016年的TheDAO事件,到BEC,EDU,SMT的安全漏洞,到Defi代币失窃事件,以太坊的智能合约可以说充满安全漏洞。大多数的代币都在自己主网上线前使用以太坊代币,作为投资者,为了自身资产的安全着想,熟悉智能合约的漏洞概念变得尤为重要。

黑客利刃砍出的ETH和ETC

TheDAO作为世界上最大的众筹项目,一度被寄予了厚望,所谓“成也萧何,败也萧何”,智能合约一度被捧上了天,但在TheDAO事件当中,其递归调用的漏洞却成为了黑客入侵的大门。此后出现“黑客”现身谈攻击合法性的戏幕,更是让人大跌眼镜,这第一次引出了智能合约代码监管的问题。

港股上市公司博雅互动:董事会已批准500万美元预算购买加密货币:8月11日消息,港股上市公司博雅互动公布董事会已批准 500 万美元(约合 3909.8 万港元)预算,用于集团在未来一年内于受监管以及许可的交易平台购买加密货币,主要包括比特币(BTC)及以太坊(ETH)。

博雅互动表示,集团进行有关加密货币购买的资金来源为集团于香港及海外营运所产生的现金储备。有关加密货币的购买,集团将根据市场情况酌情执行。本次加密货币的购买,旨在为集团未来在 Web3 领域业务布局之考量。[2023/8/11 16:19:47]

2016年6月17日发生了在区块链历史上留下沉重一笔的攻击事件。由于其编写的智能合约存在着重大缺陷,区块链业界最大的众筹项目TheDAO(被攻击前拥有1亿美元左右资产)遭到攻击,导致300多万以太币资产被分离出TheDAO资产池TheDAO编写的智能合约中有一个splitDAO函数,攻击者通过此函数中的漏洞重复利用自己的DAO资产来不断从TheDAO项目的资产池中分离DAO资产给自己。

鲸鱼自2月底以来已经购买了超过11亿枚的XRP:金色财经报道,推特用户Ali发文称,支持Ripple的鲸鱼自2月底以来已经购买了超过11亿枚XRP,价值约5.7亿美金。[2023/7/9 22:26:44]

被攻击后,Vitalik个人支持分叉的提议,也支持软分叉的开发工作,支持矿工升级客户端来进行分叉。然而Vitalik也认识到大家对这个提议有激烈的争论,无论哪一方的观点都有强力的反对。因为分叉不需要回滚交易,不会对用户和交易所造成不便,这更使Vitalik倾向于采取行动的一方。也有许多人,包括在基金会内部,倾向于另外一方反对分叉。Vitalik不会阻止也不会反对另一方在公开场合宣传他们的观点,甚至是游说矿工来抵制这个分叉。在这件事情上Vitalik会坚决的不与任何站在相对他的另一方的人争辩。

简而言之,他们所做的是更改以太坊区块链来修正DAO,但只有当大部分运行以太坊区块链网络的计算机同意,软件才能进行更新,摆脱掉漏洞,就好像攻击从来没有发生过。这一过程被称为硬分叉,从此以太坊创造了一个平行世界,现在的以太坊其实是分叉出来的“以太坊”并在一年后狂飙突进的涨到了几百美元,而原来不愿意分叉的包含TheDAO漏洞的以太坊则成了以太坊经典。这一决定引发了强烈的反应,一年后仍然存在争议,无论是在以太坊社区还是比特币用户都坚持区块链的历史不能被篡改,有些比特币用户认为硬分叉在某些方面违反了最基本的价值观。

IMF:加密货币的广泛使用或会导致银行失去存款并减少贷款:金色财经报道,国际货币基金组织 (IMF) 已警告G20国家,加密资产的广泛使用可能导致银行失去存款并减少贷款。报告称:“加密资产的广泛使用给货币政策的有效性、汇率管理、资本流动管理措施以及财政可持续性带来了巨大风险。此外,央行储备和全球金融安全网可能需要改变,从而带来潜在的不稳定。最后,银行可能会失去存款,不得不减少放贷。”该报告还指出,“尽管具体风险的重要性和相关性因国家情况而异,但加密资产存在许多风险。”不过,尽管存在“显着风险,加密资产已经开发出公共部门可以利用的技术来实现其自身的政策目标”。[2023/3/13 13:00:35]

Binance黑客VIA事件

2018年在3月7日深夜,有不少用户发现自己币安账户中持有的各种各样的代币、数字货币被市价即时币币交易成了BTC。据网友反馈,被盗的账号不在少数,不少人还以为是币安系统错误导致的,还试图从币安客服那里得到解释。当他们还没有反应过来的时候,黑客已经开始了他们有组织、有预谋的行动。

Near Protocol启动“区块链操作系统”以关注用户体验:金色财经报道,Near Protocol联合创始人Illia Polosukhin在ETHDenver行业会议上宣布,L1区块链网络Near Protocol推出了一个产品优先的操作系统,开发人员可以在该系统中构建,用户可以将其作为一个平台进行交互。根据Polosukhin的说法,该平台旨在充当浏览和发现Web3产品的公共层,包括加密货币交易所、NFT画廊和社交网络。Polusukhin在接受采访时表示,该框架将与所有区块链兼容(目前支持Near协议和以太坊虚拟机链),Near将充当通用入口点。

根据新闻稿显示,对于开发人员来说,去中心化和可组合的前端提供了一种构建和启动更好的应用程序以及更快地分叉现有部分和组件的方法,同时利用配置文件、支付和通知以及搜索等内置功能,而无需自己托管任何东西。[2023/3/3 12:39:24]

黑客启动了所有盗窃的账户的买卖引擎,买卖规则就是卖掉所有山寨币,用市场价全仓购买VIA。而恰好黑客手里持有大量VIA,这样就相当于高价购买了黑客手里的VIA。于是,VIA的K线出现了惊人的振幅:2分钟内爆拉了110倍。从交易量和拉升价格来看,有大约1000个BTC的买单,把VIA的价格从0.000225btc拉到0.025,价格上涨大约110倍。

Aptos生态钱包MartianWallet下载量突破10万次:8月23日消息,Aptos生态钱包MartianWallet官方推特表示,其应用下载量突破10万次。目前该钱包还在测试阶段,已与Aptos名称服务集成,允许用户使用Aptos名称发送交易。[2022/8/23 12:42:15]

但是黑客的行动触发了币安的预警系统,黑客没能直接提出高价卖出所得的比特币。于是他们转而以超低价格爆砸比特币现货的订单列表,引起其他交易所期货价格的连锁反应。于是黑客预先埋伏的巨量空单获得巨大收益。黑客的攻击,已经去中心化了。

LGC的安全设计

由于货币需要一个稳定的系统,智能合约设计的越复杂出错的可能性就越高,所以在早期中本聪认为货币系统是不需要图灵完备的语言的,比特币之所以不支持智能合约也是觉得货币需要极高的稳定性。那么,如何运行区块链里保持货币稳定的同时又可以开发Dapp呢?

在LGC中Token链是一个并行多链的结构,共享用户基础。作为一个DAPP开发者最关心的肯定是三件事:1开发难度2用户体验3社区生态。那么Token链的设计就是针对不想自己重新开发一条公链,但想要发行token和链的开发人员。

LGC生态主要面向的对象是开发者,所以在设计Token链的时候最大的想法是设计一个可以吸引大家都来发币的平台,这样可以让在LGC上开发DAPP的开发者可以获得更多的用户资源。

LGC的中心思想是设计一个社区的机制,让开发者可以轻易的开发一个DAPP,其他的交给LGC来处理,安全问题当然也是LGC在设计之初考虑的重点。

比如近期对很多项目发起攻击的“transferFrom“函数,LGC就在require(balances>=_value);下一行增加了require(allowance>=_value);?判断,确保了合约转账不会出现可供黑客利用的漏洞。

Token不应该是一个智能合约,而应该是一个预先定义好事件的一个“对象”,这个“对象”可以有自己的参数,接受Token的地址可以有两种:普通的用户地址和合约地址,合约地址收到Token之后可以执行非图灵完备的合约语言,进行简单的状态计算和Token转移。

公链是区块链发展的前提基础,也是区块链行业未来发展的核心保障。而目前区块链的发展现状是,底层公链的性能尚未发展起来,在其上构建的各类DAPP严重受限于性能,各种共识算法都有不完美之处,安全问题也令人堪忧。由于智能合约一旦上传,即公开且不可更改,因此大多“区块链2.0”项目有安全性验证的需求。一些团体也开始致力于应用形式化验证技术,为智能合约和区块链生态提供安全保护。将智能合约转化为数学模型,通过逻辑上的推理演算来验证模型,从而证明智能合约的安全性。

但由于智能合约是“不可变更的”。一旦部署,它们的代码是不能更改的,导致无法修复任何发现的bug。在潜在的未来里,整个组织都由智能合约代码管控,对于适当的安全性需求巨大。过去的黑客如TheDAO或BEC,SMT,EDU,BAI等漏洞事件提高了开发者们的警惕,可我们还有很长的路要走。

各个公链在可扩展性,应用性,共识哲学以及安全建设上的角逐将持续很长一段时间。我们认为既然没有完美的防止漏洞的方法,那我们不妨学习LGC,让Token这个“对象”尽可能的简洁,是现阶段区块链行业里比较好的解决方案。

来源:金色财经

郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。

地球链

[0:0ms0-0:781ms