鱼C论坛

 找回密码
 立即注册
查看: 310|回复: 1

[已解决]OpenProcess

[复制链接]
发表于 2023-5-26 07:07:44 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
我用OpenProcess获取某软件的权限,结果失败,有没有更好提取权限的方法  ??
最佳答案
2023-5-26 07:08:21
OpenProcess函数是用来打开一个已存在的进程对象的,而不是用来获取某个软件的权限的。如果您想获取某个软件的权限,可以使用Windows API中的其他函数,如AdjustTokenPrivileges和LookupPrivilegeValue等函数来实现。以下是一个示例代码,演示如何使用这些函数来获取某个软件的权限:
  1. #include <Windows.h>
  2. #include <iostream>
  3. int main()
  4. {
  5.     HANDLE hToken;
  6.     TOKEN_PRIVILEGES tkp;
  7.     if (!OpenProcessToken(GetCurrentProcess(), TOKEN_ADJUST_PRIVILEGES | TOKEN_QUERY, &hToken))
  8.     {
  9.         std::cout << "OpenProcessToken failed with error " << GetLastError() << std::endl;
  10.         return 1;
  11.     }
  12.     if (!LookupPrivilegeValue(NULL, SE_DEBUG_NAME, &tkp.Privileges[0].Luid))
  13.     {
  14.         std::cout << "LookupPrivilegeValue failed with error " << GetLastError() << std::endl;
  15.         CloseHandle(hToken);
  16.         return 1;
  17.     }
  18.     tkp.PrivilegeCount = 1;
  19.     tkp.Privileges[0].Attributes = SE_PRIVILEGE_ENABLED;
  20.     if (!AdjustTokenPrivileges(hToken, FALSE, &tkp, sizeof(TOKEN_PRIVILEGES), NULL, NULL))
  21.     {
  22.         std::cout << "AdjustTokenPrivileges failed with error " << GetLastError() << std::endl;
  23.         CloseHandle(hToken);
  24.         return 1;
  25.     }
  26.     std::cout << "Success!" << std::endl;
  27.     CloseHandle(hToken);
  28.     return 0;
  29. }
复制代码

在上述示例中,我们使用了LookupPrivilegeValue函数来获取SE_DEBUG_NAME特权的LUID,然后使用AdjustTokenPrivileges函数来启用该特权。请注意,您需要管理员权限来获取和启用特权。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2023-5-26 07:08:21 | 显示全部楼层    本楼为最佳答案   
OpenProcess函数是用来打开一个已存在的进程对象的,而不是用来获取某个软件的权限的。如果您想获取某个软件的权限,可以使用Windows API中的其他函数,如AdjustTokenPrivileges和LookupPrivilegeValue等函数来实现。以下是一个示例代码,演示如何使用这些函数来获取某个软件的权限:
  1. #include <Windows.h>
  2. #include <iostream>
  3. int main()
  4. {
  5.     HANDLE hToken;
  6.     TOKEN_PRIVILEGES tkp;
  7.     if (!OpenProcessToken(GetCurrentProcess(), TOKEN_ADJUST_PRIVILEGES | TOKEN_QUERY, &hToken))
  8.     {
  9.         std::cout << "OpenProcessToken failed with error " << GetLastError() << std::endl;
  10.         return 1;
  11.     }
  12.     if (!LookupPrivilegeValue(NULL, SE_DEBUG_NAME, &tkp.Privileges[0].Luid))
  13.     {
  14.         std::cout << "LookupPrivilegeValue failed with error " << GetLastError() << std::endl;
  15.         CloseHandle(hToken);
  16.         return 1;
  17.     }
  18.     tkp.PrivilegeCount = 1;
  19.     tkp.Privileges[0].Attributes = SE_PRIVILEGE_ENABLED;
  20.     if (!AdjustTokenPrivileges(hToken, FALSE, &tkp, sizeof(TOKEN_PRIVILEGES), NULL, NULL))
  21.     {
  22.         std::cout << "AdjustTokenPrivileges failed with error " << GetLastError() << std::endl;
  23.         CloseHandle(hToken);
  24.         return 1;
  25.     }
  26.     std::cout << "Success!" << std::endl;
  27.     CloseHandle(hToken);
  28.     return 0;
  29. }
复制代码

在上述示例中,我们使用了LookupPrivilegeValue函数来获取SE_DEBUG_NAME特权的LUID,然后使用AdjustTokenPrivileges函数来启用该特权。请注意,您需要管理员权限来获取和启用特权。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-5-2 01:29

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表