我有一个 C# winform 应用程序,将安装在 Windows 7、Vista 和 XP 计算机上,32 位或 64 位,操作系统为英语、德语和西班牙语(以及将来的其他语言)。
我需要获取本地计算机上所有管理员和用户帐户名称的列表。我只需要一个帐户名称列表,仅此而已。
问题是我的代码仅适用于英语操作系统。
有没有办法获取本地计算机上的用户名,无论操作系统的语言如何,无论是 XP、Vista 还是 7,无论是 32 位还是 64 位?
我在某处读到一篇关于使用 SID 获取本地管理员名称(以防重命名)的帖子。使用 SID 可以帮助解决我的问题吗?
下面是我的代码。在德语操作系统计算机上,代码在“DirectoryEntry admGroup = localMachine.Children.Find("administrators", "group");”行上失败。它在这里失败很可能是因为在德语操作系统中“管理员”、“组”等词的拼写可能不同。对于西班牙语操作系统来说,情况也可能如此。
我的 32 位操作系统代码:
DirectoryEntry localMachine = new DirectoryEntry(
"WinNT://" + Environment.MachineName);
DirectoryEntry admGroup = localMachine.Children.
Find("administrators", "group");
object adminmembers = admGroup.Invoke("members", null);
DirectoryEntry userGroup = localMachine.Children.Find("users", "group");
object usermembers = userGroup.Invoke("members", null);
//Retrieve each user name.
foreach (object groupMember in (IEnumerable)adminmembers)
{
DirectoryEntry member = new DirectoryEntry(groupMember);
if (!(member.Name == "admin" || member.Name == "Domain Admins"))
{
drow = dtWindowsUser.NewRow();
drow["WindowsUser"] = member.Name;
//Add row to datatable
dtWindowsUser.Rows.Add(drow);
}
}
foreach (object groupMember in (IEnumerable)usermembers)
{
DirectoryEntry member = new DirectoryEntry(groupMember);
if (!(member.Name == "ACTUser" || member.Name == "ASPNET" ||
member.Name == "Domain Users" ||
member.Name == "Authenticated Users" ||
member.Name == "INTERACTIVE" ||
member.Name == "SQLDebugger"))
{
drow = dtWindowsUser.NewRow();
drow["WindowsUser"] = member.Name;
//Add row to datatable
dtWindowsUser.Rows.Add(drow);
}
}
我的 64 位操作系统代码:
SelectQuery query = new SelectQuery("Win32_UserAccount");
ManagementObjectSearcher searcher = new ManagementObjectSearcher(query);
foreach (ManagementObject envVar in searcher.Get())
{
str_name = envVar["Name"].ToString();
if (!(str_name == "admin" || str_name == "Domain Admins"))
{
if (!(str_name == "ACTUser" ||
str_name == "ASPNET" ||
str_name == "Domain Users" ||
str_name == "Authenticated Users" ||
str_name == "INTERACTIVE" ||
str_name == "SQLDebugger"))
{
if (!(str_name == "HomeGroupUser$"))
{
drow = dtWindowsUser.NewRow();
drow["WindowsUser"] = str_name;
//Add row to datatable
dtWindowsUser.Rows.Add(drow);
}
}
}
}