買以太坊 買以太坊
Ctrl+D 買以太坊
ads
首頁 > 屎幣 > Info

GAS:源碼解讀:你買的NFT到底是什么?_GINTO價格

Author:

Time:1900/1/1 0:00:00

如果你是WEB3加密界的新手,面對眾多概念無從入手,那么歡迎你,來對地方了!!

本文圍繞標準?ERC721協議,描述了Mint、?safeMint、?transfer等是如何實現資產管理的,并通過解讀代碼來了解它的安全性設計和以太坊數據上鏈成本構成。

1.所謂NFT資產是什么?

2.Mint和safeMint的差別

3.交易時會發生什么?有哪些細節設計

4.NFT哪些數據也存儲在鏈上?

5.以太坊上存儲有多貴?

Web3新手,有無技術背景均可:

研發——可無障礙閱讀,理解精美的合約設計

非研發——可能讀不懂列舉的代碼,但能體會標準協議的設計思路

在opensea上,可看到每個NFT都有個唯一的編號。

比如azuki系列中第4132號,在頁面的Details欄目可以看到其合約地址,ID編號,部署所在公鏈等信息,而Properties欄目則是其設定的具備各種屬性,對應的稀有度(非azuki本身攜帶,而是opensea整合計算的)。

而咱們回顧到源代碼(此處取ERC721標準庫openzepplin代碼),會發現程序記錄了全局性的兩個字典類型的變量,通過?_owners中用數字映射地址的方式記錄每一個ID?當前對應的所有者,同時也附帶用_balances?記錄了當前所有者總計持有的NFT數量

Infura宣布其IPFS產品將于2023年1月9日進行必要維護:12月24日消息,Infura宣布,IPFS產品將于2023年1月9日進行必要的維護。這會影響任何與pins的API交互,特別是 /api/v0/add;啟用“僅顯示固定內容”安全功能的專用網關。Infura估計該服務將部分不可用約30分鐘。[2022/12/24 22:04:20]

并且由于ERC721創新性的賦予了一個ID對應地址的變量?_owners,從而與ERC20僅_balances?進行地址與余額的管理,區分出了FT(同質化)與NFT(非同質化)的差別。

Mint?意思為鑄造,即每個NFT的創造過程,例如之前的愛死機NFT?當奈飛的NFT忘記了web2的業務安全

Mint?獲取到該NFT的資產證明。

從源代碼中可以看到,Mint?主要是進行了安全判斷:

判斷1:確保轉入的不是0x00地址(黑洞地址無法轉出,轉入則資產損失)

判斷2:確保此交易所操作的NFTID是不存在的

最終代碼執行的操作是:

操作1:將轉入地址的_balances?所持有總數加1

操作2:將對應?NFTID?的所有者修改為轉入的地址

通駿說鏈:FTX破產后流動性變得更加集中,或是更大風險的體現:金色財經報道,在Metainsight主辦的以“FTX事件冷思考:客戶資產如何安全管理”為主題的Metainsight圓桌匯上, WEB3博主通駿說鏈表示,FTX爆雷是多個事件疊加的一個結果,它不單是幣圈的事情,整體事件的形勢、俄烏戰爭及美國經濟影響的疊加,使整個市場流動性缺失。幣圈資金的抽走,導致Luna和FTX事件,其實現在還有很多機構也沒有披露在Luna和FTX上損失有多少。

很多難以預測的隱患,尤其是DeFi和借貸類項目很難估計它的情況,比如最近的Genesis。但我們觀察到衍生品市場的情況,影響也是巨大的,在去杠桿的過程中,尤其是合約期權以及NFT,從頭部開始,整體流動性本身就很枯竭現在變得更加枯竭,FTX暴雷之后或許還有很多雷吧。在FTX消失后,機構籌碼流向頭部交易所,使得頭部交易所一家獨大,流動性變得更加集中,這或許是更大風險的體現。[2022/11/20 22:08:24]

操作3:完成交易則發出emit?事件,可以讓鏈下監聽到這次交易的數據

中間有_beforeTokenTransfer和_afterTokenTransfer 屬于虛函數,作為標準,是讓項目方可以再不修改標準協議的情況下增加一些特定的邏輯代碼用的。

Binance調整FTT U本位永續合約維持保證金率,最高杠桿降為20倍:11月8日消息,據官方公告,Binance合約將于2022年11月08日16:30(東八區時間)調整FTT U本位合約維持保證金階梯,調整內容包含維持保證金率,最高杠桿倍數從25倍降為20倍。請用戶參考更新后的維持保證金階梯限額進行下單;對于已開倉的訂單,請用戶提前調整倉位和保證金,以避免強制平倉。(Binance)[2022/11/8 12:32:42]

