Abstract
As computer programs run on top of blockchain, smart contracts have proliferated a myriad of decentralized applications while bringing security vulnerabilities, which may cause huge financial losses. Thus, it is crucial and urgent to detect the vulnerabilities of smart contracts. However, existing fuzzers for smart contracts are still inefficient to detect sophisticated vulnerabilities that require specific vulnerable transaction sequences to trigger. To address this challenge, we propose a novel vulnerability-guided fuzzer based on reinforcement learning, namely RLF, for generating vulnerable transaction sequences to detect such sophisticated vulnerabilities in smart contracts. In particular, we firstly model the process of fuzzing smart contracts as a Markov decision process to construct our reinforcement learning framework. We then creatively design an appropriate reward with consideration of both vulnerability and code coverage so that it can effectively guide our fuzzer to generate specific transaction sequences to reveal vulnerabilities, especially for the vulnerabilities related to multiple functions. We conduct extensive experiments to evaluate RLF’s performance. The experimental results demonstrate that our RLF outperforms state-of-the-art vulnerability-detection tools (e.g., detecting 8%-69% more vulnerabilities within 30 minutes).
Original language | English |
---|---|
Title of host publication | Proceedings of the 37th IEEE/ACM International Conference on Automated Software Engineering (ASE) |
Publisher | Association for Computing Machinery (ACM) |
Pages | 1-12 |
Number of pages | 2006 |
ISBN (Electronic) | 10.1145/3551349 |
ISBN (Print) | 9781450394758 |
Publication status | Published - 5 Jan 2023 |
Event | 37th IEEE/ACM International Conference on Automated Software Engineering (ASE) - Ann Arbor, United States Duration: 26 Sept 2022 → 1 Oct 2022 https://www.aconf.org/conf_181212.html |
Conference
Conference | 37th IEEE/ACM International Conference on Automated Software Engineering (ASE) |
---|---|
Country/Territory | United States |
City | Ann Arbor |
Period | 26/09/22 → 1/10/22 |
Internet address |