0

我在 C# 中有一个应用程序,可以使用 PowerShell 显示来自 Active Directory 的信息。

class userps
{
    public string Name { get; set; }
    public bool Enabled { get; set; }
}

PSObject[] results = pipeline.Invoke().ToArray();
List<userps> listUserps = new List<userps>();
foreach (PSObject obj in results)
{
     lista = JsonConvert.DeserializeObject<List<userps>>(obj.ToString());
}

如果对象返回至少两个元素的数据,例如:

[
  {
    "Name":"xxx",
    "Enabled":true
  },
  {
    "Name":"yyy",
    "Enabled":true
  }
]

然后一切都很好,List.Count = 2。但是,如果它返回一个元素:

[
  {
    "Name":"xxx",
    "Enabled":true
  }
]

然后List.Count = 0 并且有一个例外:

Newtonsoft.Json.JsonSerializationException:“无法将当前 JSON 对象(例如 {"name":"value"})反序列化为类型 'System.Collections.Generic.List`1[ConsoleApp1.userps]',因为该类型需要 JSON 数组(例如 [1,2,3])正确反序列化。
要修复此错误,请将 JSON 更改为 JSON 数组(例如 [1,2,3])或更改反序列化类型,使其成为普通的 .NET 类型(例如,不是像整数这样的原始类型,而不是像这样的集合类型可以从 JSON 对象反序列化的数组或列表。
JsonObjectAttribute 也可以添加到类型中以强制它从 JSON 对象反序列化。
路径“名称”,第 2 行,位置 11。”</p>

我该如何解决这个问题,以便它适用于一个元素,也适用于几个元素?

4

1 回答 1

2

看起来您从 PowerShell 命令获取的对象不是集合,而是序列化为 JSON 中的对象。当命令只返回一个对象而不是列表时,这是 PowerShell 的常见行为。

例子:

Get-Service | ConvertTo-Json

[
    {
        "Name":  "AdobeFlashPlayerUpdateSvc",
        ...
    },  
    {
        "Name":  "ALG",
        ...
    },
    ...
]

Get-Service -Name 'NetLogon' | ConvertTo-Json

{
    "Name":  "NetLogon",
    ...
}

为避免这种情况,请将您的命令封装在数组构造函数中,并用 InputObject 参数替换管道:

ConvertTo-Json -InputObject @(Get-Service -Name 'NetLogon')

[
    {
        "Name":  "NetLogon",
        ...
    }
]
于 2018-06-11T11:29:34.887 回答