1

我正在使用 PowerShell 4.0 中的 New-WebServiceProxy 从 API 中提取数据,然后将其传送到 JSON 文件以供审查并导入另一个 API 服务(相同的 API 版本等,只是不同的主机)。

$tasklist.Taskconfig | ConvertTo-JSON-Depth 50 -As String | Out-File -FilePath $exportpath\$name.xml -Force

给我包含 TaskConfig 的 XML。在这种情况下,TaskConfig 是我正在与之交互的 API 自动生成的对象类型。当我想导入我正在使用的内容时:

$taskconfig      = (Get-Content "$taskjson") -join "`n" | ConvertFrom-Json

但是当我运行它时,它无法创建对象。我认为这是因为 JSON 包含嵌套的子级,导致错误-

无法将值“@{Name=plugindive;Value=;> Children=System.Object[]}”转换为类型“Microsoft.PowerShell.Commands.NewWebserviceProxy.AutogeneratedTypes.WebServiceProxy1rcleWeb_WebClientAPI_asmx_wsdl.TaskConfig”。错误:“无法转换”@{Name=plugindive; Value=;Children=System.Object[]}” 类型“System.Management.Automation.PSCustomObject”的值以键入“Microsoft.PowerShell.Commands.NewWebserviceProxy.AutogeneratedTypes.WebServiceProxy1rcleWeb_WebClientAPI_asmx_wsdl.TaskConfig”。

我试过明确说明对象的类型:

$taskconfig      = [Microsoft.PowerShell.Commands.NewWebserviceProxy.AutogeneratedTypes.WebServiceProxy1rcleWeb_WebClientAPI_asmx_wsdl.TaskConfig](Get-Content "$taskjson" | Out-string | ConvertFrom-Json)

以及创建对象然后尝试从我的 JSON 添加孩子 -

$taskconfig.children = $json.children

但这些都以同样的方式失败。

有趣的是,我似乎在 PowerShell 5.0 中没有遇到同样的问题,但我无法验证原因——还有其他方法可以解决这个问题吗?

在下面添加了示例 JSON

{"Name": "plugindive",
"Value": null,
"Children": [{
        "Name": "auto",
        "Value": "False",
        "Children": [

        ]
    },
    {
        "Name": "categories",
        "Value": null,
        "Children": [{
                "Name": "Module Z",
                "Value": "False",
                "Children": [

                ]
            },
            {
                "Name": "Module A",
                "Value": "False",
                "Children": [

                ]
            },
            {
                "Name": "Module B",
                "Value": "False",
                "Children": [

                ]
            },
            {
                "Name": "Module C",
                "Value": "False",
                "Children": [

                ]
            }
        ]
    }
]
}
4

1 回答 1

0

似乎这在 PowerShell v3.0 中不起作用,所以我只是直接使用显式 XML 发布帖子,而不是转换为 JSON。

于 2017-12-24T11:39:23.913 回答