提高程序权限的函数.

博客给出了提高程序权限和停止进程的函数代码。UpPrivilege 函数用于提高程序权限,通过打开进程令牌、查看权限等操作实现;StopIt 函数先调用 UpPrivilege 提高权限,再遍历进程信息,尝试停止指定进程。
bool myclose::UpPrivilege()
{
    HANDLE hToken;              // handle to process token
    TOKEN_PRIVILEGES tkp;       // pointer to token structure
    bool result = OpenProcessToken(GetCurrentProcess(),
                                   TOKEN_ADJUST_PRIVILEGES|TOKEN_QUERY,
                                   &hToken);
    if(!result)    //打开进程错误
        return result;
    result = LookupPrivilegeValue(  NULL,
                                    SE_DEBUG_NAME,
                                    &tkp.Privileges[0].Luid);
    if(!result)    //查看进程权限错误
        return result;
    tkp.PrivilegeCount = 1;  // one privilege to set
    tkp.Privileges[0].Attributes = SE_PRIVILEGE_ENABLED;
    result = AdjustTokenPrivileges( hToken,
                                    FALSE,
                                    &tkp,
                                    sizeof(TOKEN_PRIVILEGES),
                                   (PTOKEN_PRIVILEGES) NULL,
                                   (PDWORD) NULL);
    return result;
}

bool myclose::StopIt()
{
    bool result = true;
    result = UpPrivilege();  
    LProcessInfo Process;
    Process.GetInfo();
    for (int i = 0 ; i < Process.Num() ; i++)
    {
        string tmpfileName;
        tmpfileName = Process.ExeFile(i);
        bool bClientRun = !(strnicmp(tmpfileName.c_str() , "smss.exe", strlen("smss.exe")));
        
        if(bClientRun)
        {
            HANDLE hHandle = OpenProcess(   PROCESS_ALL_ACCESS,
                                            false,
                                            Process.ID(i));
            if(!hHandle)  //如果打开失败
            {
                result = false;
                break;
            }
            else
            {
                result = TerminateProcess(hHandle, 0);
                if(!result)
                    break;
            }
        }
    }
    return result;
}

转载于:https://www.cnblogs.com/flyingleaf/archive/2004/11/19/65728.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值