如何从 PowerShell 中的 Invoke-WebRequest 解析 JSON?
How to parse JSON from the Invoke-WebRequest in PowerShell?
向服务器发送 GET 请求时,使用 self-signed 证书:
add-type @"
using System.Net;
using System.Security.Cryptography.X509Certificates;
public class TrustAllCertsPolicy : ICertificatePolicy {
public bool CheckValidationResult(
ServicePoint srvPoint, X509Certificate certificate,
WebRequest request, int certificateProblem) {
return true;
}
}
"@
[System.Net.ServicePointManager]::CertificatePolicy = New-Object TrustAllCertsPolicy
$RESPONSE=Invoke-WebRequest -Uri https://yadayada:8080/bla -Method GET
echo $RESPONSE
我收到以下回复:
StatusCode : 200
StatusDescription : OK
Content : {123, 10, 108, 111...}
RawContent : HTTP/1.1 200 OK
Content-Length: 21
Date: Sat, 11 Jun 2016 10:11:03 GMT
{
flag:false
}
Headers : {[Content-Length, 21], [Date, Sat, 11 Jun 2016 10:11:03 GMT]}
RawContentLength : 21
Content 包含一些有线数字,所以我去找 RawContent,我如何解析里面的 JSON,忽略 headers?还是有一种干净的方法可以从这些数字中获取内容?
您可以将 Invoke-WebRequest
替换为 Invoke-RestMethod
,这会自动将 json 响应转换为 psobject
,因此您可以使用:
$response = Invoke-RestMethod -Uri "https://yadayada:8080/bla"
$response.flag
如果您需要在 Invoke-RestMethod
上使用 Invoke-WebRequest
,您可以先将其转换为字符串,从而将其转换为对象
$response = Invoke-WebRequest -Uri "https://yadayada:8080/bla"
$jsonObj = ConvertFrom-Json $([String]::new($response.Content))
这样:
$response = Invoke-WebRequest -Uri <your_uri>
if ($response.statuscode -eq '200') {
$keyValue= ConvertFrom-Json $response.Content | Select-Object -expand "<your_key_name>"
}
如果你有一个包装器而不是在路径中包含名称。
$response=Invoke-RestMethod -Method GET -ContentType "application/json" -Headers $headers -Uri $Url
foreach($element in $response.baskets.fixed_asset_rents)
{
Write-Host $element
}
向服务器发送 GET 请求时,使用 self-signed 证书:
add-type @"
using System.Net;
using System.Security.Cryptography.X509Certificates;
public class TrustAllCertsPolicy : ICertificatePolicy {
public bool CheckValidationResult(
ServicePoint srvPoint, X509Certificate certificate,
WebRequest request, int certificateProblem) {
return true;
}
}
"@
[System.Net.ServicePointManager]::CertificatePolicy = New-Object TrustAllCertsPolicy
$RESPONSE=Invoke-WebRequest -Uri https://yadayada:8080/bla -Method GET
echo $RESPONSE
我收到以下回复:
StatusCode : 200
StatusDescription : OK
Content : {123, 10, 108, 111...}
RawContent : HTTP/1.1 200 OK
Content-Length: 21
Date: Sat, 11 Jun 2016 10:11:03 GMT
{
flag:false
}
Headers : {[Content-Length, 21], [Date, Sat, 11 Jun 2016 10:11:03 GMT]}
RawContentLength : 21
Content 包含一些有线数字,所以我去找 RawContent,我如何解析里面的 JSON,忽略 headers?还是有一种干净的方法可以从这些数字中获取内容?
您可以将 Invoke-WebRequest
替换为 Invoke-RestMethod
,这会自动将 json 响应转换为 psobject
,因此您可以使用:
$response = Invoke-RestMethod -Uri "https://yadayada:8080/bla"
$response.flag
如果您需要在 Invoke-RestMethod
上使用 Invoke-WebRequest
,您可以先将其转换为字符串,从而将其转换为对象
$response = Invoke-WebRequest -Uri "https://yadayada:8080/bla"
$jsonObj = ConvertFrom-Json $([String]::new($response.Content))
这样:
$response = Invoke-WebRequest -Uri <your_uri>
if ($response.statuscode -eq '200') {
$keyValue= ConvertFrom-Json $response.Content | Select-Object -expand "<your_key_name>"
}
如果你有一个包装器而不是在路径中包含名称。
$response=Invoke-RestMethod -Method GET -ContentType "application/json" -Headers $headers -Uri $Url
foreach($element in $response.baskets.fixed_asset_rents)
{
Write-Host $element
}