safeMint 意為安全的鑄造,從代碼實現中可以看到他本身也是調用了MInt 但是他額外增加了_checkOnERC721Received 的判斷,這點是屬于ERC165的標準,相當于在完成轉入操作后,則判斷對方地址,是否是黑洞地址(即無法發起交易NFT操作的地址)是防止轉入對象為合約地址時候,其合約沒有預設置好轉出的函數,導致資產在內無法被轉走,從而造成永久損失。

設計初衷可見:https://eips.ethereum.org/EIPS/eip-165

是讓合約接口標準化的提案,在編程語法中interface 是接口的意思,在其中定義的函數可以不實現僅僅放上函數名字相關參數,在程序復雜的時候,相當于目錄一般告訴別人我都有什么功能。

但是接口的寫法各有千秋,名字定義參數類型,甚至是否存在都有不同,

埃及央行:違反加密交易禁令最高罰款約358萬人民幣:9月13日消息,埃及中央銀行 (CBE)發布聲明表示,正在通過一些區域和國際平臺跟蹤加密貨幣交易的現象。埃及央行警告說,任何違反加密交易禁令決定的人都可能被處以100萬至1000萬埃及鎊(約358萬人民幣)的罰款。

埃及中央銀行再次警告不要與所有類型的加密虛擬貨幣進行交易,因為其風險很高,包括其價值大幅波動,并被用于金融犯罪和電子盜版,此外,它不是由中央銀行或任何官方中央發行機構發行的,因此,它缺乏任何物質保障來確保貨幣的穩定和保護其交易商的權利。(Egypt Independent)[2022/9/14 13:27:48]

所以此提案最終形成了ERC165標準,規范了接口的識別規則。

使用流程是:

STEP 1?判斷是否存在?supportsInterface?函數,并且其符合165標準

STEP?2通過?supportsInterface?函數,判斷是否具有轉出NFT的函數

(PS:讓合約具備NFT接收轉出功能,可通過引入?IERC721Receiver.sol?拓展包來實現)

標準協議設計有兩種轉移方式,transfer?和?transferFrom,作用于兩種場景:

比特幣礦企Marathon Digital二季度虧損1.92美元:8月9日消息,比特幣礦企Marathon Digital在第二季度虧損1.92美元,高于2021年第二季度的1.09億美元凈虧損,此外其在第二季度開采了707枚比特幣,比上一季度減少了44%,同時持有的比特幣儲備本季度還減值1.276億美元。

金色財經此前消息,本月初Marathon Digital完成1億美元信貸額度再融資,Silvergate Bank參與。[2022/8/9 12:11:33]

transfer 轉移:由用戶調用,將本消息發送的錢包所持有的NFTID轉移到指定地址

transferFrom 從轉移:用某機構調用,需要用戶先授權某地址,讓其有權可轉移。

類比一下:

transfer?就是現金交易,從自己口袋里拿錢支付

transferFrom?就是掃碼扣款,由店家申請扣款,受制于用戶是否開通小額代扣權限

接下來咱們從代碼來看看,其中可能有會意想不到的細節。

他會檢測當前交易的?from?方是否是此NFTID的持有者,并且限制該NFT轉入0x00地址。其次進行?from?轉出地址和?to?轉入地址的余額刷新,修改?_balances全局變量并且重新設置_owners此NFTID的所有者地址修改為to。

這里有個防護的細節會先執行_approve(address(0), tokenId);? 清空歷史授權,如果沒有這一步,則資產完成了轉移,但是其NFTID的轉移授權依舊在,細思極恐:

這里的交易本質調用的是_safeTransfer 所以他的核心邏輯是require 部分,

這的一大細節是:_msgSender() ? 這是openzepplin的標準庫Context.sol 中的方法。

其實就是獲取當前交易的發送者地址,但這里使用了封裝版本,而不是直接使用msg.sender

是考慮到,可能存在一種交易類型“元交易” ,即交易的付費gas方和交易發起方不相同的情況。

所以一些處于中間環節的,類似library的合約需要考慮這種特殊情況。

其余部分判斷是確定是否有授權記錄,易于理解,不作贅述

交易的環節也看完后,其實很多新同學也頓感奇怪,原來我買的NFT只有一個ID的歸屬地址指向了我,從而達成了唯一性。那就算如此,稀有度信息放在哪里?我的NFT圖像本身在那里?

這就是涉及到ERC721的元數據拓展IERC721Metadata.sol

要放什么都可以,但是項目方往往在鏈上只存儲最基礎的ID+IPFS的地址。

咱們可以通過之前Etherscan教程方法來看看一些項目數據有什么?

Azuki上合約地址是:0xed5af388653567af2f388e6224dc7c4b3241c544

通過Read Contract可以查閱到,其元數據只存放了ipfs上的指向地址

而近期興起的Metaverse項目元宇宙土地sandbox和****Decentraland ,以及去年火熱的****Axie Infinity ,基本鏈上存儲元數據也只是ID+網址。

