因为安装脚本中需要调用到我们的一个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