在Linux下搞软件开发的朋友, 几乎没有不知道strings命令的。我们先用man strings来看看:
?1 | strings - print the strings of printable characters in files. |
意思是, 打印文件中可打印的字符。 我来补充一下吧, 这个文件可以是文本文件(test.c), 可执行文件(test), 动态链接库(test.o), 静态链接库(test.a)
脱离代码地长篇大论而不去实际验证, 不是我的风格。 还是搞点代码下菜吧(代码存在test.c中):
?12345678910111213141516 | #include <stdio.h> int add( int x, int y) { return x + y; } int main() { int a = 1; int b = 2; int c = add(a, b); printf ( "oh, my dear, c is %d\n" , c); return 0; } |
我们来看看strings test.c的结果:
?1234567891011 | [taoge@localhost learn_c]$ strings test.c #include <stdio.h> int add( int x, int y) return x + y; int main() int a = 1; int b = 2; int c = add(a, b); printf ( "oh, my dear, c is %d\n" , c); return 0; [taoge@localhost learn_c]$ |
可以看到, 确实打印出了test.c中的很多字符。
下面, 我们对可执行文件用strings试试, 如下:
?1234567891011121314 | [taoge@localhost learn_c]$ gcc test .c [taoge@localhost learn_c]$ strings a.out /lib/ld-linux .so.2 =$TsU __gmon_start__ libc.so.6 _IO_stdin_used printf __libc_start_main GLIBC_2.0 PTRh [^_] oh, my dear, c is %d [taoge@localhost learn_c]$ |
可以看到, 打印出了a.out中很多字符。
实际上, 如果有目标文件、静态库或动态库, , 也是可以用strings命令进行打印操作的。 我们来看看:
xxx.h文件:
?1 | void print(); |
xxx.c文件:
?1234567 | #include <stdio.h> #include "xxx.h" void print() { printf ( "rainy days\n" ); } |
然后, 我们来看看怎么制作静态、动态库吧(在后续博文中会继续详细介绍):
?12345678910111213141516171819202122232425262728293031323334353637383940414243444546 | [taoge@localhost learn_strings]$ ls xxx.c xxx.h [taoge@localhost learn_strings]$ gcc -c xxx.c [taoge@localhost learn_strings]$ ar rcs libxxx.a xxx.o [taoge@localhost learn_strings]$ gcc -shared -fPIC -o libxxx.so xxx.o [taoge@localhost learn_strings]$ ls libxxx.a libxxx.so xxx.c xxx.h xxx.o [taoge@localhost learn_strings]$ strings xxx.o rainy days [taoge@localhost learn_strings]$ strings libxxx.a !<arch> / 1437887339 0 0 0 14 ` Rprint xxx.o/ 1437887333 501 502 100664 848 ` rainy days GCC: (GNU) 4.4.4 20100726 (Red Hat 4.4.4-13) .symtab .strtab .shstrtab .rel.text .data .bss .rodata .comment .note.GNU-stack xxx.c print puts [taoge@localhost learn_strings]$ [taoge@localhost learn_strings]$ [taoge@localhost learn_strings]$ strings libxxx.so __gmon_start__ _init _fini __cxa_finalize _Jv_RegisterClasses print puts libc.so.6 _edata __bss_start _end GLIBC_2.1.3 GLIBC_2.0 rainy days [taoge@localhost learn_strings]$ |
看到了吧。
strings命令很简单, 看起来好像没什么, 但实际有很多用途。 下面, 我来举一个例子。 在大型的软件开发中, 假设有100个.c/.cpp文件, 这个.cpp文件最终生成10个.so库, 那么怎样才能快速知道某个.c/.cpp文件编译到那个.so库中去了呢? 当然, 你可能要说, 看makefile不就知道了。 对, 看makefile肯定可以, 但如下方法更好, 直接用命令:
?1 | strings -f "*.so" | grep "xxxxxx" |
如果还不明白, 那就就以上面的小程序为例为说明, 不过, 此处我们考虑所有的文件, 如下:
?1234 | [taoge@localhost learn_c]$ strings -f * | grep "my dear" a.out: oh, my dear, c is %d test .c: printf ( "oh, my dear, c is %d\n" , c); [taoge@localhost learn_c]$ |
可以看到, 源文件test.c和可执行文件中皆有"my dear"串, 一下子就找到了对应的文件,清楚了吧。如果某.c/.cpp文件编译进了.so库, 那么,strings -f * | grep "my dear"必定可以找到对应的.so文件, 其中"my dear"为该.c/.cpp文件中的某个日志串(比如以printf为打印)。
strings的作用先介绍到此, 算是抛砖引玉地熟悉一下strings吧。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
近日,国外研究人员披露了移交中的安全漏洞,这是支撑现代蜂窝网络的基本机制,攻击者可以利用这种漏洞使用低成本设备发起拒绝服务(DoS)和中间人(MitM)攻击。"移交程序中的漏洞不仅限于一个移交案例,而且它们会影响所有不同的移交案例和基于未经验证的测量报告和信号...
漏洞服务器安全蜂窝网络移动网络
数据仓库有四个基本的特征:面向主题的、集成的、相对稳定的、反映历史变化的。其中数据集成是数据仓库构建的首要前提,指将多个分散的、异构的数据源整合在一起以便于后续的数据分析。将数据集成过程平台化,将极大提升数据开发人员的效率,本文主要内容为:数据集成 VS 数据...
数据库技术flink数据分析数据集成平台
研究数据表明,安全运营中心(SOC)可以显著推动企业的网络安全计划,这使SOC成为有效企业网络安全计划的基石。从平均总控制时间来看,非常成功的网络安全企业与不那么成功的网络安全企业相比,部署SOC的可能性高52%。实际上,仅部署SOC就可将企业控制数据泄露事故...
服务器安全网络安全SOC安全运营中心
1、下载以及前面的rpm安装步骤请参照 Linux 使用rpm方式安装最新mysql(5.7.16)步骤以及常见问题解决2、四个rpm包安装完成后执行mysqld --initialize --user=mysql 如果提示目的文件夹内有文件:直接将/var/...
linuxrpmmysql