Invoke-WebRequest, POST con parámetros


198

Estoy intentando POSTAR en un uri y enviar el parámetro username=me

Invoke-WebRequest -Uri http://example.com/foobar -Method POST

¿Cómo paso los parámetros usando el método POST?


2
Vea esta respuesta a una pregunta similar.
Ansgar Wiechers

Respuestas:


301

Coloque sus parámetros en una tabla hash y páselos así:

$postParams = @{username='me';moredata='qwerty'}
Invoke-WebRequest -Uri http://example.com/foobar -Method POST -Body $postParams

8
Para mi referencia futura tanto como la información de cualquier otra persona, la tabla hash también se puede pasar, con un solo estilo, directamente al parámetro -Body.
cori

2
agregue $ ProgressPreference = 'SilentlyContinue' para acelerar las cosas por un factor de 10.
andrej

94

Para algunos servicios web exigentes, la solicitud debe tener el tipo de contenido establecido en JSON y el cuerpo para ser una cadena JSON. Por ejemplo:

Invoke-WebRequest -UseBasicParsing http://example.com/service -ContentType "application/json" -Method POST -Body "{ 'ItemID':3661515, 'Name':'test'}"

o el equivalente para XML, etc.


15

Esto simplemente funciona:

$body = @{
 "UserSessionId"="12345678"
 "OptionalEmail"="MyEmail@gmail.com"
} | ConvertTo-Json

$header = @{
 "Accept"="application/json"
 "connectapitoken"="97fe6ab5b1a640909551e36a071ce9ed"
 "Content-Type"="application/json"
} 

Invoke-RestMethod -Uri "http://MyServer/WSVistaWebClient/RESTService.svc/member/search" -Method 'Post' -Body $body -Headers $header | ConvertTo-HTML

3

Comando único sin variables ps cuando se usa JSONcomo cuerpo {lastName:"doe"}para la llamada API POST:

Invoke-WebRequest -Headers @{"Authorization" = "Bearer N-1234ulmMGhsDsCAEAzmo1tChSsq323sIkk4Zq9"} `
                  -Method POST `
                  -Body (@{"lastName"="doe";}|ConvertTo-Json) `
                  -Uri https://api.dummy.com/getUsers `
                  -ContentType application/json
Al usar nuestro sitio, usted reconoce que ha leído y comprende nuestra Política de Cookies y Política de Privacidad.
Licensed under cc by-sa 3.0 with attribution required.