我正在开发一个程序,该程序收集有关系统上运行的进程的一些统计信息。
我有一个代码,它检索一些常规信息,例如可执行文件版本、发布者等。
在我打开 lsass.exe 之前,该代码对我来说很好。当我尝试打开文件进行读取时,CreateFile 失败并出现错误 ERROR_FILE_NOT_FOUND。
这是代码:
auto FileHandle
= CreateFile(file_to_process.c_str(), // C:\Windows\System32\lsass.exe
GENERIC_READ,
FILE_SHARE_DELETE|FILE_SHARE_READ|FILE_SHARE_WRITE,
NULL,
OPEN_EXISTING,
FILE_ATTRIBUTE_NORMAL,
NULL);
if ( INVALID_HANDLE_VALUE == FileHandle )
{
int err_v = GetLastError(); // ERROR_FILE_NOT_FOUND
}
此代码是系统服务的一部分,它以“SYSTEM”权限运行。