1,preload
2,显式链接时将介入库放在被介入库的前面,例如,我们利用tcmalloc来hack malloc等函数,那么显式链接tcmalloc时,应保证在libc前面。这样加载时会先加载libtcmalloc,再加载libc。
3,编译生成动态库时使用-z interpose选项,会在动态库的符号表中存一个INTERPOSE的flag,动态链接器在加载进程时,判断该flag并优先载入其符号.
gcc libbbb.c -z interpose -fPIC -shared -o libbbb.so
readelf -a libbbb.so |grep INTERPOSE
但这种方法在fedora及uclibc中验证无效,因为动态链接器中压根没判断此flag,心塞,估计是觉得LD_PRELOAD就足够了吧,而且编译时强制介入的方法太粗暴不够灵活。
4,热补丁(运行时插入)
1804

被折叠的 条评论
为什么被折叠?



