2

だから、私はOSX(gcc 4.2.1)でいくつかの介入コードをいじっていて、次を機能させようとしています:

DYLD_INSERT_LIBRARIES=my.dylib を使用して ./login を呼び出すと、デフォルトのログイン実装がオーバーライドされ、カスタム実装が使用されます。これは不自然な例ですが、要点を理解するのに役立ちます。

私の情報源:

猫 libinterposers.c

#include <stdio.h>
#include <unistd.h>
#include <fcntl.h>
#include "login.h"

typedef struct interpose_s
{
  void *new_func;
  void *orig_func;
} interpose_t;

int my_open(const char *, int, mode_t);
int my_close(int);
int my_login();


static const interpose_t interposers[] __attribute__ ((section("__DATA, __interpose"))) = 
{
     { (void *)my_open,  (void *)open  },
     { (void *)my_close, (void *)close },
     { (void *)my_login, (void *)login },
};

int my_login()
{
  printf("--> my_login()\n");
  return 1;
}

int my_open(const char *path, int flags, mode_t mode)
{
  int ret = open(path, flags, mode);
  printf("--> %d = open(%s, %x, %x)\n", ret, path, flags, mode);
  return ret;
}

int my_close(int d)
{
  int ret = close(d);
  printf("--> %d = close(%d)\n", ret, d);
  return ret;
}

猫のログイン.c

#include <stdio.h>
#include "login.h"

int login()
{
  return -1;
}

int main()
{
  if (login() == 1)
  {
    printf("login successful\n");
  }
  else
  {
    printf("login failed\n");
  }
}

そして最後に、login.h

int login();

「cat /dev/null」のようなもので実行すると、正常に動作します...

DYLD_INSERT_LIBRARIES=/tmp/libinterposers.dylib cat /dev/null
--> 3 = open(/dev/null, 0, 0)
--> 0 = close(3

ただし、./login の例で実行すると

DYLD_INSERT_LIBRARIES=/tmp/libinterposers.dylib ./login
login failed

ご覧のとおり、login failed, my custom "my_login" function never runs ... と表示されるだけです。何かアイデアはありますか? 前もって感謝します!

4

1 に答える 1

5

login関数は動的ではなく静的にリンクされているため、介入するものは何もありません。静的にリンクされた関数を挿入することはできません。これを機能させたい場合はlogin、独自の動的ライブラリに移動する必要があります。

于 2010-12-29T03:34:44.997 に答える