Our new X account is live! Follow @wizwand_team for updates
WorkDL logo mark

Backdooring Neural Code Search

About

Reusing off-the-shelf code snippets from online repositories is a common practice, which significantly enhances the productivity of software developers. To find desired code snippets, developers resort to code search engines through natural language queries. Neural code search models are hence behind many such engines. These models are based on deep learning and gain substantial attention due to their impressive performance. However, the security aspect of these models is rarely studied. Particularly, an adversary can inject a backdoor in neural code search models, which return buggy or even vulnerable code with security/privacy issues. This may impact the downstream software (e.g., stock trading systems and autonomous driving) and cause financial loss and/or life-threatening incidents. In this paper, we demonstrate such attacks are feasible and can be quite stealthy. By simply modifying one variable/function name, the attacker can make buggy/vulnerable code rank in the top 11%. Our attack BADCODE features a special trigger generation and injection procedure, making the attack more effective and stealthy. The evaluation is conducted on two neural code search models and the results show our attack outperforms baselines by 60%. Our user study demonstrates that our attack is more stealthy than the baseline by two times based on the F1 score.

Weisong Sun, Yuchen Chen, Guanhong Tao, Chunrong Fang, Xiangyu Zhang, Quanjun Zhang, Bin Luo• 2023

Related benchmarks

TaskDatasetResultRank
Neural Code SearchNeural Code Search (NCS) (test)
ANR31.42
35
Retrieval-Augmented Code GenerationCSN-Python Non-target Queries (test)
Similarity (GPT-4o)0.315
19
Code RetrievalCSN-Python Non-target Queries (test)
MRR0.652
19
Retrieval-Augmented Code GenerationCSN-Python Target Queries (test)
Verification Rate (GPT-4o)26.37
19
Code RetrievalCSN-Python Target Queries (test)
ASR@10.07
18
Backdoor Stealthiness DetectionHuman Study CV Group (100 clean code snippets, 25 injected)
Precision42
3
Backdoor Stealthiness DetectionHuman Study (NLP Group) 100 clean code snippets, 25 injected
Precision55
3
Showing 7 of 7 rows

Other info

Code

Follow for update