NFT:当硬核黑客开始研究“钓鱼” 你的NFT还安全吗?

前有周杰伦无聊猿NFT被钓鱼攻击,损失超300万人民币。

后有全球最大的NFT交易平台之一OpenSea大批用户遭遇钓鱼攻击,多人资产受损。

可见Web3世界黑客依然猖狂作祟,为了打击黑客嚣张的气焰,我们将为大家持续输出干货系列文章,教导大家NFT防技巧。

本文研究了两类典型的NFT的钓鱼攻击,一类是盗取用户签名的钓鱼攻击,如:Opensea钓鱼邮件事件;一类是高仿域名和内容的NFT钓鱼网站。跟我们一起看看

「盗取用户签名的钓鱼」

2022年2月21日,全球最大的加密数字藏品市场Opensea遭遇黑客攻击。根据Opensea官方回复,有部分用户由于签署了给黑客的授权而导致用户NFT被盗。

我们将本次事件再次复现一下,在本次事件攻击事件中,攻击者信息如下:

攻击者地址:

0x3e0defb880cd8e163bad68abe66437f99a7a8a74

攻击者合约:

0xa2c0946ad444dccf990394c5cbe019a858a945bd

攻击者获得相关NFT的交易具体如下图所示:

FTX巴哈马混淆公司与客户资金,银行余额总计2.195亿美元:金色财经报道,FTX巴哈马清算人提交的法庭文件显示,FTX巴哈马分部FTX Digital Markets Ltd似乎将公司资金和客户资金混淆,其中约1.37亿美元的客户资产只受到有限的控制和治理,并没有被隔离。文件表示,在FTX Digital持有的2.195亿美元的总余额中,2150万美元已由清算人变现,另有5450万美元正等待移交给他们。另一笔存放在美国账户中的1.432亿美元已被司法部扣押,其他资金一直存在争议,直到巴哈马的破产在美国得到承认。[2023/2/17 12:12:02]

针对其中一笔交易进行分析,

0xee038a31ab6e3f06bd747ab9dd0c3abafa48a51e969bcb666ecd3f22ff989589,具体内容如下:

由上图可知,攻击者是获得了用户的授权,之后直接调用transferfrom方法将用户的NFT盗走。

Messari:第三季度NFT平均每月销售额不到10亿美元:金色财经报道,据Messari数据,以美元计算,ETH上NFT 8月的交易量比1月份下降了90%。NFT第三季度平均每月销售额不到10亿美元,而第二季度为46亿美元。

Messari称,虽然NFT日均交易量大幅下降,但日均交易者数量的降幅要小得多。这表明每天大约有40,000名忠实用户。[2022/10/2 18:37:18]

根据Opensea的CEODevinFinzer发布的twitter,攻击者是通过钓鱼的方式获取到用户在Opensea上的挂单授权。

通过分析攻击交易,黑客攻击主要分为以下三个步骤。

1.构造正确的待签名交易;

2.诱用户点击授权;

3.获取用户签名后构造攻击合约盗取用户NFT。

步骤一?

首先对攻击者构建的交易签名内容进行分析,跟踪函数调用栈发现具体的签名信息如下:

由上图可知,签名的计算方式为:keccak256("\x19EthereumSignedMessage:\n32",hashOrder(order));这种签名方式会在order前再加一个消息前缀:’\x19EthereumSignedMessage:\n32’,以确保改签名不能在以太坊之外使用。之后将加上消息前缀的完整数据再计算keccak256值,最后用私钥进行签名。

未平仓总量自12,510张下降至12,423张:8月22日消息,据KingData数据监控,CFTC8月10日至8月16日CME比特币期货持仓周报显示:未平仓总量自12,510张下降至12,423张。

机构多头头寸8,915张,空头头寸9,072张,多空持仓比例1:1,机构多空力量均衡,略微偏向看空;

大户多头头寸619张,空头头寸815张,多空持仓比例1:1.3,大户整体偏向看空;散户多头头寸1,202张,空头头寸849张,多空持仓比例1.4:1,散户显著偏向看涨。[2022/8/22 12:40:05]

但是该方式仅能声明所有权,无法防止重放攻击。如:用户A签署了消息发送给合约M,另一用户B可以将这个签名重放给合约N。下图为订单签名中具体涉及到的信息。

其中涉及到的签名主要参数为:

Side:买入或卖出

paymentToken:用于支付订单的代币类型

basePrice:订单中NFT的价格

maker:订单发出地址

taker:接收订单的目标地址

上述签名信息中包含订单金额、目标地址等敏感信息,但是经过keccak256计算Hash后的值只是一串二进制字符串,用户无法识别。

攻击者根据上述Order信息构造签名,可以随意将上述签名中涉及到的basePrice参数金额设置为0,接收地址设置为自己等。

步骤二?

攻击者构造好待签名数据后就可以诱用户点击授权。由于签名的元数据是经过Keccak256计算后得到的包含0x的66个十六进制字符,用户无法得知其代表的具体含义,因此可能直接点击签名,使得攻击者获得了用户的挂单授权。

