我正在编写我的第一个脚本,它是压缩系统上的所有elf可执行文件。
find / * -executable -type f -exec file '{}' \; | grep ELF | sed -e "s/[:].*//" |
upx --best --ultra-brute upx不响应已发送的文件
发布于 2012-08-03 16:29:45
我不确定你的系统是否安全(你不想至少过滤共享库吗?),但我建议:
find / -executable -type f | xargs file |\
grep ELF | cut -d: -f1 | xargs upx --best --ultra-brute如果文件名中有空格
find / -executable -type f -print0 | xargs -0 file |\
grep ELF | cut -d: -f1 | xargs -0 upx --best --ultra-brute但很可能会遇到shell限制(xargs:参数行太长)
一种解决方法是使用循环:
find / -executable -type f -print0 | xargs -0 file |\
grep ELF | cut -d: -f1 |\
while read f
do
upx --best --ultra-brute "$f"
done发布于 2012-08-03 16:14:42
您需要在exec参数中包含管道。我用sh -c做到了这一点
find / * -executable -type f -exec sh -c 'file '{}' \
| grep -q ELF' \; -print \
| upx --best --ultra-brute 另外,我在这里使用的是-print,而不是你用sed构建的代码。这样做更好,因为如果文件名中包含:,则基于sed的解决方案将不起作用(带有xargs -0的-print0会更好)。
https://stackoverflow.com/questions/11788204
复制相似问题