Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Invoke-WebRequest -Method 'POST' with -ContentType 'application/json' Fails

When using:

        $body = @{    
            Manager  = "[email protected]" #$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  

Or

$response = Invoke-WebRequest -Method 'POST' -Uri $Url  -Body $body -ContentType 'application/json' # -Headers $Headers  

Neither ContentType 'application/json' Nor $Headers = @{'Content-Type' = 'application/json' } -Headers $Headers
Works

The error is always:

"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.'."}}"

The same call works in Postman

I am using PS 5.1 and I must have -ContentType 'application/json' otherwise PS works but the service fails

What can be the issue?

like image 416
Ofer Gal Avatar asked Oct 22 '25 13:10

Ofer Gal


2 Answers

The API requires that the body be a JSON string. You can do a simple conversion (using ConvertTo-Json) in your Invoke-RestMethod command and set the content type accordingly.

Invoke-RestMethod -Method POST -Uri $uri -Header $header -Body ($body | ConvertTo-Json) -ContentType 'application/json'
like image 192
NickSalacious Avatar answered Oct 26 '25 00:10

NickSalacious


I agree with NickSalacious. Your issue is that you are not sending JSON.

If you are using Postman and just starting to do API in PowerShell. Postman has a "Code" Link in the top right hand corner of the request. Just below and to the right of the Send button. In there you can select PowerShell. This will give you a good basis to see how the same request could be ran in PowerShell.

Postman would turn your body into this:

$body = "{`n    `"Manager`": `"[email protected]`",`n    `"Name`": `"some name`",`n    `"Number`": `"Some number`",`n    `"Practice`": `"Some Practice`"`n}"

This is not the easiest to work with and to read. Learning and using ConvertTo-Json is going to help a lot more in the long run.

*Edit: Also look at Invoke-RestMethod and Invoke-WebRequest. They behave differently and sometimes one will be better than the other.

*Edit2: Figured I would put an example of another way to do it.

$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
like image 42
Redsloth55 Avatar answered Oct 26 '25 00:10

Redsloth55



Donate For Us

If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!