strings 是 Linux 系统中的一个实用工具,用于从二进制文件中提取可显示的字符串。尽管它本身不具备直接检测重复代码的功能,但可以与其他工具一起使用来达成此目的。以下是几种可行的方法:
提取字符串:
strings your_binary_file > strings_output.txt
排序字符串:
sort strings_output.txt > sorted_strings_output.txt
检测重复字符串:
uniq -d sorted_strings_output.txt
如果已知重复代码的特征(如特定函数名或代码片段),可以借助 grep 进行搜索:
提取字符串:
strings your_binary_file > strings_output.txt
查找特定模式的重复代码:
grep -oP 'your_pattern' strings_output.txt | sort | uniq -d
当对比多个二进制文件以寻找重复代码时:
提取字符串:
strings file1_binary > file1_strings_output.txt strings file2_binary > file2_strings_output.txt
对比字符串:
diff file1_strings_output.txt file2_strings_output.txt | grep '>'
还可以使用 awk 来进一步处理和识别重复代码:
提取字符串:
strings your_binary_file > strings_output.txt
查找重复字符串并计数:
awk '{count[$0]++} END {for (word in count) if (count[word] > 1) print word, count[word]}' strings_output.txt以上方法能够帮助您利用 strings 命令与其它工具相结合来
查找和分析二进制文件中的重复代码。