2

私はLdrLoadDll関数を試していますが、うまくいきません。また、いくつかの例をグーグルで検索しましたが、これに関するドキュメントや正しい例はあまりありません。正確に何をするのかを知っています。以下のコードを確認してください。 。

//declaration function pointer for LdrLoadDll
typedef NTSTATUS (_stdcall*fp_LdrLoadDll)(
IN PWCHAR PathToFile OPTIONAL,
IN ULONG Flags OPTIONAL, 
IN PUNICODE_STRING ModuleFileName, 
OUT PHANDLE ModuleHandle ); 

//calling LdrLoadDll using getprocaddress
 HANDLE handle;
  HMODULE module = LoadLibrary(L"ntdll.dll");
    fp_LdrLoadDll loadDll;
    loadDll = (fp_LdrLoadDll)GetProcAddress(module,"LdrLoadDll");
    if(loadDll == NULL)
    {
        MessageBox(0,L"Not able to load the function",L"LdrLoadDll",&handle);
    }
    UNICODE_STRING input;
    input.Buffer = L"C:\\Desktop\\myDll.dll";
    input.Length = wcslen(input.Buffer)*2;
    input.MaximumLength = wcslen(input.Buffer) +2;

    NTSTATUS status = loadDll(NULL,LOAD_WITH_ALTERED_SEARCH_PATH,&input,0);

上記を実行すると、ハンドルが有効なステータスになりません。これを手伝ってください。

4

1 に答える 1

3

次のようにUnicode文字列を初期化するとうまくいきました

RtlInitUnicodeString(&input,L"myDll.dll");
于 2010-06-21T03:55:39.833 に答える