我试着从扫雷者的记忆中读取来学习这类东西,但我有一个小问题。
当我试图打印模块时,它告诉我我没有权限这样做,我知道这是因为该进程的内存受到读写保护,要从内存中读取,我需要有调试权限。
就在这里,我的问题是当我调用OpenThreadToken(..)时,它失败了,代码为1008,即ERROR_NO_TOKEN。
下面是代码,抱歉介绍太长:
int privileges(){
HANDLE token;
TOKEN_PRIVILEGES tp;
DWORD siz = sizeof(TOKEN_PRIVILEGES);
if (OpenThreadToken(GetCurrentThread(), TOKEN_ADJUST_PRIVILEGES | TOKEN_QUERY,
FALSE, &token) != 0){ //HERE IT FAILS
LookupPrivilegeValue(NULL, SE_DEBUG_NAME, &tp.Privileges[0].Luid);
tp.PrivilegeCount = 1;
tp.Privileges[0].Attributes = SE_PRIVILEGE_ENABLED;
if (AdjustTokenPrivileges(token, 0, &tp, siz, NULL ,NULL) != 0){
cout << "--Conseguido acceso debug.\n";
return TRUE;
}
else {
cout << "fail adjust\n";
return FALSE;
}
}
else {
cout << "fail if: " << GetLastError() << endl;
cin.get();
return FALSE;
}
我不知道为什么它失败了。我也试过微软的例子,但同样的问题。
有人知道为什么会失败吗?
2条答案
按热度按时间bvpmtnay1#
如果使用模拟API,则线程只有自己的令牌,否则只有进程令牌。如果
OpenThreadToken
失败并返回ERROR_NO_TOKEN
,则只需返回OpenProcessToken
。nkkqxpd92#
将
ImpersonateSelf(SecurityImpersonation);
写为:ImpersonateSelf makes函数获取一个访问令牌,该令牌模拟调用进程的安全上下文。该令牌被分配给调用线程。
要查看所有的安全防护等级,请单击here