win32 – 使用LookupAccountName查找SID

可以使用LookupAccountNameA获取sid。

LookupAccountName函数接受系统名称和帐户作为输入。它检索该帐户的安全标识符(SID)以及在其上找到该帐户的域的名称。

使用此api无需在LocalSystem帐户的上下文中运行

代码示例:(C ++)

#include <Windows.h>
#include <Sddl.h>

#include <stdio.h>

int main(int argc, char** argv)
{
    LPCTSTR wszAccName = TEXT("domainname\\username");
    LPTSTR wszDomainName = (LPTSTR)GlobalAlloc(GPTR, sizeof(TCHAR) * 1024);
    DWORD cchDomainName = 1024;
    SID_NAME_USE eSidType;
    LPTSTR sidstring;
    char sid_buffer[1024];
    DWORD cbSid = 1024;
    SID* sid = (SID*)sid_buffer;

    if (!LookupAccountName(NULL, wszAccName, sid_buffer, &cbSid, wszDomainName, &cchDomainName, &eSidType)) {
        return GetLastError();
    }

    if (!ConvertSidToStringSid(sid, &sidstring)) {
        return GetLastError();
    }

    printf("%ws\n", sidstring);
    return 0;

}

另一种方法,使用WTSQueryUserToken ...

获取会话ID指定的登录用户的主要访问令牌。要成功调用此函数,调用应用程序必须在LocalSystem帐户的上下文中运行并且具有SE_TCB_NAME特权。

首先使用WTSenumerateSessions进行枚举,然后比较用户名并获取相应的SessionId,然后调用WTSQueryUserToken以获取令牌,然后使用GetTokenInformation来获取sid。

相关:如何在C ++中利用我的服务获取用户的SID和用户名

原文链接: https://www.cnblogs.com/strive-sun/p/13541553.html

欢迎关注

微信关注下方公众号,第一时间获取干货硬货;公众号内回复【pdf】免费获取数百本计算机经典书籍;

也有高质量的技术群,里面有嵌入式、搜广推等BAT大佬

    win32 - 使用LookupAccountName查找SID

原创文章受到原创版权保护。转载请注明出处:https://www.ccppcoding.com/archives/404852

非原创文章文中已经注明原地址,如有侵权,联系删除

关注公众号【高性能架构探索】,第一时间获取最新文章

转载文章受原作者版权保护。转载请注明原作者出处!

(0)
上一篇 2023年4月25日 下午4:45
下一篇 2023年4月25日 下午4:45

相关推荐