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

最低0.47元/天 解锁文章
4646

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



