Invoke-WebRequest
Ottiene il contenuto da una pagina Web su Internet.
Sintassi
Invoke-WebRequest
[-UseBasicParsing]
[-Uri] <Uri>
[-HttpVersion <Version>]
[-WebSession <WebRequestSession>]
[-SessionVariable <String>]
[-AllowUnencryptedAuthentication]
[-Authentication <WebAuthenticationType>]
[-Credential <PSCredential>]
[-UseDefaultCredentials]
[-CertificateThumbprint <String>]
[-Certificate <X509Certificate>]
[-SkipCertificateCheck]
[-SslProtocol <WebSslProtocol>]
[-Token <SecureString>]
[-UserAgent <String>]
[-DisableKeepAlive]
[-TimeoutSec <Int32>]
[-Headers <IDictionary>]
[-MaximumRedirection <Int32>]
[-MaximumRetryCount <Int32>]
[-RetryIntervalSec <Int32>]
[-Method <WebRequestMethod>]
[-Proxy <Uri>]
[-ProxyCredential <PSCredential>]
[-ProxyUseDefaultCredentials]
[-Body <Object>]
[-Form <IDictionary>]
[-ContentType <String>]
[-TransferEncoding <String>]
[-InFile <String>]
[-OutFile <String>]
[-PassThru]
[-Resume]
[-SkipHttpErrorCheck]
[-PreserveAuthorizationOnRedirect]
[-SkipHeaderValidation]
[<CommonParameters>]
Invoke-WebRequest
[-UseBasicParsing]
[-Uri] <Uri>
[-HttpVersion <Version>]
[-WebSession <WebRequestSession>]
[-SessionVariable <String>]
[-AllowUnencryptedAuthentication]
[-Authentication <WebAuthenticationType>]
[-Credential <PSCredential>]
[-UseDefaultCredentials]
[-CertificateThumbprint <String>]
[-Certificate <X509Certificate>]
[-SkipCertificateCheck]
[-SslProtocol <WebSslProtocol>]
[-Token <SecureString>]
[-UserAgent <String>]
[-DisableKeepAlive]
[-TimeoutSec <Int32>]
[-Headers <IDictionary>]
[-MaximumRedirection <Int32>]
[-MaximumRetryCount <Int32>]
[-RetryIntervalSec <Int32>]
[-Method <WebRequestMethod>]
-NoProxy
[-Body <Object>]
[-Form <IDictionary>]
[-ContentType <String>]
[-TransferEncoding <String>]
[-InFile <String>]
[-OutFile <String>]
[-PassThru]
[-Resume]
[-SkipHttpErrorCheck]
[-PreserveAuthorizationOnRedirect]
[-SkipHeaderValidation]
[<CommonParameters>]
Invoke-WebRequest
[-UseBasicParsing]
[-Uri] <Uri>
[-HttpVersion <Version>]
[-WebSession <WebRequestSession>]
[-SessionVariable <String>]
[-AllowUnencryptedAuthentication]
[-Authentication <WebAuthenticationType>]
[-Credential <PSCredential>]
[-UseDefaultCredentials]
[-CertificateThumbprint <String>]
[-Certificate <X509Certificate>]
[-SkipCertificateCheck]
[-SslProtocol <WebSslProtocol>]
[-Token <SecureString>]
[-UserAgent <String>]
[-DisableKeepAlive]
[-TimeoutSec <Int32>]
[-Headers <IDictionary>]
[-MaximumRedirection <Int32>]
[-MaximumRetryCount <Int32>]
[-RetryIntervalSec <Int32>]
-CustomMethod <String>
[-Proxy <Uri>]
[-ProxyCredential <PSCredential>]
[-ProxyUseDefaultCredentials]
[-Body <Object>]
[-Form <IDictionary>]
[-ContentType <String>]
[-TransferEncoding <String>]
[-InFile <String>]
[-OutFile <String>]
[-PassThru]
[-Resume]
[-SkipHttpErrorCheck]
[-PreserveAuthorizationOnRedirect]
[-SkipHeaderValidation]
[<CommonParameters>]
Invoke-WebRequest
[-UseBasicParsing]
[-Uri] <Uri>
[-HttpVersion <Version>]
[-WebSession <WebRequestSession>]
[-SessionVariable <String>]
[-AllowUnencryptedAuthentication]
[-Authentication <WebAuthenticationType>]
[-Credential <PSCredential>]
[-UseDefaultCredentials]
[-CertificateThumbprint <String>]
[-Certificate <X509Certificate>]
[-SkipCertificateCheck]
[-SslProtocol <WebSslProtocol>]
[-Token <SecureString>]
[-UserAgent <String>]
[-DisableKeepAlive]
[-TimeoutSec <Int32>]
[-Headers <IDictionary>]
[-MaximumRedirection <Int32>]
[-MaximumRetryCount <Int32>]
[-RetryIntervalSec <Int32>]
-CustomMethod <String>
-NoProxy
[-Body <Object>]
[-Form <IDictionary>]
[-ContentType <String>]
[-TransferEncoding <String>]
[-InFile <String>]
[-OutFile <String>]
[-PassThru]
[-Resume]
[-SkipHttpErrorCheck]
[-PreserveAuthorizationOnRedirect]
[-SkipHeaderValidation]
[<CommonParameters>]
Descrizione
Il Invoke-WebRequest
cmdlet invia richieste HTTP e HTTPS a una pagina Web o a un servizio Web. Analizza la risposta e restituisce raccolte di collegamenti, immagini e altri elementi HTML significativi.
Questo cmdlet è stato introdotto in PowerShell 3.0.
A partire da PowerShell 7.0, Invoke-WebRequest
supporta la configurazione proxy definita dalle variabili di ambiente. Vedere la sezione Note di questo articolo.
Importante
Gli esempi di questo articolo fanno riferimento agli host nel contoso.com
dominio. Si tratta di un dominio fittizio usato da Microsoft per esempi. Gli esempi sono progettati per illustrare come usare i cmdlet.
Tuttavia, poiché i contoso.com
siti non esistono, gli esempi non funzionano. Adattare gli esempi agli host nell'ambiente.
Esempio
Esempio 1: Inviare una richiesta Web
In questo esempio viene usato il Invoke-WebRequest
cmdlet per inviare una richiesta Web al sito Bing.com.
$Response = Invoke-WebRequest -URI https://www.bing.com/search?q=how+many+feet+in+a+mile
$Response.InputFields | Where-Object {
$_.name -like "* Value*"
} | Select-Object Name, Value
name value
---- -----
From Value 1
To Value 5280
Il primo comando genera la richiesta e salva la risposta nella $Response
variabile.
Il secondo comando ottiene qualsiasi oggetto InputField in cui la proprietà Name è simile "* Value"
a . I risultati filtrati vengono inviati tramite pipe per Select-Object
selezionare le proprietà Nome e Valore .
Esempio 2: Usare un servizio Web con stato
In questo esempio viene illustrato come usare il Invoke-WebRequest
cmdlet con un servizio Web con stato.
$LoginParameters = @{
Uri = 'https://www.contoso.com/login/'
SessionVariable = 'Session'
Method = 'POST'
Body = @{
User = 'jdoe'
Password = 'P@S$w0rd!'
}
}
$LoginResponse = Invoke-WebRequest @LoginParameters
$ProfileResponse = Invoke-WebRequest 'https://www.contoso.com/profile/' -WebSession $Session
La prima chiamata a invia una richiesta di Invoke-WebRequest
accesso. Il comando specifica un valore di Session
per il valore del parametro SessionVariable . Al termine del comando, la $LoginResponse
variabile contiene un oggetto BasicHtmlWebResponseObject e la $Session
variabile contiene un WebRequestSession
oggetto . Questo registra l'utente nel sito.
La seconda chiamata a Invoke-WebRequest
recupera il profilo dell'utente, che richiede l'accesso dell'utente al sito. I dati di $Session
sessione archiviati nella variabile forniscono cookie di sessione al sito creato durante l'accesso.
Esempio 3: Ottenere collegamenti da una pagina Web
Questo esempio ottiene i collegamenti in una pagina Web. Usa il cmdlet per ottenere il Invoke-WebRequest
contenuto della pagina Web. Usa quindi la proprietà Links di BasicHtmlWebResponseObject che Invoke-WebRequest
restituisce e la proprietà Href di ogni collegamento.
(Invoke-WebRequest -Uri "https://aka.ms/pscore6-docs").Links.Href
Esempio 4: Scrivere contenuto della risposta in un file usando la codifica definita nella pagina richiesta
In questo esempio viene usato il cmdlet per recuperare il Invoke-WebRequest
contenuto della pagina Web di una pagina della documentazione di PowerShell.
$Response = Invoke-WebRequest -Uri "https://aka.ms/pscore6-docs"
$Stream = [System.IO.StreamWriter]::new('.\docspage.html', $false, $Response.Encoding)
try {
$Stream.Write($Response.Content)
} finally {
$Stream.Dispose()
}
Il primo comando recupera la pagina e salva l'oggetto risposta nella $Response
variabile.
Il secondo comando crea un oggetto StreamWriter da usare per scrivere il contenuto della risposta in un file. La proprietà Encoding dell'oggetto response viene usata per impostare la codifica per il file.
I comandi finali scrivono la proprietà Content nel file e quindi eliminano StreamWriter.
Si noti che la proprietà Encoding è Null se la richiesta Web non restituisce il contenuto di testo.
Esempio 5: Inviare un file multipart/form-data
In questo esempio viene usato il Invoke-WebRequest
cmdlet caricare un file come multipart/form-data
invio. Il file c:\document.txt
viene inviato come campo document
modulo con l'oggetto Content-Type
.text/plain
$FilePath = 'c:\document.txt'
$FieldName = 'document'
$ContentType = 'text/plain'
$FileStream = [System.IO.FileStream]::new($filePath, [System.IO.FileMode]::Open)
$FileHeader = [System.Net.Http.Headers.ContentDispositionHeaderValue]::new('form-data')
$FileHeader.Name = $FieldName
$FileHeader.FileName = Split-Path -leaf $FilePath
$FileContent = [System.Net.Http.StreamContent]::new($FileStream)
$FileContent.Headers.ContentDisposition = $FileHeader
$FileContent.Headers.ContentType = [System.Net.Http.Headers.MediaTypeHeaderValue]::Parse($ContentType)
$MultipartContent = [System.Net.Http.MultipartFormDataContent]::new()
$MultipartContent.Add($FileContent)
$Response = Invoke-WebRequest -Body $MultipartContent -Method 'POST' -Uri 'https://api.contoso.com/upload'
Esempio 6: Invio di dati multipart/form-data semplificato
Alcune API richiedono multipart/form-data
invii per caricare file e contenuto misto. In questo esempio viene illustrato l'aggiornamento di un profilo utente.
$Uri = 'https://api.contoso.com/v2/profile'
$Form = @{
firstName = 'John'
lastName = 'Doe'
email = 'john.doe@contoso.com'
avatar = Get-Item -Path 'c:\Pictures\jdoe.png'
birthday = '1980-10-15'
hobbies = 'Hiking','Fishing','Jogging'
}
$Result = Invoke-WebRequest -Uri $Uri -Method Post -Form $Form
Il modulo del profilo richiede questi campi: firstName
, email
lastName
avatar
, birthday
e .hobbies
L'API prevede l'inserimento di un'immagine per l'immagine del profilo utente nel avatar
campo. L'API accetta anche più hobbies
voci da inviare nello stesso modulo.
Quando si crea $Form
hashTable, i nomi delle chiavi vengono usati come nomi dei campi del modulo. Per impostazione predefinita, i valori di HashTable vengono convertiti in stringhe. Se è presente un valore System.IO.FileInfo , il contenuto del file viene inviato. Se sono presenti una raccolta, ad esempio matrici o elenchi, il campo modulo viene inviato più volte.
Usando Get-Item
la chiave, l'oggetto avatar
FileInfo
viene impostato come valore. Il risultato è che i dati dell'immagine per jdoe.png
vengono inviati.
Fornendo un elenco alla chiave, il hobbies
campo è presente negli invii una volta per ogni elemento dell'elencohobbies
.
Esempio 7: Rilevare messaggi non riusciti da Invoke-WebRequest
Quando Invoke-WebRequest
si verifica un messaggio HTTP non riuscito (404, 500 e così via), non restituisce alcun output e genera un errore di terminazione. Per rilevare l'errore e visualizzare statusCode , è possibile racchiudere l'esecuzione in un try/catch
blocco.
try
{
$Response = Invoke-WebRequest -Uri "www.microsoft.com/unkownhost"
# This will only execute if the Invoke-WebRequest is successful.
$StatusCode = $Response.StatusCode
} catch {
$StatusCode = $_.Exception.Response.StatusCode.value__
}
$StatusCode
404
L'errore di terminazione viene rilevato dal catch
blocco, che recupera statusCode dall'oggetto Exception .
Esempio 8: Scaricare più file contemporaneamente
Il Invoke-WebRequest
cmdlet può scaricare un solo file alla volta. Nell'esempio seguente viene Start-ThreadJob
usato per creare più processi di thread per scaricare più file contemporaneamente.
$baseUri = 'https://github.com/PowerShell/PowerShell/releases/download'
$files = @(
@{
Uri = "$baseUri/v7.3.0-preview.5/PowerShell-7.3.0-preview.5-win-x64.msi"
OutFile = 'PowerShell-7.3.0-preview.5-win-x64.msi'
},
@{
Uri = "$baseUri/v7.3.0-preview.5/PowerShell-7.3.0-preview.5-win-x64.zip"
OutFile = 'PowerShell-7.3.0-preview.5-win-x64.zip'
},
@{
Uri = "$baseUri/v7.2.5/PowerShell-7.2.5-win-x64.msi"
OutFile = 'PowerShell-7.2.5-win-x64.msi'
},
@{
Uri = "$baseUri/v7.2.5/PowerShell-7.2.5-win-x64.zip"
OutFile = 'PowerShell-7.2.5-win-x64.zip'
}
)
$jobs = @()
foreach ($file in $files) {
$jobs += Start-ThreadJob -Name $file.OutFile -ScriptBlock {
$params = $using:file
Invoke-WebRequest @params
}
}
Write-Host "Downloads started..."
Wait-Job -Job $jobs
foreach ($job in $jobs) {
Receive-Job -Job $job
}
Esempio 9: Ignora convalida intestazione
Per impostazione predefinita, il Invoke-WebRequest
cmdlet convalida i valori delle intestazioni note con un formato di valore definito dagli standard. Nell'esempio seguente viene illustrato come la convalida può generare un errore e come usare il parametro SkipHeaderValidation per evitare la convalida dei valori per gli endpoint che tollerano valori formattati non validi.
$Uri = 'https://httpbin.org/headers'
$InvalidHeaders = @{
'If-Match' = '12345'
}
Invoke-WebRequest -Uri $Uri -Headers $InvalidHeaders
Invoke-WebRequest -Uri $Uri -Headers $InvalidHeaders -SkipHeaderValidation
Invoke-WebRequest: The format of value '12345' is invalid.
StatusCode : 200
StatusDescription : OK
Content : {
"headers": {
"Host": "httpbin.org",
"If-Match": "12345",
"User-Agent": "Mozilla/5.0 (Windows NT 10.0; Microsoft Windows 10.0.19044; en-US) PowerShell/7.2.5",
"X-Amzn-Trace-Id": �
RawContent : HTTP/1.1 200 OK
Date: Mon, 08 Aug 2022 16:24:24 GMT
Connection: keep-alive
Server: gunicorn/19.9.0
Access-Control-Allow-Origin: *
Access-Control-Allow-Credentials: true
Content-Type: application�
Headers : {[Date, System.String[]], [Connection, System.String[]], [Server, System.String[]], [Access-Control-Allow-Origin, System.String[]]�}
Images : {}
InputFields : {}
Links : {}
RawContentLength : 249
RelationLink : {}
httpbin.org è un servizio che restituisce informazioni sulle richieste Web e sulle risposte per la risoluzione dei problemi. La $Uri
variabile viene assegnata all'endpoint /headers
del servizio, che restituisce le intestazioni di una richiesta come contenuto nella risposta.
L'intestazione della If-Match
richiesta è definita nella sezione RFC-7232 3.1 e richiede che il valore dell'intestazione venga definito con virgolette circostanti. La $InvalidHeaders
variabile viene assegnata a una tabella hash in cui il valore di If-Match
non è valido perché è definito come 12345
anziché "12345"
.
La chiamata Invoke-WebRequest
con le intestazioni non valide restituisce una segnalazione di errore che il valore formattato non è valido. La richiesta non viene inviata all'endpoint.
La chiamata Invoke-WebRequest
con il parametro SkipHeaderValidation ignora l'errore di convalida e invia la richiesta all'endpoint. Poiché l'endpoint tollera valori di intestazione non conformi, il cmdlet restituisce l'oggetto response senza errori.
Esempio 10: Inviare una richiesta usando HTTP 2.0
Questo esempio ottiene i collegamenti in una pagina Web usando il protocollo HTTP 2.0. Usa il cmdlet per ottenere il Invoke-WebRequest
contenuto della pagina Web. Usa quindi la proprietà Links di BasicHtmlWebResponseObject che Invoke-WebRequest
restituisce e la proprietà Href di ogni collegamento.
(Invoke-WebRequest -Uri 'https://aka.ms/pscore6-docs' -HttpVersion 2.0).Links.Href
Parametri
-AllowUnencryptedAuthentication
Consente l'invio di credenziali e segreti su connessioni non crittografate. Per impostazione predefinita, la fornitura di credenziali o qualsiasi opzione di autenticazione con un URI che non inizia con https://
i risultati di un errore e la richiesta viene interrotta per impedire la comunicazione involontaria dei segreti in testo normale tramite connessioni non crittografate. Per eseguire l'override di questo comportamento a proprio rischio, specificare il parametro AllowUnencryptedAuthentication .
Avviso
L'uso di questo parametro non è sicuro e non è consigliato. Viene fornito solo per la compatibilità con i sistemi legacy che non possono fornire connessioni crittografate. Usare a proprio rischio.
Questa funzionalità è stata aggiunta in PowerShell 6.0.0.
Type: | SwitchParameter |
Position: | Named |
Default value: | False |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-Authentication
Specifica il tipo di autenticazione esplicito da usare per la richiesta. L'impostazione predefinita è None (Nessuna). Impossibile usare il parametro Authentication con il parametro UseDefaultCredentials .
Opzioni di autenticazione disponibili:
None
: questa è l'opzione predefinita quando l'autenticazione non è specificata. Non viene usata alcuna autenticazione esplicita.Basic
: richiede credenziali. Le credenziali vengono inviate come intestazione di autenticazioneAuthorization: Basic
di base RFC 7617 nel formatobase64(user:password)
di .Bearer
: richiede il parametro Token . Invia un'intestazione RFC 6750Authorization: Bearer
con il token fornito.OAuth
: richiede il parametro Token . Invia un'intestazione RFC 6750Authorization: Bearer
con il token fornito.
L'autenticazione esegue l'override di tutte Authorization
le intestazioni fornite alle intestazioni o incluse in WebSession.
Questa funzionalità è stata aggiunta in PowerShell 6.0.0.
Type: | WebAuthenticationType |
Accepted values: | None, Basic, Bearer, OAuth |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-Body
Specifica il corpo della richiesta. Il corpo corrisponde al contenuto della richiesta che segue le intestazioni.
È anche possibile inviare un valore del corpo a Invoke-WebRequest
.
Il parametro Body può essere usato per specificare un elenco di parametri di query o il contenuto della risposta.
Quando l'input è una richiesta POST e il corpo è un valore String, il valore a sinistra del primo segno di uguale (=
) viene impostato come chiave nei dati del modulo e il testo rimanente viene impostato come valore. Per specificare più chiavi, usare un oggetto IDictionary, ad esempio una tabella hash, per corpo.
Quando l'input è una richiesta GET e il corpo è un IDictionary (in genere, una tabella hash), il corpo viene aggiunto all'URI come parametri di query. Per altri tipi di richiesta ,ad esempio PATCH, il corpo viene impostato come valore del corpo della richiesta nel formato standard name=value
con i valori codificati con URL.
Quando l'input è un System.Xml. L'oggetto XmlNode e la dichiarazione XML specifica una codifica che viene usata per i dati nella richiesta, a meno che non venga eseguito l'override del parametro ContentType .
Il parametro Body accetta anche un System.Net.Http.MultipartFormDataContent
oggetto. Ciò facilita le multipart/form-data
richieste. Quando viene fornito un oggetto MultipartFormDataContent per Body, le intestazioni correlate al contenuto fornite ai parametri ContentType, Headers o WebSession vengono sostituite dalle intestazioni Content dell'oggetto MultipartFormDataContent . Questa funzionalità è stata aggiunta in PowerShell 6.0.0.
Type: | Object |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | True |
Accept wildcard characters: | False |
-Certificate
Specifica il certificato client usato per una richiesta Web sicura. Immettere una variabile che contiene un certificato oppure un comando o un'espressione che ottiene il certificato.
Per trovare un certificato, usare o usare Get-PfxCertificate
il cmdlet nell'unità Get-ChildItem
Certificato (Cert:
). Se il certificato non è valido o non ha un'autorità sufficiente, il comando ha esito negativo.
Type: | X509Certificate |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-CertificateThumbprint
Specifica il certificato di chiave pubblica digitale (X509) di un account utente con autorizzazione per l'invio della richiesta. Immettere l'identificazione personale del certificato.
I certificati vengono usati nell'autenticazione basata sui certificati client. I certificati possono essere mappati solo agli account utente locali, non agli account di dominio.
Per visualizzare l'identificazione personale del certificato, usare il Get-Item
comando o Get-ChildItem
per trovare il certificato in Cert:\CurrentUser\My
.
Nota
Questa funzionalità è supportata solo nelle piattaforme del sistema operativo Windows.
Type: | String |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-ContentType
Specifica il tipo di contenuto della richiesta Web.
Se il valore per ContentType contiene il formato di codifica (come charset
), il cmdlet usa tale formato per codificare il corpo della richiesta Web. Se contentType non specifica un formato di codifica, viene usato invece il formato di codifica predefinito. Un esempio di ContentType con un formato di codifica è text/plain; charset=iso-8859-5
, che specifica l'alfabeto latino/cirillico .
Se questo parametro viene omesso e il metodo request è POST, Invoke-WebRequest
imposta il tipo di contenuto su application/x-www-form-urlencoded
. In caso contrario, il tipo di contenuto non viene specificato nella chiamata.
ContentType viene sottoposto a override quando viene fornito un oggetto MultipartFormDataContent per Body.
Type: | String |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-Credential
Specifica un account utente che dispone dell'autorizzazione per l'invio della richiesta. Il valore predefinito è l'utente corrente.
Digitare un nome utente, ad esempio User01 o Domain01\User01 oppure immettere un oggetto PSCredential generato dal Get-Credential
cmdlet.
Le credenziali possono essere usate solo o in combinazione con determinate opzioni di parametro di autenticazione . Se usato da solo, fornisce solo le credenziali al server remoto se il server remoto invia una richiesta di autenticazione. Quando viene usato con le opzioni di autenticazione , le credenziali vengono inviate in modo esplicito.
Le credenziali vengono archiviate in un oggetto PSCredential e la password viene archiviata come SecureString.
Nota
Per altre informazioni sulla protezione dei dati SecureString , vedere How secure is SecureString?.
Type: | PSCredential |
Position: | Named |
Default value: | Current user |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-CustomMethod
Specifica un metodo personalizzato usato per la richiesta Web. Questa operazione può essere usata se il metodo request richiesto dall'endpoint non è un'opzione disponibile nel metodo. Il metodo e CustomMethod non possono essere usati insieme.
In questo esempio viene eseguita una TEST
richiesta HTTP all'API:
Invoke-WebRequest -uri 'https://api.contoso.com/widget/' -CustomMethod 'TEST'
Questa funzionalità è stata aggiunta in PowerShell 6.0.0.
Type: | String |
Aliases: | CM |
Position: | Named |
Default value: | None |
Required: | True |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-DisableKeepAlive
Indica che il cmdlet imposta il valore KeepAlive nell'intestazione HTTP su False. Per impostazione predefinita, KeepAlive è True. KeepAlive stabilisce una connessione permanente al server per semplificare le richieste successive.
Type: | SwitchParameter |
Position: | Named |
Default value: | False |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-Form
Converte un dizionario in un multipart/form-data
invio. Il modulo può non essere usato con Corpo.
Se viene usato ContentType , viene ignorato.
Le chiavi del dizionario vengono usate come nomi dei campi del modulo. Per impostazione predefinita, i valori del modulo vengono convertiti in valori stringa.
Se il valore è un oggetto System.IO.FileInfo , il contenuto del file binario viene inviato. Il nome del file viene inviato come proprietà nome file . Il tipo MIME è impostato come application/octet-stream
. Get-Item
può essere usato per semplificare la fornitura dell'oggetto System.IO.FileInfo .
$Form = @{ resume = Get-Item 'c:\Users\jdoe\Documents\John Doe.pdf' }
Se il valore è un tipo di raccolta, tali matrici o Elenchi, il campo per il campo viene inviato più volte. I valori dell'elenco vengono considerati come stringhe per impostazione predefinita. Se il valore è un oggetto System.IO.FileInfo , il contenuto del file binario viene inviato. Le raccolte annidate non sono supportate.
$Form = @{ tag = 'Vacation', 'Italy', '2017' pictures = Get-ChildItem 'c:\Users\jdoe\Pictures\2017-Italy' }
Nell'esempio precedente il tags
campo viene fornito tre volte nel formato, una volta per ognuno di Vacation
, Italy
e 2017
. Il pictures
campo viene inviato anche una volta per ogni file nella 2017-Italy
cartella. Il contenuto binario dei file nella cartella viene inviato come valori.
Questa funzionalità è stata aggiunta in PowerShell 6.1.0.
Type: | IDictionary |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-Headers
Specifica le intestazioni della richiesta Web. Immettere una tabella hash o un dizionario.
Le intestazioni correlate al contenuto, ad esempio Content-Type
vengono sostituite quando viene fornito un oggetto MultipartFormDataContent per Body.
Type: | IDictionary |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-HttpVersion
Specifica la versione HTTP usata per la richiesta. Il valore predefinito è 1.1
.
I valori validi sono:
- 1.0
- 1,1
- 2.0
- 3,0
Type: | Version |
Position: | Named |
Default value: | 1.1 |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-InFile
Ottiene il contenuto della richiesta Web da un file. Immettere un percorso e un nome file. Se si omette il percorso, l'impostazione predefinita è il percorso corrente.
Type: | String |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-MaximumRedirection
Specifica quante volte PowerShell reindirizza una connessione a un URI (Uniform Resource Identifier) alternativo prima che la connessione non riesca. Il valore predefinito è 5. Il valore 0 (zero) impedisce qualsiasi reindirizzamento.
Type: | Int32 |
Position: | Named |
Default value: | 5 |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-MaximumRetryCount
Specifica quante volte PowerShell ritenta una connessione quando viene ricevuto un codice di errore compreso tra 400 e 599 inclusi o 304. Vedere anche Il parametro RetryIntervalSec per specificare il numero di tentativi.
Type: | Int32 |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-Method
Specifica il metodo usato per la richiesta Web. I valori validi per questo parametro sono:
Default
Delete
Get
Head
Merge
Options
Patch
Post
Put
Trace
Il parametro CustomMethod può essere usato per i metodi di richiesta non elencati in precedenza.
Type: | WebRequestMethod |
Accepted values: | Default, Get, Head, Post, Put, Delete, Trace, Options, Merge, Patch |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-NoProxy
Indica che il cmdlet non deve usare un proxy per raggiungere la destinazione. Quando è necessario ignorare il proxy configurato nell'ambiente, usare questa opzione. Questa funzionalità è stata aggiunta in PowerShell 6.0.0.
Type: | SwitchParameter |
Position: | Named |
Default value: | False |
Required: | True |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-OutFile
Specifica il file di output per il quale questo cmdlet salva il corpo della risposta. Immettere un percorso e un nome file.
Se si omette il percorso, l'impostazione predefinita è il percorso corrente. Il nome viene considerato come un percorso letterale.
I nomi contenenti parentesi quadre ([]
) devono essere racchiusi tra virgolette singole ('
).
Per impostazione predefinita, Invoke-WebRequest
restituisce i risultati alla pipeline. Per inviare i risultati a un file e alla pipeline, usare il parametro Passthru.
Type: | String |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-PassThru
Indica che il cmdlet restituisce i risultati, oltre a scriverli in un file. Questo parametro è valido solo quando nel comando viene usato anche il parametro OutFile.
Type: | SwitchParameter |
Position: | Named |
Default value: | False |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-PreserveAuthorizationOnRedirect
Indica che il cmdlet deve mantenere l'intestazione Authorization
, quando presente, tra reindirizzamenti.
Per impostazione predefinita, il cmdlet rimuove l'intestazione Authorization
prima del reindirizzamento. Se si specifica questo parametro, questa logica viene disabilitata nei casi in cui l'intestazione deve essere inviata al percorso di reindirizzamento.
Questa funzionalità è stata aggiunta in PowerShell 6.0.0.
Type: | SwitchParameter |
Position: | Named |
Default value: | False |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-Proxy
Specifica un server proxy per la richiesta, anziché connettersi direttamente alla risorsa Internet. Immettere l'URI di un server proxy di rete.
Type: | Uri |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-ProxyCredential
Specifica un account utente autorizzato a usare il server proxy specificato dal parametro Proxy . Il valore predefinito è l'utente corrente.
Digitare un nome utente, ad esempio User01
o Domain01\User01
, oppure immettere un oggetto PSCredential , ad esempio uno generato dal Get-Credential
cmdlet .
Questo parametro è valido solo quando il parametro Proxy viene usato anche nel comando . Non è possibile usare i parametri ProxyCredential e ProxyUseDefaultCredentials nello stesso comando.
Type: | PSCredential |
Position: | Named |
Default value: | Current user |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-ProxyUseDefaultCredentials
Indica che il cmdlet usa le credenziali dell'utente corrente per accedere al server proxy specificato dal parametro Proxy .
Questo parametro è valido solo quando il parametro Proxy viene usato anche nel comando . Non è possibile usare i parametri ProxyCredential e ProxyUseDefaultCredentials nello stesso comando.
Type: | SwitchParameter |
Position: | Named |
Default value: | False |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-Resume
Esegue un tentativo ottimale di riprendere il download di un file parziale. Resume richiede OutFile.
La ripresa opera solo sulle dimensioni del file locale e del file remoto e non esegue altre convalide che il file locale e il file remoto siano uguali.
Se le dimensioni del file locale sono inferiori alle dimensioni del file remoto, il cmdlet tenta di riprendere il download del file e accoda i byte rimanenti alla fine del file.
Se le dimensioni del file locale corrispondono alle dimensioni del file remoto, non viene eseguita alcuna azione e il cmdlet presuppone che il download sia già stato completato.
Se le dimensioni del file locale sono maggiori delle dimensioni del file remoto, il file locale viene sovrascritto e l'intero file remoto viene nuovamente scaricato. Questo comportamento equivale all'uso di OutFile senza Resume.
Se il server remoto non supporta la ripresa del download, il file locale viene sovrascritto e l'intero file remoto viene nuovamente scaricato. Questo comportamento equivale all'uso di OutFile senza Resume.
Se il file locale non esiste, viene creato il file locale e viene scaricato l'intero file remoto. Questo comportamento equivale all'uso di OutFile senza Resume.
Questa funzionalità è stata aggiunta in PowerShell 6.1.0.
Type: | SwitchParameter |
Position: | Named |
Default value: | False |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-RetryIntervalSec
Specifica l'intervallo tra tentativi per la connessione quando viene ricevuto un codice di errore compreso tra 400 e 599 inclusi o 304. Vedere anche Il parametro MaximumRetryCount per specificare il numero di tentativi. Il valore deve essere compreso tra 1
e [int]::MaxValue
.
Type: | Int32 |
Position: | Named |
Default value: | 5 |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-SessionVariable
Specifica una variabile per la quale questo cmdlet crea una sessione di richiesta Web e la salva nel valore .
Immettere un nome di variabile senza il simbolo del simbolo del dollaro ($
).
Quando si specifica una variabile di sessione, Invoke-WebRequest
crea un oggetto sessione di richiesta Web e lo assegna a una variabile con il nome specificato nella sessione di PowerShell. È possibile usare la variabile nella sessione appena il comando termina l'esecuzione.
Prima di PowerShell 7.4, la sessione di richiesta Web non è una connessione permanente. Si tratta di un oggetto che contiene informazioni sulla connessione e sulla richiesta, inclusi cookie, credenziali, il valore massimo di reindirizzamento e la stringa dell'agente utente. È possibile usarlo per condividere lo stato e i dati tra le richieste Web.
A partire da PowerShell 7.4, la sessione di richiesta Web è persistente, purché le proprietà della sessione non vengano sottoposte a override in una richiesta successiva. Quando sono, il cmdlet ricrea la sessione con i nuovi valori. Le sessioni persistenti riducono il sovraccarico per le richieste ripetute, rendendole molto più veloci.
Per usare la sessione di richieste Web in richieste Web successive, specificare la variabile di sessione nel valore del parametro WebSession. PowerShell usa i dati nell'oggetto sessione di richiesta Web quando si stabilisce la nuova connessione. Per eseguire l'override di un valore nella sessione di richieste Web, usare un parametro del cmdlet come UserAgent o Credential. I valori di parametro hanno la precedenza sui valori nella sessione di richieste Web.
Non è possibile usare i parametri SessionVariable e WebSession nello stesso comando.
Type: | String |
Aliases: | SV |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-SkipCertificateCheck
Ignora i controlli di convalida dei certificati. Sono incluse tutte le convalide, ad esempio scadenza, revoca, autorità radice attendibile e così via.
Avviso
L'uso di questo parametro non è sicuro e non è consigliato. Questa opzione deve essere usata solo per gli host noti usando un certificato autofirmato a scopo di test. Usare a proprio rischio.
Questa funzionalità è stata aggiunta in PowerShell 6.0.0.
Type: | SwitchParameter |
Position: | Named |
Default value: | False |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-SkipHeaderValidation
Indica che il cmdlet deve aggiungere intestazioni alla richiesta senza convalida.
Questa opzione deve essere usata per i siti che richiedono valori di intestazione non conformi agli standard. Se si specifica questa opzione, la convalida viene disabilitata per consentire il passaggio del valore deselezionato. Se specificato, tutte le intestazioni vengono aggiunte senza convalida.
Questa opzione disabilita la convalida per i valori passati ai parametri ContentType, Headers e UserAgent .
Questa funzionalità è stata aggiunta in PowerShell 6.0.0.
Type: | SwitchParameter |
Position: | Named |
Default value: | False |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-SkipHttpErrorCheck
Questo parametro fa sì che il cmdlet ignori gli stati di errore HTTP e continui a elaborare le risposte. Le risposte di errore vengono scritte nella pipeline esattamente come se avessero esito positivo.
Questo parametro è stato introdotto in PowerShell 7.
Type: | SwitchParameter |
Position: | Named |
Default value: | False |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-SslProtocol
Imposta i protocolli SSL/TLS consentiti per la richiesta Web. Per impostazione predefinita, sono consentiti tutti i protocolli SSL/TLS supportati dal sistema. SslProtocol consente di limitare protocolli specifici a scopo di conformità.
Questi valori sono definiti come enumerazione basata su flag. È possibile combinare più valori per impostare più flag usando questo parametro. I valori possono essere passati al parametro SslProtocol come matrice di valori o come stringa delimitata da virgole di tali valori. Il cmdlet combina i valori usando un'operazione binary-OR. Il passaggio di valori come matrice è l'opzione più semplice e consente anche di usare il completamento tramite tabulazione sui valori. Potrebbe non essere possibile definire più opzioni in tutte le piattaforme.
Nota
Nelle piattaforme non Windows potrebbe non essere possibile fornire Tls
o Tls12
come opzione. Il supporto per Tls13
non è disponibile in tutti i sistemi operativi e deve essere verificato per ogni sistema operativo.
Questa funzionalità è stata aggiunta in PowerShell 6.0.0 e il supporto per Tls13
è stato aggiunto in PowerShell 7.1.
Type: | WebSslProtocol |
Accepted values: | Default, Tls, Tls11, Tls12 |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-TimeoutSec
Specifica per quanto tempo la richiesta può essere in sospeso prima del timeout. Immettere un valore in secondi. Il valore predefinito, 0, specifica un timeout indefinito.
La restituzione o il timeout di una query DNS (Domain Name System) può richiedere fino a 15 secondi. Se la richiesta contiene un nome host che richiede la risoluzione e si imposta TimeoutSec su un valore maggiore di zero, ma meno di 15 secondi, possono essere necessari 15 secondi o più prima che venga generata un'eccezione WebException e il timeout della richiesta.
Type: | Int32 |
Position: | Named |
Default value: | 0 |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-Token
Token OAuth o Bearer da includere nella richiesta. Il token è richiesto da determinate opzioni di autenticazione . Non può essere usato in modo indipendente.
Il token accetta un SecureString
oggetto contenente il token. Per fornire il token manualmente, usare quanto segue:
Invoke-WebRequest -Uri $uri -Authentication OAuth -Token (Read-Host -AsSecureString)
Questo parametro è stato introdotto in PowerShell 6.0.
Type: | SecureString |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-TransferEncoding
Specifica un valore per l'intestazione della risposta HTTP con codifica di trasferimento. I valori validi per questo parametro sono:
Chunked
Compress
Deflate
GZip
Identity
Type: | String |
Accepted values: | chunked, compress, deflate, gzip, identity |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-Uri
Specifica l'URI (Uniform Resource Identifier) della risorsa Internet a cui viene inviata la richiesta Web. Immettere un URI. Questo parametro supporta solo HTTP o HTTPS.
Questo parametro è obbligatorio. L'URI del nome del parametro è facoltativo.
Type: | Uri |
Position: | 0 |
Default value: | None |
Required: | True |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-UseBasicParsing
Questo parametro è stato deprecato. A partire da PowerShell 6.0.0, tutte le richieste Web usano solo l'analisi di base. Questo parametro è incluso solo per la compatibilità con le versioni precedenti e qualsiasi uso di esso non ha alcun effetto sull'operazione del cmdlet.
Type: | SwitchParameter |
Position: | Named |
Default value: | False |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-UseDefaultCredentials
Indica che il cmdlet usa le credenziali dell'utente corrente per inviare la richiesta Web. Non può essere usato con l'autenticazione o la credenziale e potrebbe non essere supportato in tutte le piattaforme.
Type: | SwitchParameter |
Position: | Named |
Default value: | False |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-UserAgent
Specifica una stringa agente utente per la richiesta Web.
L'agente utente predefinito è simile a Mozilla/5.0 (Windows NT 10.0; Microsoft Windows 10.0.15063; en-US) PowerShell/6.0.0
con lievi variazioni per ogni sistema operativo e piattaforma.
Per testare un sito Web con la stringa dell'agente utente standard usata dalla maggior parte dei browser Internet, usare le proprietà della classe PSUserAgent , ad esempio Chrome, FireFox, InternetExplorer, Opera e Safari.
Ad esempio, il comando seguente usa la stringa dell'agente utente per Internet Explorer: Invoke-WebRequest -Uri https://website.com/ -UserAgent ([Microsoft.PowerShell.Commands.PSUserAgent]::InternetExplorer)
Type: | String |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-WebSession
Specifica una sessione di richieste Web. Immettere il nome della variabile, incluso il segno di dollaro ($
).
Per eseguire l'override di un valore nella sessione di richieste Web, usare un parametro del cmdlet come UserAgent o Credential. I valori di parametro hanno la precedenza sui valori nella sessione di richieste Web. Anche le intestazioni correlate al contenuto, ad esempio Content-Type
, vengono sottoposte a override quando viene fornito un oggetto MultipartFormDataContent per Body.
A differenza di una sessione remota, la sessione di richiesta Web non è una connessione permanente. Si tratta di un oggetto che contiene informazioni sulla connessione e sulla richiesta, inclusi cookie, credenziali, il valore massimo di reindirizzamento e la stringa dell'agente utente. È possibile usarlo per condividere lo stato e i dati tra le richieste Web.
Per creare una sessione di richiesta Web, immettere un nome di variabile, senza un segno di dollaro, nel valore del parametro SessionVariable di un Invoke-WebRequest
comando. Invoke-WebRequest
crea la sessione e la salva nella variabile . Nei comandi successivi, usare la variabile come valore del parametro WebSession.
Non è possibile usare i parametri SessionVariable e WebSession nello stesso comando.
Type: | WebRequestSession |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
Input
È possibile inviare il corpo di una richiesta Web a questo cmdlet.
Output
Questo cmdlet restituisce l'oggetto response che rappresenta il risultato della richiesta Web.
Note
PowerShell include gli alias seguenti per Invoke-WebRequest
:
- Tutte le piattaforme:
iwr
A partire da PowerShell 6.0.0 Invoke-WebRequest
supporta solo l'analisi di base.
Per altre informazioni, vedere BasicHtmlWebResponseObject.
A causa delle modifiche apportate a .NET Core 3.1, PowerShell 7.0 e versioni successive usano la proprietà HttpClient.DefaultProxy per determinare la configurazione del proxy.
Il valore di questa proprietà è determinato dalla piattaforma:
- Per Windows: legge la configurazione del proxy dalle variabili di ambiente. Se queste variabili non sono definite, la proprietà viene derivata dalle impostazioni proxy dell'utente.
- Per macOS: legge la configurazione del proxy dalle variabili di ambiente. Se queste variabili non sono definite, la proprietà viene derivata dalle impostazioni proxy del sistema.
- Per Linux: legge la configurazione del proxy dalle variabili di ambiente. Se queste variabili non sono definite, la proprietà inizializza un'istanza non configurata che ignora tutti gli indirizzi.
Le variabili di ambiente usate per DefaultProxy
l'inizializzazione nelle piattaforme basate su Windows e Unix sono:
HTTP_PROXY
: nome host o indirizzo IP del server proxy usato nelle richieste HTTP.HTTPS_PROXY
: nome host o indirizzo IP del server proxy usato nelle richieste HTTPS.ALL_PROXY
: nome host o indirizzo IP del server proxy usato nelle richieste HTTP e HTTPS nel casoHTTP_PROXY
oHTTPS_PROXY
non siano definite.NO_PROXY
: elenco delimitato da virgole di nomi host che devono essere esclusi dal proxy.