我在LogonUserW失败后立即通过调用GetLastError()来检查错误代码,它总是183,但我不知道为什么LogonUserW会失败并带有这样的值。搜索了msdn,发现183(ERROR_ALREADY_EXISTS)表示“当该文件已经存在时无法创建文件”,那么LogonUserW会创建哪个文件?
请问有人在这里说清楚吗?
if (LogonUserW(uniUserName, uniDomainName, uniPassword, LOGON32_LOGON_NETWORK, LOGON32_PROVIDER_DEFAULT, &token))
{
//do something when success
}
else
{
STI_LOG(LOG_AUTH_DETAILS, ("Login fail\n"), true);
DWORD ec = GetLastError();
String message;
switch (ec)
{
case ERROR_PRIVILEGE_NOT_HELD:
message = "Error Privilege not held\n";
break;
case ERROR_LOGON_FAILURE:
message = "Error Logon Failure\n";
break;
//...
default:
message = "Other errors\n";
}
STI_LOG(LOG_ERROR, ("Fail to log in user: %d-%s\n", ec, message.getCString()), true);
}
答案 0 :(得分:5)
在致电GetLastError
之前,您正在此宏中执行一些日志记录代码:
STI_LOG(LOG_AUTH_DETAILS, ("Login fail\n"), true);
此日志记录功能中的一个API调用很可能也设置了最后一个错误标志。当然,像“文件已存在”这样的错误与日志记录功能的一致性要比登录更加一致。
因此,首先应在失败的函数调用后立即调用GetLastError
if (LogonUserW(uniUserName, uniDomainName,
uniPassword, LOGON32_LOGON_NETWORK, LOGON32_PROVIDER_DEFAULT, &token))
{
//do something when success
}
else
{
DWORD ec = GetLastError();
STI_LOG(LOG_AUTH_DETAILS, ("Login fail\n"), true);
// ... etc. ...
}
正如says on MSDN:
进行此更改后,请查看GetLastError
的返回代码是否更符合您的预期。