取得 WinNT/2000 下的用户名

简介: 取得 WinNT/2000 下的用户名   // 取得当前用户的 Token HANDLE hToken = NULL; OpenProcessToken(GetCurrentProcess(), TOKEN_QUERY, &hToken); // 获取 Token Info...

取得 WinNT/2000 下的用户名

 

// 取得当前用户的 Token
HANDLE hToken = NULL;
OpenProcessToken(GetCurrentProcess(), TOKEN_QUERY, &hToken);

// 获取 Token Information
DWORD dwReturned = 0;
GetTokenInformation(hToken, TokenOwner, NULL, 0, &dwReturned);

LPVOID pvOwner = new BYTE[dwReturned];
GetTokenInformation(hToken, TokenOwner, pvOwner, dwReturned, &dwReturned);

PTOKEN_OWNER pTokenOwner = (PTOKEN_OWNER)pvOwner;

// 查找 Token 对应的用户名
SID_NAME_USE snu;

TCHAR tszName[256], tszDomain[256];
DWORD cbName = 256, cbDomain = 256;

LookupAccountSid(NULL/* Local system */, 
    pTokenOwner->Owner, tszName, &cbName, tszDomain, &cbDomain, &snu))

// 输出用户名和 Domain
cout << _T("User = ") << tszName << endl;
cout << _T("Domain = ") << tszDomain << endl;

delete[] pvOwner;

 

取 Groups 和比较是否为 Administrators

 

// 获取 Token Information
GetTokenInformation(hToken, TokenGroups, NULL, 0, &dwReturned);

LPVOID pvGroups = new BYTE[dwReturned];
  
GetTokenInformation(hToken, TokenGroups, pvGroups, dwReturned, &dwReturned);

PTOKEN_GROUPS pTokenGroups = (PTOKEN_GROUPS)pvGroups;

// 获取 Administrators 的 SID
PSID pSIDAdmin = NULL;

SID_IDENTIFIER_AUTHORITY SIDAuth = SECURITY_NT_AUTHORITY;
AllocateAndInitializeSid(&SIDAuth, 2, SECURITY_BUILTIN_DOMAIN_RID, 
    DOMAIN_ALIAS_RID_ADMINS, 0, 0, 0, 0, 0, 0, &pSIDAdmin);

// 查找 Token 是否属于 Administrators 组
SID_NAME_USE snu;

TCHAR tszName[256], tszDomain[256];
DWORD cbName = 256, cbDomain = 256;

for (int i = 0; i < pTokenGroups->GroupCount; i ++)
{
    LookupAccountSid(NULL/* Local system */, 
        pTokenGroups->Groups[i].Sid, tszName, &cbName, tszDomain, &cbDomain, &snu);

    if (EqualSid(pSIDAdmin, pTokenGroups->Groups[i].Sid))
        cout << " Administrators:" << endl;

    cout << _T("Group = ") << tszName << endl;
    cout << _T("Domain = ") << tszDomain << endl;
}

FreeSid(pSIDAdmin);
delete[] pvGroups;

 

上述代码在 Windows 2000/XP 下测试通过。

目录
相关文章
|
安全 数据安全/隐私保护
配置samba的访问密码和用户名
出于安全问题,需要为samba配置密码: $ smbpasswd -a 按提示输入想使用的密码即可 另外 /etc/samba/smb.conf 的 [global] 段必须有: security = user 如此这般,局域网的人访问你的电脑都需要以上命令设置的用户名和密码。
10657 2
|
7月前
|
存储 弹性计算 运维
循环测试用户名与密码是否正确
【4月更文挑战第29天】
36 0
|
7月前
|
存储 弹性计算 运维
测试用户名与密码是否正确
【4月更文挑战第29天】
43 0
|
7月前
|
数据安全/隐私保护 Windows
windows密码获取 -- mimikatz
windows密码获取 -- mimikatz
114 0
|
数据安全/隐私保护
WIN10共享文件夹,取消用户名和密码
WIN10共享文件夹,取消用户名和密码
120 0
WIN10共享文件夹,取消用户名和密码
|
开发工具 数据安全/隐私保护 git
TortoiseGit 修改用户名和密码
TortoiseGit 修改用户名和密码
810 0
TortoiseGit 修改用户名和密码
|
NoSQL 数据库 数据安全/隐私保护
Windows下MongoDB安装及创建用户名和密码
Windows下MongoDB安装及创建用户名和密码 下载MongoDB的安装文件https://www.mongodb.com/download-center#community,选择合适的版本(注:本人选择的是3.2.6) 下载完MongoDB.msi后点击Next一路安装下去(注:本人的mongodb的安装路径为D:\MongoDB\Server\) 将MongoDB服务器作为Windows服务运行 请注意,你必须有管理权限才能运行下面的命令。
2776 0
Confluence 6 修改用户名的说明
一些有关用户名修改的重要信息: 提及和页面历史(Mentions and page history) – 当前页面的任何用户的提及到的用户名将会自动更新为新的用户名,但是在  Confluence 5.3 版中页面使用的提及功能指向的用户名将不会更新而是老的用户名。
947 0
|
数据安全/隐私保护