以下工作将 Swagger json 解析为资源、方法、httptype,但可能... $path.Definition 部分很奇怪,我如何才能使 $path.Definition 成为一个数组而不是我需要的字符串解析数组符号。
$json = Get-Content -Path "$PSScriptRoot/Test/example_swagger.json" | ConvertFrom-Json
$paths = Get-Member -InputObject $json.paths -MemberType NoteProperty
$result = ""
foreach($path in $paths) {
$elements = $path.Name.Substring(5).split("/") -join ","
$httpmethods = $path.Definition.Substring($path.Definition.IndexOf("@{"))
if ($httpmethods.Contains("get")) {
$result += $elements + ", GET" + "`n"
}
if ($httpmethods.Contains("post")) {
$result += $elements + ", POST" + "`n" #same methodnames different http methods
}
}
$result
最佳答案
正如我对 Iterating through a JSON file PowerShell 的回答中所详细说明的,ConvertFrom-Json 的输出很难迭代。这使得“对于对象中的每个键”和“提前未知对象的键”这种情况更难以处理,但并非不可能。
您需要一个辅助函数:
# helper to turn PSCustomObject into a list of key/value pairs
function Get-ObjectMember {
[CmdletBinding()]
Param(
[Parameter(Mandatory=$True, ValueFromPipeline=$True)]
[PSCustomObject]$obj
)
$obj | Get-Member -MemberType NoteProperty | ForEach-Object {
$key = $_.Name
[PSCustomObject]@{Key = $key; Value = $obj."$key"}
}
}
有了这个,方法变得更加简单:
$swagger = Get-Content -Path "example_swagger.json" -Encoding UTF8 -Raw | ConvertFrom-Json
$swagger.paths | Get-ObjectMember | ForEach-Object {
[pscustomobject]@{
path = $_.Key
methods = $_.Value | Get-ObjectMember | ForEach-Object Key
}
}
应用于 https://editor.swagger.io/ 中的默认 Swagger 文件作为示例,这是打印的
path methods
---- -------
/pet {post, put}
/pet/findByStatus get
/pet/findByTags get
/pet/{petId} {delete, get, post}
/pet/{petId}/uploadImage post
/store/inventory get
/store/order post
/store/order/{orderId} {delete, get}
/user post
/user/createWithArray post
/user/createWithList post
/user/login get
/user/logout get
/user/{username} {delete, get, put}
关于json - Powershell 解析 Swagger Json,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/66074896/