利用rundll32.exe来运行自定义的dll导出函数


因为安装脚本中需要调用到我们的一个dll中的导出函数,于是有了下文。
重要参考:INFO:Windows Rundll 和 Rundll32 接口
http://support.microsoft.com/kb/164787

刚开始不知道原来rundll对调用的导出函数的原型进行了限制,导致
"尝试运行 XXX 时发生意外"
在dll中assert出来,并attatch到rundll32进程,发现参数不对,完全不是我想的那样,于是上网搜索,还好找到了msdn上的这篇文章,哈哈哈

32 位 DLL:

  void CALLBACK
  EntryPoint(HWND hwnd, HINSTANCE hinst, LPSTR lpszCmdLine, int nCmdShow);
    

知道问题,解决起来就方便多了,代码:

void CALLBACK RundllFuncExample(HWND hwnd, HINSTANCE hinst, LPSTR lpszCmdLine, int nCmdShow)
{
 USES_CONVERSION;
 if (lpszCmdLine)
 {
  int nArgs = 0;
  // 这里用了shell api +_+ 关于这个函数请查看MSDN
  LPWSTR* szArglist = ::CommandLineToArgvW(A2W(lpszCmdLine), &nArgs);
  if (NULL != szArglist
   && nArgs == REGAPP_ARG_NUM )
  {
   // 调用真正的dll函数
  }
 }
}

调用例子:

RUNDLL32.EXE "example.dll",RundllFuncExample arg1 arg2 arg 3 arg 4 arg 5

你可能感兴趣的:(windows,shell,api,脚本,dll,callback)