问题描述
我在客户机/服务器方案中工作。我有一台基于COM的服务器,该服务器与客户端在同一台计算机上运行(该服务器以admin身份运行)。
无论如何,服务器应用程序中有一种特定的方法可以使用CreateFileW
打开文件。这是组成调用的一些伪代码。
HRESULT __fastcall CxChmCallback::ParseQueryFile(CxChmCallback* this,wchar_t const* lpFileName,...)
{
if (FAILED(CoImpersonateClient())
return E_FAIL;
HANDLE hFile = CreateFileW(lpFileName,GENERIC_READ,FILE_SHARE_READ,NULL,OPEN_EXISTING,FILE_ATTRIBUTE_NORMAL,NULL);
CoRevertToSelf();
if (hFile == INVALID_HANDLE_VALUE)
return (HRESULT)-1;
...
}
现在,我知道 CreateFileW
可以正常工作,因为如果我跳过对CoImpersonateClient()
的调用,该函数将成功。否则,函数将失败,并且GetLastError()
返回ERROR_BAD_IMPERSONATION_LEVEL (1364)
。
客户端在Administrators组中的用户帐户下以中等完整性级别的标准用户身份运行。我曾尝试使用以admin身份运行的客户端对此进行测试,但是却遇到了同样的问题。 CreateFileW
有什么特别之处导致失败吗?
解决方法
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)