3

dlsym がストリップされたバイナリから関数をインポートできるのは奇妙です。

誰でも理由/方法を教えてもらえますか?

=== FILE: a.c ===
int a1() { return 1; }
int a2() { return 2; }
=== end of a.c ===

=== FILE: b.c ===
#include <stdio.h>
#include <dlfcn.h>
#include <stdlib.h>

typedef int (*fint)();

fint dlsym_fint(void *handle, char *name)
{
    fint x = (fint)dlsym(handle, name);
    char *err = NULL;
    if ((err = dlerror()) != NULL) {
        printf("dlsym: %s\n", err);
        exit(1);
    }
    return x;
}

int main()
{
    void *dl = dlopen("a.so", RTLD_NOW);
    fint a = NULL;
    a = dlsym_fint(dl, "a1");
    printf("%p: %d\n", a, a());
    a = dlsym_fint(dl, "a2");
    printf("%p: %d\n", a, a());
    return 0;
}
=== end of b.c ===

$ gcc -shared -fPIC -o a.so a.c
$ nm a.so
...
00000000000004ec T a1
00000000000004f7 T a2
...

$ strip a.so
$ nm a.so
nm: a.so: no symbols

$ gcc -o b b.c -ldl

$ ./b
0x2aaaaaac74ec: 1
0x2aaaaaac74f7: 2
4

2 に答える 2

6

試してみてくださいreadelf -s a.so。動的シンボルはその後も存在しstripます。

(または単にに切り替えnm -D a.soます。)

于 2011-07-21T05:46:35.527 に答える
4

stripダイナミックリンカによって使用されるダイナミックシンボルテーブルではなく、デバッグシンボルテーブルを削除します。これらのシンボルも削除するには、、-fvisibility=hiddenおよびシンボル可視化関数/変数属性を使用して、公開する関数を選択します。

于 2011-07-21T05:46:34.170 に答える