当前位置:首页 » 魔兽世界 » 魔兽tkp什么意思

魔兽tkp什么意思

发布时间: 2022-07-10 23:50:04

‘壹’ 求教高人用C#提升进程访问权限的方法!

嗯嗯,我也正在搞这个问题,
if (!OpenProcessToken(GetCurrentProcess(),
TOKEN_ADJUST_PRIVILEGES | TOKEN_QUERY, &hToken)) {
return false;
}
选解释这段,打开进程的Token(这个不会翻译,不过看英文能大概知道什么意思,take的过去分词),然后它有三个参数,第一个得到当前进程的句柄,第二个是一个值,其中一个是:
public const int TOKEN_QUERY = 0X00000008;
我也用到这个,另一个的值要去查下,然后把找到的进程Token存在hToken中,
LookupPrivilegeValue是用来查看DEBUG特权的值并保存在sedebugnameValue这个结构体里。
AdjustTokenPrivileges这个是关键的调整特权的函数,以上的程序都是为找到这个函数的参数而存在的。
^-^ 我现在要出门了,要是还是不懂你就问,我懂的我就会补充上去。

‘贰’ 如何提升SeDebug权限

1、关于提升权限的方法,在MSDN里面有一个好例子:

#include <windows.h>
#include <stdio.h>
#pragma comment(lib, "cmcfg32.lib")

BOOL SetPrivilege(
HANDLE hToken, // access token handle
LPCTSTR lpszPrivilege, // name of privilege to enable/disable
BOOL bEnablePrivilege // to enable or disable privilege
)
{
TOKEN_PRIVILEGES tp;
LUID luid;

if ( !LookupPrivilegeValue(
NULL, // lookup privilege on local system
lpszPrivilege, // privilege to lookup
&luid ) ) // receives LUID of privilege
{
printf("LookupPrivilegeValue error: %u\n", GetLastError() );
return FALSE;
}

tp.PrivilegeCount = 1;
tp.Privileges[0].Luid = luid;
if (bEnablePrivilege)
tp.Privileges[0].Attributes = SE_PRIVILEGE_ENABLED;
else
tp.Privileges[0].Attributes = 0;

// Enable the privilege or disable all privileges.

if ( !AdjustTokenPrivileges(
hToken,
FALSE,
&tp,
sizeof(TOKEN_PRIVILEGES),
(PTOKEN_PRIVILEGES) NULL,
(PDWORD) NULL) )
{
printf("AdjustTokenPrivileges error: %u\n", GetLastError() );
return FALSE;
}

if (GetLastError() == ERROR_NOT_ALL_ASSIGNED)

{
printf("The token does not have the specified privilege. \n");
return FALSE;
}

return TRUE;
}
2、经过分析之后,于是写出开关Debug权限的函数:
BOOL CWarKeyDlg::EnableDebugPrivilege(BOOL bEnableDebugPrivilege)
{
HANDLE hToken;
TOKEN_PRIVILEGES tp;
LUID luid;

if(!::OpenProcessToken(GetCurrentProcess(), TOKEN_ADJUST_PRIVILEGES, &hToken))
{
::MessageBox(this->GetSafeHwnd(), GET_TOKEN_ERROR, MSG_BOX_TITLE, MB_OK);
return FALSE;
}

if(!::LookupPrivilegeValue(NULL, SE_DEBUG_NAME, &luid))
{
::MessageBox(this->GetSafeHwnd(), GET_PRIVILEGE_VALUE_ERROR, MSG_BOX_TITLE, MB_OK);
::CloseHandle(hToken);
return FALSE;
}

tp.PrivilegeCount = 1;
tp.Privileges[0].Luid = luid;
if(bEnableDebugPrivilege)
{
tp.Privileges[0].Attributes = SE_PRIVILEGE_ENABLED;
}
else
{
tp.Privileges[0].Attributes = 0;
}

if(!::AdjustTokenPrivileges(hToken, FALSE, &tp, sizeof(tp), NULL, NULL))
{
::MessageBox(this->GetSafeHwnd(), ADJUST_PRIVILEGE_ERROR, MSG_BOX_TITLE, MB_OK);
::CloseHandle(hToken);
return FALSE;
}

::CloseHandle(hToken);

if(::GetLastError() == ERROR_NOT_ALL_ASSIGNED)
{
::MessageBox(this->GetSafeHwnd(), ENABLE_DEBUG_ERROR, MSG_BOX_TITLE, MB_OK);
return FALSE;
}
return TRUE;
}

利用这个函数给自己的WarKey开启Debug权限,再访问魔兽进程的内存时,就可以读出其中的数据了。

‘叁’ 电脑出现tkpkiegn是什么意思,又点击不起来

1,系统重装一下看看是不是中病毒了
2,键盘坏了。

热点内容
绝地求生未来之役比赛为什么进不去 发布:2023-08-31 22:07:08 浏览:1483
dota2位置什么意思 发布:2023-08-31 22:00:04 浏览:922
lol电竞是什么样子 发布:2023-08-31 21:58:40 浏览:1379
绝地求生八倍镜的那个圆圈怎么弄 发布:2023-08-31 21:58:31 浏览:1469
lol龙龟一个多少金币 发布:2023-08-31 21:55:07 浏览:830
王者如何改游戏内名称 发布:2023-08-31 21:55:06 浏览:1113
游戏主播打广告是什么意思 发布:2023-08-31 21:55:06 浏览:1816
绝地求生如何免费拿到ss7赛季手册 发布:2023-08-31 21:52:13 浏览:1000
pgg是哪个国家的战队lol 发布:2023-08-31 21:52:07 浏览:880
一个人的时候才发现游戏很没意思 发布:2023-08-31 21:49:24 浏览:1514