问题描述
使用时:
$body = @{
Manager = "spmigrationuser@contoso.com" #$item.PMEmail
Name = "some name"
Number = "Some number"
Practice = "Some Practice"
}
$response = Invoke-RestMethod -Method Post -Uri $Url -Body $body -ContentType 'application/json' # -Headers $Headers
或
$response = Invoke-WebRequest -Method 'POST' -Uri $Url -Body $body -ContentType 'application/json' # -Headers $Headers
ContentType 'application/json' 都没有
也不
$Headers = @{'Content-Type' = 'application/json' }
-Headers $Headers
作品
错误总是:
"Invoke-WebRequest : {"error":{"code":"InvalidRequestContent","message":"The request content is not valid and Could not be deserialized: 'Error parsing NaN value. Path '',line 1,position 1.'."}}"
同样的调用在 Postman 中有效
我使用的是 PS 5.1,我必须有 -ContentType 'application/json' 否则 PS 可以工作但服务失败
可能是什么问题?
解决方法
API 要求正文是 JSON 字符串。您可以在 Invoke-RestMethod 命令中进行简单的转换(使用 ConvertTo-Json)并相应地设置内容类型。
Invoke-RestMethod -Method POST -Uri $uri -Header $header -Body ($body | ConvertTo-Json) -ContentType 'application/json'
,
我同意 NickSalacious 的观点。您的问题是您没有发送 JSON。
如果您正在使用 Postman 并且刚开始在 PowerShell 中执行 API。邮递员在请求的右上角有一个“代码”链接。就在“发送”按钮的下方和右侧。在那里你可以选择 PowerShell。这将为您提供一个很好的基础,以了解如何在 PowerShell 中运行相同的请求。
邮递员会把你的身体变成这样:
$body = "{`n `"Manager`": `"spmigrationuser@contoso.com`",`n `"Name`": `"some name`",`n `"Number`": `"Some number`",`n `"Practice`": `"Some Practice`"`n}"
这不是最容易使用和阅读的。从长远来看,学习和使用 ConvertTo-Json 会有更多帮助。
*编辑:另请参阅 Invoke-RestMethod 和 Invoke-WebRequest。他们的行为不同,有时一个会比另一个更好。
*Edit2:我想我会举一个例子来说明另一种方法。
$request = @{
Uri = 'http://YourURI.Here'
Headers = @{ 'Authorization' = $token
'AnotherHeader?' = 'Sure'}
Method = 'POST'
Body = '{
"Manager": $item.PMEmail,"Name": "some name","Number": "Some number","Practice": "Some Practice"
}'
ContentType = 'application/json'
}
$response = Invoke-RestMethod @request
,
对不起,打扰了大家。 我在另一台电脑上测试过,效果很好。