使用WMI禁用帐户

时间:2018-06-12 16:03:55

标签: c# wmi

我正在尝试禁用本地Windows帐户。借助Microsoft librairy,我能够写出这个

ManagementScope mgmtScope = new ManagementScope("\\\\.\\Root\\CIMv2");
ObjectQuery oQuery = new ObjectQuery("SELECT * FROM Win32_UserAccount");
ManagementObjectSearcher mgmtSearch = new ManagementObjectSearcher(mgmtScope, oQuery);
ManagementObjectCollection objCollection = mgmtSearch.Get();
foreach (ManagementObject mgmtObject in objCollection)
{
    if ((string)mgmtObject["Name"] == "test")
    {
        mgmtObject.SetPropertyValue("Disabled", true);
        Console.WriteLine("{0}", mgmtObject.GetPropertyValue("Disabled"));
    }
}

GetPropertyValue函数告诉我该值已设置为" true"但是当程序退出循环foreach时,该值再次设置为" false"。

有谁知道为什么会这样?

编辑:我最终找到了答案。我只需要使用方法ManagementObject.Put()

将更改应用于对象

2 个答案:

答案 0 :(得分:1)

使用方法

将更改应用于对象
ManagementObject.Put()

答案 1 :(得分:0)

这个问题已经有了答案,但我会冒昧地告诉你,使用ORMi库(我制作和保留)可以更容易地做到这一点:

1)定义你的班级:

[WMIClass("Win32_UserAccount")]
public class UserAccount
{
    public string Name { get; set; }
    public bool Disabled { get; set; }
}

2)查询WMI:

WMIHelper helper = new WMIHelper("root\\CimV2");

UserAccount account = helper.Query<UserAccount>().Where(p => p.Name == "test").SingleOrDefault();

account.Disabled = false;

helper.UpdateInstance(account);

希望它有所帮助!

PD:您也可以通过NuGet

进行安装