原文來源:老雅痞
作為一個NFT收藏家,你應該關心鏈上的合約出處,NFT最真實的出處是直接從創造者的錢包或創造者擁有的智能合約中鑄造出來的。然而,通過一些小技巧,有人可以使用一種被稱為"SleepMinting"的技術來操縱NFT的創作者來源。
SleepMinting是指詐騙者直接將NFT鑄造到一個著名的創作者的錢包,并從創作者的錢包中回收NFT。
這就造成了這樣的假象:
(1)創作者自己真實地鑄造了一個NFT;
(2)將該NFT發送給了一個騙子;
基于"鏈上"的出處,騙子可以聲稱他們擁有一個著名創作者鑄造的NFT,并以更高的價值出售。
這在技術上是如何運作的?
首先,了解智能合約如何存儲NFT的出處和所有權是至關重要的。任何人都可以使用ERC-721標準中的ownerOf(tokenId)函數查詢NFT智能合約,以確定NFT的當前所有者是誰。你甚至可以通過改變eth_callRPC方法參數來查詢特定區塊編號的NFT所有者。然而,查看所有權變化的最簡單方法是查看ERC-721傳輸事件日志。
a16z Crypto總法律顧問:Kraken與SEC達成和解不會影響其他交易平臺:2月10日消息,a16z Crypto總法律顧問Miles Jennings針對Kraken與SEC達成和解一案發表評論稱:質押對生態系統來說非常重要,質押即服務項目既合法,也允許更多人參與區塊鏈技術。我們認為這一和解協議將不會對已制定計劃不涉及證券法的交易平臺產生任何影響。
作為Web3的重要投資者和正在建設下一代互聯網的企業,a16z對Gensler主席繼續證明他只知道如何通過零星的執法案件進行監管感到失望。距離美國證券交易委員會(SEC)上一次發布與加密貨幣相關的指導意見已經過去了四年,其主席繼續專注于上頭條,而不是根據SEC的核心使命保護投資者。現在是他優先考慮規則和指導的時候了,這些規則和指導將使市場更加清晰,并積極主動地保護公眾。[2023/2/10 11:58:45]
我的a16zCrypto同事DarenMatsuoka在Twitter上寫了一篇關于事件日志和它們如何工作的精彩文章。轉移事件日志是由智能合約向外界發送的消息,包含關于NFT轉移的細節。轉移事件日志提供了一種有效的方式來檢查NFT的來源。
即將離職的a16z合伙人Katie Haun尋求為加密投資基金籌集9億美元:1月7日消息,據英國《金融時報》報道,即將成為Andreesen Horowtiz(a16z)前合伙人的Katie Haun(Kathryn Haun)正尋求在離職后為兩只加密投資基金籌集至少9億美元的資金。
知情人士稱,Haun的目標是為一只針對加密初創公司的早期投資基金籌集3億美元,為一只專注于大型公司和數字代幣的基金籌集6億美元。
在上個月宣布將離開a16z后,Haun表示將創辦自己的風險投資公司“KRH”。2022年1月,NFT市場Opensea以133億美元投后估值完成3億美元融資,KRH參投。(CoinDesk)[2022/1/7 8:32:41]
Sleepminting
這是beeple的數百萬美元的作品"First5000Days"在rarible上出售。看看截圖,上面清楚地寫著"創造者:
a16z合伙人:不能因Web 3和加密新興技術存在缺陷就徹底限制:11月24日消息,a16z合伙人Chris Dixon在推特上發文表示,不能因為當前新興技術存在缺陷就反對新興技術發展,任何重要技術運動都需要經歷很多年時間過程,善意的批評可以改善技術,需要將“暫時出現的缺點”和“徹底限制”區分開,尤其是Web 3和加密,現在的確存在交易費用過高、能源消耗過大的問題,這是該新興技術的暫時缺陷,但出于不同發展階段,我們可以思考更多解決方案,但不能把“暫時缺陷”視為徹底否認新興技術的理由。[2021/11/24 7:08:49]
但這是個騙局。它的創造者MonsieurPersonne,也自稱是NFTs的Banksy,故意用beeple的名字鑄造了這幅作品,他使用了一種叫做sleepminting的技術。那么他是如何做到的呢?
基礎知識
NFTs是使用ERC-721智能合約創建的,他們把NFTs的所有權記錄作為一個列表。一個地址和一個作品的序列號組成一個對。像這樣。
AI流動性策略開發團隊Kosen Labs完成500萬美元種子輪融資,a16z 領投:11月17日消息,由前谷歌 DeepMind 人工智能研究人員Miljan Martic和Peter Toth建立的去中心化AI流動性策略開發團隊項目Kosen Labs宣布完成由 a16z 領投的500萬美元種子輪融資,Framework Ventures 等參投。
Kosen Labs希望將AI帶入到Web3領域中,將專注于為下一代自動做市商(如Uniswap V3 和 Sushiswap Trident)提供主動流動性提供解決方案。另外,Kosen Labs 將組建Kosen基金會,并將發布DAO治理代幣。Kosen Labs 將作為基金會的一部分提供有效的LP策略和AI解決方案。[2021/11/17 6:56:20]
Alice:1
Booble:2
Malory:3
成交后,Alice可以通過以下方式將她的NFT轉讓給Booble。
轉讓1:Alice==>Booble
現在列表更新如下:
Alice:
Booble:2,1
Malory:3
在以太坊,我們用地址名字來識別,而且我們需要簽署轉賬來授權。但是在這篇文章提供的例子中,我將使用明確的名字來簡化解釋。
現在,通常開發者以合理的方式實現ERC-721合約。Alice只有在她擁有一個NFT并能提供有效簽名的情況下才可以轉讓。
ERC-721標準只是一個社會契約,它定義了一個允許藝術平臺互操作的接口。只要合同的接口與ERC-721合同的接口相匹配,任何機器都會認為它是有效的。
但是,正如我們現在所看到的,這可能會導致以太坊上的NFTs出處出現安全問題,它是可以被篡改的。
正如我所說,任何合理的ERC-721合約都會允許礦工只為自己造幣,并且只轉讓他們擁有的碎片。
但是,假設我們定制了我們的ERC-721合約,使我們可以向其他賬戶鑄造。假設我們調整了轉讓功能,使我們的賬戶在某些情況下,也可以轉讓另一個人的NFT。那么,我們就可以建立一個允許我們sleepmint的合約。
舉例:作為攻擊者Malory,我們給Booble鑄造一個序列號為1的作品。
mint1:address(0)=>Booble(由Malory執行)
現在我們的配對看起來如下:
Alice:
Booble:1
Malory:
然后,由于Malory已經調整了合同,將序列號為1的作品從Booble的賬戶轉移到任何其他賬戶,她可以在像rarible這樣的NFT平臺上提供出售。
由于她從地址(0)到Booble的鑄幣為"創造者--Booble"被顯示出來。
一旦Malory成功詐騙了一個買家,她就會收到她的"Ethers",并將假冒作品賣給買家。
轉讓1:Booble=>買方。
更新后的所有權記錄現在是這樣的。
Alice:
Booble:
Malory:
Buyer:1
就這樣,Malory成功地篡改了NFT的創作出處記錄,以高于其價值的價格出售了她的作品。
具體細節:
仔細查看rarible和Etherscan的信息,我們會發現這更像是一個接口問題,而不是一個安全漏洞。沒有人能夠進入beeple的賬戶。
另外,當仔細看一下交易記錄時,可以發現騙子的手法:
偽造的mint交易
偽造的轉賬交易
對于mint交易,我們可以看到Etherscan顯示兩個"From"字段。一個是msg.sender發送的交易,另一個是說明NFT的發件人。
對于交易的發件人字段,即msg.sender,它不能被人為操縱,因為它需要發件人的私鑰的有效簽名。然而,對“TokensTransferred”的字段的授權受制于智能合約的漏洞,因此,可能會人為操縱。
簡單地說,騙子可以對“TokensTransferred”字段進行任意修改。
因此,我們必須檢查From和TokensTransferred是否都與beeple的正確地址相符。如果不是,那就是假的。
這種攻擊它與"rugpull"類似,有人認為區塊鏈使web2問題都消失了,因為每一個數據都是經過認證和檢查授權的。但事實是,這些問題并沒有消失。它們只是轉移到了別的地方。
NFT?數據日報是由Odaily星球日報與?NFT?數據整合平臺NFTGO.io合作的一檔欄目,旨在向NFT愛好者與投資者展示近24小時的NFT市場整體規模、交易活躍度、子領域市占比.
1900/1/1 0:00:00項目名稱:Zebec(ZBC)項目概況:Zebec是一項革命性的DeFi技術,可實現實時、無摩擦和連續的支付流.
1900/1/1 0:00:00尊敬的WEEX用戶您好!早春活動百萬交易員征集令 活動四:天天空投 活動方式: 活動期間每天抽出10位有完成合約交易的用戶隨機送8、18、38、68、88USDT,周一至周五不限幣種.
1900/1/1 0:00:00據LiveBitcoinNews消息,Coinbase的高管和員工近日表示,所采取的行動與戰爭無關,而是為了打擊數字貨幣行業的欺詐和非法行為.
1900/1/1 0:00:00原文作者:ChristopherHarland-Dunaway原文標題:《THEMANYESCAPESOFJUSTINSUN》 原文編譯:胡韜.
1900/1/1 0:00:00親愛的用戶:AAX聯合Coinify推出0手續費活動。時間有限,通過Coinify買幣,可享0手續費。*0Coinify手續費包括所有銀行手續費,卡相關手續費和服務費.
1900/1/1 0:00:00