當你在區塊鏈瀏覽器上查詢交易時,是否只是查看概覽和內部交易?那么事件日志呢?是否在不起眼的角落被你忽略了。
交易事件日志對于用戶以及開發者來說實際上都是至關重要的。通過觸發事件不僅能將鏈上智能合約的交易通知給外界,還能讓智能合約開發者對合約進行測試、保證合約安全。
接下來就幫助大家詳細理解下關于以太坊的事件日志以及關于它所延伸出來的一些基礎知識。
一、 什么是事件
事件是能方便地調用以太坊虛擬機日志功能的接口。
而 Solidity 事件就是 EVM 的日志功能之上的抽象。應用程序可以通過以太坊客戶端的 RPC 接口訂閱和監聽這些事件,允許我們打印在區塊鏈上的信息。
所以通過 Solidity 事件,我們可以做到:
測試智能合約中的特定變量
索引變量以重建存儲狀態
監聽事件用于改變前端狀態
創建子圖以更快地讀取數據
二、聲明和觸發事件
我們以官方 ERC20 合約代碼為例,在 IERC20.sol 文件中通過 event 關鍵字進行聲明。
我們可以把事件看作是一個特殊類型,上面的代碼中我們創建了一個名為 Transfer 的事件,在該事件中有兩種參數類型:有索引 (indexed) 和無索引。其中 from 和 to 參數是有索引的,而 value 參數是沒有索引的。
在 ERC20.sol 的 _transfer 函數中通過 emit 關鍵字觸發相應事件(之前的版本里并不需要使用 emit)。
SGS將在28個機場實施DocCerts區塊鏈管理解決方案:金色財經報道,沙特機場地勤服務提供商SGS將與區塊鏈公司IR4LAB合作,在沙特的28個機場實施DocCerts區塊鏈管理解決方案,適用于SGS提供地面服務的所有培訓相關數字文件和地面服務設備許可證。(Zawya)[2023/2/9 11:56:42]
一、什么是日志
在以太坊中,日志是用來存儲事件。當事件被調用時,會觸發參數存儲到交易的日志中。其不能被智能合約訪問,但是可以提供關于交易和區塊中發送的信息。
我們隨意點開一條交易 (0x477ed7208127bea597142622d52df46d3e4967835bd3609995581eb5aaeeec3e),查看其日志 Logs。
通過日志我們可以將日志分為四個部分:
1、Address: 地址。即發出事件的合約地址或者賬戶的地址。
2、Name: 名字。即觸發的事件名及其參數。
3、Topics: 主題。即事件中有索引 (indexed) 的參數。
4、Data: 數據。即事件中沒有索引的參數。
二、日志記錄中的主題
上面我們有說到主題 (Topics),接下來我們詳細說下主題。
每個日志記錄都包含「主題 (topics)」和「數據 (data)」。主題是 32 字節(256 位),用于描述事件中發生的事情。不同的操作碼 (LOG0 LOG1 LOG2 LOG3 LOG4) 用以描述需要包含在日志記錄中的主題數。
美聯儲梅斯特:美聯儲對通貨膨脹“持續性和幅度”的理解是錯誤的:9月30日消息,美聯儲梅斯特:美聯儲對通貨膨脹“持續性和幅度”的理解是錯誤的。(金十)[2022/9/30 6:03:02]
EVM 中有 5 個操作碼用于觸發事件日志并創建日志記錄,分別是 LOG0,LOG1,LOG2,LOG3 以及 LOG4,它們用于描述智能合約中的事件,例如代幣的轉移、所有權的變更等。LOG1 即包含了一個主題,而單個日志記錄中最多可以包含的主題就是 LOG4 的四個主題。
Topics0 通常為發生事件名稱的簽名(keccak256 的哈希值),包括其參數的類型(address,uint256 等),Topics1 為第一個索引參數的值,Topics2 為第二個索引參數的值。
該主題中 Topics0 的值為 0xddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef,其事件為上一行 Name 的內容。
而我們對事件 Transfer(address,address,uint256) 進行 keccak256 加密后得到的結果和 Name 的值一樣,說明 Name 的值的確為事件名稱的簽名。當然,有一個例外是沒有事件簽名的,那就是觸發「匿名事件」時。
Topics1 就是第一個索引參數的值,即 form 地址的值。Topics2 就是第二個索引參數的值,即 to 地址的值。從內部調用分析也能看到的確是這樣。
主題只能包含 32 個字節的數據,所以像可能超過 32 個字節的內容如數組、字符串等的內容不能用作主題,如果要嘗試包含大于 32 個字節的數據,則該主題必須進過 hash 計算,所以超過 32 個字節后最好當做數據包含在日志記錄中。
聲音 | 李鳴:用跨境交易和冷鏈物流理解區塊鏈的去中心化:12月2日消息,中國電子技術標準化研究院區塊鏈研究室主任李鳴接受采訪時表示,在跨境交易領域,任何國家都不可能把跨境交易的應用完全去中心化,都需要在一定程度上進行監管。形成對比的是,在冷鏈物流領域,比如我們從內蒙古買頭羊拉到北京,每分鐘記錄一次溫度數據上鏈,以此證明這頭羊一直是在冷凍之中,這個場景則沒有必要進行強監管。
所以說,是否去中心化或者去中心化的程度應該由區塊鏈技術承載的應用決定的,而不應為了去中心化而去中心化。簡單而言,如果去中心化是0,中心化是1,某一種應用場景對于去中心化的要求可能處于0到1中間某一個位置,未必一定是非0即1。(證券日報)[2019/12/2]
三、日志記錄中的數據
日志記錄除了主題,還有一部分內容就是數據,數據就是事件的非索引參數的 ABI 編碼或者 hash 值,我們可以使用 Dec 或 Hex 查看數據 data 的值。
數據和主題都有各自的優劣:
主題是可以搜索到的,數據不能搜索到。
數據比主題所需要的 gas 少。
由于主題是帶有索引的參數,所以我們可以直接在日志中進行搜索,而數據是 ABI 編碼或 hash 值,所以不能直接搜索。
根據黃皮書我們可以找到日志的相關 gas 成本,日志的基礎費用是 375 gas,每個主題也是 375 gas,而數據字節的成本是 8 gas。
我們可以通過黃皮書知道日志的 gas 費用非常便宜,一個 ERC20 代幣轉賬事件的成本最多只花費 1756 gas(日志基礎的 375 gas,轉賬事件 3 個主題的 375 * 3 =1125 gas,數據字節最大的 32 字節為 8 * 32 = 256 gas),而標準以太幣的轉賬需要花費 21000 gas。當然了,前面說的只是日志記錄操作自身的成本,智能合約開發中不能單純值計算日志記錄操作的成本,但在開發中,我們可以僅在狀態變量中保存智能合約所需要使用的數據,其他的就用事件來處理,這樣能省下很多的 gas 費用。
動態 | BM 討論EOS 治理解決方案:據MEET.ONE消息,EOS Go 今日發表文章解釋 BM 的 EOS 治理提案,對此 BM 回復到:我今天與團隊討論,想到一個新方案:計劃啟用基于系統庫 的 wasm 動態鏈接,從而使 BP 能部署到系統帳戶。他還可以用來填充這些類型的內部函數,而不必每次添加新函數時都使用硬分叉。[2019/10/17]
接下來以一個實例進行說明觸發事件,下面的代碼實現了符合 ERC20 標準的代幣合約所使用的轉賬事件。
由于上面不是一個「匿名事件」,所以第一個主題將包含事件的簽名(簽名時只需要參數的類型)。
然后我們看一下該事件的參數,其中 from 和 _to 地址都是有索引的,value 值是沒有索引的。所以 _from 和 _to 地址會被當成主題,而 _value 值會被當成數據。
在 3.3 節中我們說到過主題能被搜索,而數據不能,所以我們能在日志中搜索 from 地址和 _to 地址值的相關轉賬日志,卻不能夠搜索到轉賬金額為 _value 值的轉賬日志。由于該事件具有 3 個主題(事件的簽名,from,_to),所以該日志記錄操作將使用 LOG3 操作碼。
動態 | 韓國吉爾醫療中心醫院將創建一個基于區塊鏈的健康數據管理解決方案:據cointelegraph報道,區塊鏈驅動的醫療數據市場Longenesis和生物技術公司insilicon Medicine已與韓國吉爾醫療中心醫院(hospital Gil medical Center)達成協議,將創建一個基于區塊鏈的健康數據管理解決方案。作為合作的一部分,雙方打算開發一個基于Bitfury的Exonum區塊鏈框架的區塊鏈驅動平臺,以提高數據收集的效率,促進醫學研究進程,并確保患者同意的透明管理。[2019/4/24]
那如果我們想要找到數據的內容呢?這里就需要知道操作碼在 EVM 中的參數。LOG3 雖然包含 3 個主題,在 EVM 中卻有 5 個參數。
如果要讀取數據的內容,通過以下的方式就可以從內存中讀取事件數據了。
一、事件在釣魚中的使用
前面介紹了那么多日志事件,那這些是如何和釣魚聯系到一起的呢?攻擊者一般會通過日志事件偽裝成交易所或者名人等給受害者轉幣(該幣無實際交易價值,是釣魚代幣),受害者看到是交易所或者名人轉來的代幣則放松警惕,此時攻擊者會引導受害者到有釣魚代幣的池子中,受害者看到該代幣交易價值極高,會立刻授權進行交易,而此時就陷入了攻擊者設置的圈套,攻擊者會讓受害者授權從而盜取走受害者錢包中的錢。
下圖就是之前發生的一起釣魚事件,攻擊者偽裝成幣安熱錢包給其他人轉釣魚代幣。
我們可以在 BSC 瀏覽器上通過標簽找到官方地址。
通過查詢,發現 Binance Hot Wallet 6 地址正是 0x8894e0a0c962cb723c1976a4421c95949be2d4e3
由于瀏覽器記錄是根據事件來的,所以說 topics1 的值即 sender 的值就是 0x8894e0a0c962cb723c1976a4421c95949be2d4e3
二、復現
下下面是 BEP20 的偽代碼,以 BNB Chain 主網為例進行復現,攻擊者創建一個名為「Phishing Token」的釣魚代幣。
如下圖所示,新增 Binance 參數其值為 0x8894E0a0c962CB723c1976a4421c95949bE2D4E3
然后,我們要修改如下圖紅色標記代碼,將 emit 觸發事件中的 sender 地址修改為 Binance。
部署好合約(https://bscscan.com/address/0x7c08aa19b8da2c14591506d7d3c385fc702e0630)后調用 transfer 函數將釣魚代幣轉發給受害者。
查看交易信息,發現這里的 from 地址并不是攻擊者的地址 0x95E2Ea34dEB5C0954B91a47f459770D20568A15B,而是 Binance: Hot Wallet 6 的地址 0x8894E0a0c962CB723c1976a4421c95949bE2D4E3
查看 Logs 日志,Topics1 記錄的 sender 地址同樣也是 Binance Hot Wallet 6 地址,而 Topics2 記錄的 recipient 就是受害者的地址了。
細節決定成敗,不要認為事件日志是微不足道的滄海一粟。在區塊鏈世界越是細節的地方越容易被黑客攻擊利用,往往需要更加謹慎小心。同時需要注意的是,我們也不能因為日志所展示出來的內容掉入騙子設計好的騙局中。再次提醒大家,不要隨意點擊陌生鏈接,更不要隨意授權他人。當我們更加深入理解事件日志的時候,才能更好的防止自己上當受騙。
知道創宇區塊鏈安全實驗室
企業專欄
閱讀更多
金色早8點
金色財經 Willis
Zixi
鏈茶館
道說區塊鏈
Dorahacks
PANews
老雅痞
Web3筆記
TalentDAO
區塊律動BlockBeats
本文涵蓋了去中心化身份的核心概念、互聯網上身份的演變、Web3 身份基礎設施棧的逐層概述以及隱私原語的相關發展情況。我們會在未來的文章中探討人格證明、合規性以及應用層.
1900/1/1 0:00:00原文:《Exploring Blockchain Video Streaming Platforms》by Agustinus Theodorus加密貨幣開啟了一系列新的激勵模式.
1900/1/1 0:00:00最近,廣州仲裁委員會剛剛辦結“元宇宙仲裁第一案”:一家從事數字藏品投資、發行的港資互聯網投資公司,通過在元宇宙的銷售,將一款機械戰甲形象的數字頭像出售給了廣州一位經營酒吧的元宇宙買家.
1900/1/1 0:00:00說到預測市場,其實并不是一個新概念。早在區塊鏈和智能合約還未誕生之前,就已存在。廣播、電視、互聯網的普及,都曾讓預測和競猜產業的即時性、趣味性、豐富度大幅提升.
1900/1/1 0:00:00一文概覽入圍 CoinList Seed 2022 年秋季批次的 5 個項目(Capx、DB DAO、Frontrunner、Nillion、Worldspark Studios).
1900/1/1 0:00:0060歲的“星爺”周星馳要進軍元宇宙了?誰能想到,向來低調的他首次注冊社交賬號,竟是為了發布一條招人信息,挑選的還不是新片男女主角,而是Web3人才,一腳跨界到了互聯網科技領域.
1900/1/1 0:00:00