数据:AscendEX攻击者将50万枚DAI转移到新地址:8月11日消息,Beosin统计数据显示,攻击加密交易所AscendEX的黑客将50万枚DAI转移至0x28开头的新地址。当前AscendEX Hacker 2地址余额为3565.9枚ETH和4325,402.58枚DAI。

此前消息,加密交易所AscendEX因黑客损失达7770万美元。[2022/8/11 12:18:30]

上图中的签名对于用户来说类似盲签,即所签的消息内容对签名人来说是盲的,签名人不能看见消息的具体内容。

步骤三?

在步骤二中攻击者获取到ECDSA签名消息中的R、S、V值,即可利用其构造攻击合约盗取用户NFT。下图为OpenSea:WyvernExchangev1合约中验证order的函数validateOrder(),具体源码如下:

由源码可知,订单验证首先会校验order的有效性和是否包含有效参数,接着校验订单是否曾经通过链上校验。其中approvedOrders是一个mapping变量,该变量保存了所有已经通过链上批准验证的订单。如果订单曾经校验过则直接返回true,无需再使用ecrecover()校验ECDSA签名,以便智能合约可以直接下订单。

外汇交易经纪商Oanda:若美国通胀有所缓解,比特币或将上涨:金色财经消息,Oanda认为,如果周三的CPI数据显示美国7月通胀有所缓解,比特币可能会上涨。Oanda分析师Craig Erlam表示,通胀数据走弱可能是比特币突破2.5万美元/枚的催化剂,并再次将目标锁定在2.8万至3.2万美元/枚区间,自今年夏初以来,比特币价格就没有在这个区间交易过。考虑到核心通胀率预计将上升,若整体通胀没有放缓,美联储将很难加息少于75个基点。(金十)[2022/8/10 12:13:47]

以下是其中一笔NFT盗取交易,可以发现攻击者利用用户签名通过调用攻击者合约:

0xa2c0946ad444dccf990394c5cbe019a858a945bd,以0ether的价格盗取了用户的NFT。

「高仿域名的NFT钓鱼」

这一类的钓鱼网站主要是对NFT项目官网的域名和内容等进行几乎一致的模仿,一般会先连接用户钱包查询用户余额之后,再进行其他诱操作。这种钓鱼网站是最常见的,主要分为以下几种类型:

1仅更换原官网的顶级域名

案例一

官网:https://invisiblefriends.io/

钓鱼网站:https://invisiblefriends.ch/

查看钓鱼网站的网页源码,可以发现如下攻击地址:

查看

0xEcAcDb9FA4Ed4ACD8977821737da7bCe688be1e0的相关交易:

可以发现上述两笔交易是攻击者获取到的收益。

案例二

官网:https://cyberbrokers.io/

钓鱼网站:https://cyberbrokers.live/

查看钓鱼网站源码,发现如下攻击地址:

综上,该类事件主要是因为用户在签署交易签名时,由于签署的交易内容是加密后的字符串,导致用户无法直观的看到签署交易的具体内容,习惯性的点击确认,从而造成攻击者获取到用户的卖单权授权,盗走用户的NFT。

2主域名添加单词或符号进行混淆

有的钓鱼网站会在主域名添加单词或符号进行混淆,比如othersidemeta-airdrop、otherside-refunds.xyz等。

官网:https://otherside.xyz/

钓鱼网站:http://othersidemeta-airdrop.com/

查看钓鱼网站源码,发现页面存在setApprovalForAll()函数,该函数会授权_operator具有所有代币的控制权。如果用户授权了攻击者,则用户账号中所有的NFT将会被盗走。

3添加二级域名进行混淆

有的钓鱼网站会添加二级域名进行混淆,进行钓鱼。

?

官网:https://www.okaybears.com/

钓鱼网站:https://okaybears.co.uk/?

查看网页源码,根据solanaweb3的官方文档API,确认如下地址为攻击地址:

在如今钓鱼事件频发的情况下,用户需提高安全意识,保护自己。以下是我们的安全建议:

1签名时应当明确签署的交易内容,包括交易价格、交易地址等信息,如下图红框处内容所示:

如果存在签署内容仅为二进制字符串内容等无法明确的内容,请勿签署。

2切勿点击任何邮件中的链接、附件,或输入任何个人信息。

3访问NFT官网时,一般在官网右上角等处会显示官方twitter、discord等社交帐号,需在官方账号上确认官网地址。

4安装钓鱼插件,可辅助识别部分钓鱼网站。比如下面这一款

https://chrome.google.com/webstore/detail/beosin-alert/lgbhcpagiobjacpmcgckfgodjeogceji?hl=zh-CN

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

地球链

比特币WEB:WEB3到底长啥样?

最近有关WEB3的事件越来越多、越来越大,一篇《WEB3.0与中国无关》的文章上线两小时就火遍全网,然后消失;著名投资机构A16Z已投资超过90个WEB3项目.

聚币DAO:DAO 如何应对合规挑战?

FWB、BanklessDAO、GitcoinDAO、MirrorDAO等等顶流DAO,目前都在探索如何解决合规问题。为啥DAO要有个法律实体?2022年,各个DAO纷纷成立法律实体.

[0:15ms0-1:35ms