像mirror那些是專門設計低費用可進行高存儲,一個塊常規都是30M起步,大約是以太坊的1000倍。

這里是本文稍難的地方。咱們從源碼來分析鏈上存儲的成本構成以及金額換算

成本產生將有2個方面,按執行流程來看

用戶發起一筆交易,將要寫鏈上數據作為參數傳入,其大小是一筆成本

交易執行合約代碼,依據修改和使用,EVM計算消耗的gas成本。

咱們可以核對下以太坊黃皮書,里對交易數據大小所消耗gas有清晰的定義

可以看到交易所附帶的參數的價格:

每筆交易都有21000 GAS需要支付

為交易的每個非零字節數據或代碼支付68 GAS

為交易的每個零字節數據或代碼支付4 GAS

所以如果是再?Mint?的時候,登記上若干NFT屬性信息,交易的data部分會將abc等字符轉成2個十六進制表示,而每個字符為一個八位二進制,等于一個byte。所以可以約等于將data的長度除以2作為byte數。

而1kb的數據,如果都是非0的有信息量的文本信息,則等于增加是68*1000=6.8W 的gas消耗。按20gwei的gas價格和2000的eth兌換美元價格,可以估算出,每上鏈1kb數據在交易發起端就要:

20*(21000+68000)*1e9/1e18 * 2000 =?3.5美金

由于交易發起后,還有智能合約上存儲的邏輯,咱們從以太坊go源代碼中(EIP1283),來分析具體的消費量,代碼具體在函數內,太長了不全粘來:

func?gasSStore(evm *EVM, contract *Contract, stack *Stack, mem *Memory, memorySize uint64)(uint64, error)

歷史上GAS消耗的估算有經過若干迭代,如果是Petersburg或者 Constantinople 未激活的話,則不按下面邏輯進行計算

gas消耗計算,依賴3個種數據的管理形式(增刪改)

從零值地址到非零值(NEW VALUE),每個存儲槽需消耗2Wgas

從非零值地址到零值地址(DELETE),每個存儲槽需消耗5Kgas,但會有獎勵1.5W gas退回

從非零到非零(CHANGE),每個存儲槽需消耗 200 gas

注意,上述每一個存儲槽算32byte,1kb存儲則是32個存儲槽。Mint?的過程是新增存儲,所以如果新增1kb的數據存儲在鏈上代價將是64Wgas,換算成金額則是:

20*(640000)*1e9/1e18 * 2000 =?25 美金

真可謂寸土寸金!

Tags:NFTGASINTTRAMANEKI Vault (NFTX)NAGASWAPGINTO價格METRA

屎幣
COI:我們在元宇宙中的身份會是什么樣子?_Bitcoin Metaverse

我們在元宇宙中的身份會是什么樣子?去中心化的Web3表明它將完全在我們的控制之下,但存儲在網上的信息表明情況并非如此.

1900/1/1 0:00:00
CRYPTO:佳士得、蘇富比等頂級拍賣行紛紛入局NFT拍賣 這會是門好生意嗎?_數字藝術

2021年3月11日,一副名為《每一天:前5000天》的NFT數字藝術品在英國拍賣行佳士得,以6935萬美元成交,約合人民幣4.5億元.

1900/1/1 0:00:00
LAYER:以太坊合并 如何影響顯卡和區塊鏈行業?_以太坊

引言 本文為5月27日晚《Metaverse Insight首期交流——以太坊合并的影響》交流的會議紀要,會議主要討論了ETH升級合并將帶來的影響.

1900/1/1 0:00:00
TIMI:金色前哨 | 以太坊L2網絡Optimism上線多家交易所:鎖倉量躍至前三_OPTCM價格

自以太坊擴容方案Optimism于4月底宣布發行代幣OP并公布代幣經濟學以來,市場對于OP的關注持續火熱。隨著5月31日OP推出并上線多個中心化交易所,市場熱度再次高漲.

1900/1/1 0:00:00
數字資產:金色觀察 | 監管權交給CFTC?美國兩黨首次嘗試為數字資產建立全面監管框架_穩定幣有哪幾種

在一系列備受矚目的破產和失敗之后,兩黨參議員公布了監管加密貨幣和其他數字資產的最廣泛立法提案。在周二,美國參議員Kirsten Gillibrand和Cynthia Lummis正式發布了加密監.

1900/1/1 0:00:00
比特幣:金色趨勢丨行情反轉了還是爆空誘多?_區塊鏈

前期提示的潛在圓弧頂頸線28600一直未有效跌破,并且這一帶也是5日線200均線位置,歷史上可以看到BTC從高位首次回落至5日線200均線一帶往往會有一個反彈修復的動作,前期跌速過快.

1900/1/1 0:00:00
ads