如何使用ObjectQuery获取本地用户的所有组?

时间:2014-07-23 11:36:06

标签: c# usergroups objectquery principalcontext principalsearcher

我尝试显示特殊用户所在的所有群组。 我也知道,我可以这样做:

 public static List<Principal> getUsers(){
     PrincipalContext context = new PrincipalContext(ContextType.Machine, "computername");
        PrincipalSearcher search = new PrincipalSearcher(new UserPrincipal(context));
        return search.FindAll().ToList();

    }

但是我想要工作一个PrincipalContext,因为我需要在PC上远程使用它,它不在任何域中。所以我试过这个:

 public static void findUsers()
    {
        ObjectQuery query = new ObjectQuery("SELECT * FROM Win32_Group WHERE LocalAccount.Name =\'Test'");
        ManagementObjectSearcher searcher = new ManagementObjectSearcher(scope, query);
        var result = searcher.Get();
         foreach (var envVar in result)
        {
            Console.WriteLine("GroupName: {0}", envVar["Name"]);
        }
        Console.ReadLine();
    }

它给我一个例外,因为查询不正确。

非常感谢您提供任何帮助。

2 个答案:

答案 0 :(得分:1)

@Edper你的提示非常好,但我用另一种方法来解决我的问题。

任务是输入一个用户名和一个远程服务器的IP,并获得本地用户所在的所有组。

class Program
{
    static ManagementScope scope =
           new ManagementScope(
               "\\\\ServerIP\\root\\cimv2");
    static string username = "Test";


    static void Main(string[] args)
    {
        string partComponent = "Win32_UserAccount.Domain='Domain',Name='"+username+"'";
        ObjectQuery query = new ObjectQuery("SELECT * FROM Win32_GroupUser WHERE PartComponent = \"" + partComponent + "\"");
        using (ManagementObjectSearcher searcher = new ManagementObjectSearcher(scope, query))
        {
            var result = searcher.Get();
            foreach (var envVar in result)
            {
                ManagementObject groupComponent = new ManagementObject("\\\\ServerIP\\root\\cimv2", envVar["GroupComponent"].ToString(), null);
                Console.WriteLine(groupComponent["Name"]);
            }
        }
        Console.ReadLine(); 
    }
}

当然这不是jet(GUI正在进行中),但它现在我想要的只是。

如果你想测试它,你需要在远程PC上建立一个本地用户,该用户的用户名和密码与用户你运行Code with相同。(这个用户需要管理员权限)

答案 1 :(得分:0)

没有LocalAccount.Name字段,只需使用Name并同时删除\,以便它看起来像:(我用过&#39;来宾&#39;作为我的例子不是&#39;测试&#39;

public static void findUsers()
{
    ObjectQuery query = new ObjectQuery("SELECT * FROM Win32_Group WHERE Name = 'Guests'");
    ManagementObjectSearcher searcher = new ManagementObjectSearcher(scope, query);
    var result = searcher.Get();
     foreach (var envVar in result)
    {
        Console.WriteLine("GroupName: {0}", envVar["Name"]);
    }
    Console.ReadLine();
}