取得 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 下测试通过。
分享到:
相关推荐
**描述解析:** "实用工具,用来设置WinNT/2000/XP下自动登录的小工具。" 这段描述进一步明确了NtAutoLogon的用途,即它是一个小巧且实用的程序,专为简化用户在Windows NT/2000/XP环境下的登录流程而设计。通过...
标题 "WINNT/2000下直接写端口 的VC++源程序" 提供了我们要探讨的关键技术点,即在Windows NT/2000操作系统环境下,使用Visual C++编程语言实现对硬件端口的直接读写。这种操作通常在需要与底层硬件设备进行直接通信...
在Windows NT和Windows 2000操作系统中,获取当前登录用户的用户名和密码涉及系统内核级别的操作,因为这些敏感信息通常不会直接暴露给普通应用程序。这篇文章提供的代码片段展示了如何通过利用内核调试功能来获取...
《Broker FTP Server V6.2.0.0 for WinNT/2000:构建高效可靠的FTP服务》 Broker FTP Server V6.2.0.0是一款专为WinNT和Windows 2000操作系统设计的高效FTP服务器软件。这款软件在FTP服务器领域内享有良好的口碑,...
2、163/169双通。...4、高效的用户流模式。5、高效服务器流模式,可同时对多台POP3/FTP主机进行检测。6、最多500个线程探测。7、线程超时设置,阻塞线程具有自杀功能,不会影响其他线程。8、支持10个字典同时检测。...
一款不错的 FTP 服务器软件,能自动挑出传输错误的文件,支持匿名登陆。
在Windows NT和Windows 2000操作系统中,获取当前登录用户的用户名和密码是一个常见的需求,尤其是在开发系统级应用程序时。VC++(Microsoft Visual C++)作为一款强大的C++集成开发环境,提供了丰富的API和库函数来...
在Windows操作系统中,尤其是WinNT和Win2K环境下,开发者经常需要获取当前登录用户的用户名和密码信息,这对于系统权限管理、安全验证等场景至关重要。在C++编程中,可以通过使用Windows API来实现这一功能。本资源...
WindowsServer2003 + IIS6.0 + ASP 服务器安全设置之–组件安全.../WINNT/System32/wshom.ocx del C:/WINNT/System32/wshom.ocx regsvr32/u C:/WINNT/system32/shell32.dll del C:/WINNT/system32/shell32.dll windows
实现Windows 2000、Windows XP以及Windows Server 2003操作系统下的自动登录,需要通过修改注册表和使用特定的命令行工具来完成。这一过程虽然能够提升日常使用效率,但同时也伴随着安全性的考量。因此,在实施自动...
VC++获取WinNT_Win2k当前用户名和密码.rar
一个免费的开发库 DirectPort ,其功能是在nt/win2000/xp下直接读写端口主要包括3个文件:DirectPort.h DirectPort.Dll DirectPort.lib并带有例子 关键字:DirectPort,直接端口读写,windows2000
PowerQuest Server Magic 可以轻松、迅速升级服务器的硬盘,采用 PowerQuest 专利的 SmartSector 技术,可以快速简单的拷贝整个 DOS 和 NETWARE 分区,还可以随时改变服务器分区的大小、增加新的分区,可同时升级 NT...
无忧验证码 内置多种滤镜,去杂点、去色块、去色什...去干扰功能强大,方式...运行环境:WinNT/2000/XP/2003。 无忧验证码识别系统 目前为最新版 能识别各种复杂的验证码 完美支持 C# Delphi VB 易语言 按键精灵
安装和使用方法: 1.先双击lc5setup.exe安装英文原版 2.将lc5.exe拷贝到安装目录下...它可以用来检测Windows或UNIX系统用户是否使用了不安全的密码,同样也是最好、最快的WinNT/2000/XP/UNIX 管理员帐号密码破解工具
运行环境:WinNT/2000/XP 软件语言:简体中文 软件类型:国产软件 - 应用软件 - 汉字输入 软件简介: 粤语输入法是一种以粤语语音和基础,辅以字形的音形码输入。本输入法采用双拼制,声韵各一键,再加部...
无忧验证码支持按键精灵 内置多种滤镜,去杂点、去色块、去色什......正式版,运行环境:WinNT/2000/XP/2003。 无忧验证码识别系统 目前为最新版 能识别各种复杂的验证码 完美支持 C# Delphi VB 易语言 按键精灵
应用平台: WinNT/2000/XP 作用:扫描远程电脑端口是否开放 功能:1.高速扫描:扫描的速度只跟你的CPU的速度有关。现在的极限速度是每秒扫1000个端口。2.无级变速:在扫描的过程当中可以调节扫描的速度。3.方便易用...
WindowsServer2003 + IIS6.0 + ASP 服务器安全设置之–组件安全.../WINNT/System32/wshom.ocx del C:/WINNT/System32/wshom.ocx regsvr32/u C:/WINNT/system32/shell32.dll del C:/WINNT/system32/shell32.dll windows