Invoke-WebRequest
Hiermee haalt u inhoud op van een webpagina op internet.
Syntaxis
StandardMethod (Standaard)
Invoke-WebRequest
[-Uri] <Uri>
[-UseBasicParsing]
[-HttpVersion <Version>]
[-WebSession <WebRequestSession>]
[-SessionVariable <String>]
[-AllowUnencryptedAuthentication]
[-Authentication <WebAuthenticationType>]
[-Credential <PSCredential>]
[-UseDefaultCredentials]
[-CertificateThumbprint <String>]
[-Certificate <X509Certificate>]
[-SkipCertificateCheck]
[-SslProtocol <WebSslProtocol>]
[-Token <SecureString>]
[-UserAgent <String>]
[-DisableKeepAlive]
[-ConnectionTimeoutSeconds <Int32>]
[-OperationTimeoutSeconds <Int32>]
[-Headers <IDictionary>]
[-SkipHeaderValidation]
[-AllowInsecureRedirect]
[-MaximumRedirection <Int32>]
[-MaximumRetryCount <Int32>]
[-PreserveAuthorizationOnRedirect]
[-RetryIntervalSec <Int32>]
[-Method <WebRequestMethod>]
[-PreserveHttpMethodOnRedirect]
[-UnixSocket <UnixDomainSocketEndPoint>]
[-Proxy <Uri>]
[-ProxyCredential <PSCredential>]
[-ProxyUseDefaultCredentials]
[-Body <Object>]
[-Form <IDictionary>]
[-ContentType <String>]
[-TransferEncoding <String>]
[-InFile <String>]
[-OutFile <String>]
[-PassThru]
[-Resume]
[-SkipHttpErrorCheck]
[<CommonParameters>]
StandardMethodNoProxy
Invoke-WebRequest
[-Uri] <Uri>
[-UseBasicParsing]
[-HttpVersion <Version>]
[-WebSession <WebRequestSession>]
[-SessionVariable <String>]
[-AllowUnencryptedAuthentication]
[-Authentication <WebAuthenticationType>]
[-Credential <PSCredential>]
[-UseDefaultCredentials]
[-CertificateThumbprint <String>]
[-Certificate <X509Certificate>]
[-SkipCertificateCheck]
[-SslProtocol <WebSslProtocol>]
[-Token <SecureString>]
[-UserAgent <String>]
[-DisableKeepAlive]
[-ConnectionTimeoutSeconds <Int32>]
[-OperationTimeoutSeconds <Int32>]
[-Headers <IDictionary>]
[-SkipHeaderValidation]
[-AllowInsecureRedirect]
[-MaximumRedirection <Int32>]
[-MaximumRetryCount <Int32>]
[-PreserveAuthorizationOnRedirect]
[-RetryIntervalSec <Int32>]
[-Method <WebRequestMethod>]
[-PreserveHttpMethodOnRedirect]
[-UnixSocket <UnixDomainSocketEndPoint>]
[-NoProxy]
[-Body <Object>]
[-Form <IDictionary>]
[-ContentType <String>]
[-TransferEncoding <String>]
[-InFile <String>]
[-OutFile <String>]
[-PassThru]
[-Resume]
[-SkipHttpErrorCheck]
[<CommonParameters>]
CustomMethod
Invoke-WebRequest
[-Uri] <Uri>
-CustomMethod <String>
[-UseBasicParsing]
[-HttpVersion <Version>]
[-WebSession <WebRequestSession>]
[-SessionVariable <String>]
[-AllowUnencryptedAuthentication]
[-Authentication <WebAuthenticationType>]
[-Credential <PSCredential>]
[-UseDefaultCredentials]
[-CertificateThumbprint <String>]
[-Certificate <X509Certificate>]
[-SkipCertificateCheck]
[-SslProtocol <WebSslProtocol>]
[-Token <SecureString>]
[-UserAgent <String>]
[-DisableKeepAlive]
[-ConnectionTimeoutSeconds <Int32>]
[-OperationTimeoutSeconds <Int32>]
[-Headers <IDictionary>]
[-SkipHeaderValidation]
[-AllowInsecureRedirect]
[-MaximumRedirection <Int32>]
[-MaximumRetryCount <Int32>]
[-PreserveAuthorizationOnRedirect]
[-RetryIntervalSec <Int32>]
[-PreserveHttpMethodOnRedirect]
[-UnixSocket <UnixDomainSocketEndPoint>]
[-Proxy <Uri>]
[-ProxyCredential <PSCredential>]
[-ProxyUseDefaultCredentials]
[-Body <Object>]
[-Form <IDictionary>]
[-ContentType <String>]
[-TransferEncoding <String>]
[-InFile <String>]
[-OutFile <String>]
[-PassThru]
[-Resume]
[-SkipHttpErrorCheck]
[<CommonParameters>]
CustomMethodNoProxy
Invoke-WebRequest
[-Uri] <Uri>
-CustomMethod <String>
[-UseBasicParsing]
[-HttpVersion <Version>]
[-WebSession <WebRequestSession>]
[-SessionVariable <String>]
[-AllowUnencryptedAuthentication]
[-Authentication <WebAuthenticationType>]
[-Credential <PSCredential>]
[-UseDefaultCredentials]
[-CertificateThumbprint <String>]
[-Certificate <X509Certificate>]
[-SkipCertificateCheck]
[-SslProtocol <WebSslProtocol>]
[-Token <SecureString>]
[-UserAgent <String>]
[-DisableKeepAlive]
[-ConnectionTimeoutSeconds <Int32>]
[-OperationTimeoutSeconds <Int32>]
[-Headers <IDictionary>]
[-SkipHeaderValidation]
[-AllowInsecureRedirect]
[-MaximumRedirection <Int32>]
[-MaximumRetryCount <Int32>]
[-PreserveAuthorizationOnRedirect]
[-RetryIntervalSec <Int32>]
[-PreserveHttpMethodOnRedirect]
[-UnixSocket <UnixDomainSocketEndPoint>]
[-NoProxy]
[-Body <Object>]
[-Form <IDictionary>]
[-ContentType <String>]
[-TransferEncoding <String>]
[-InFile <String>]
[-OutFile <String>]
[-PassThru]
[-Resume]
[-SkipHttpErrorCheck]
[<CommonParameters>]
Description
De Invoke-WebRequest
cmdlet verzendt HTTP- en HTTPS-aanvragen naar een webpagina of webservice. Het parseert het antwoord en retourneert verzamelingen van koppelingen, afbeeldingen en andere belangrijke HTML-elementen.
Deze cmdlet is geïntroduceerd in PowerShell 3.0.
Vanaf PowerShell 7.0 ondersteunt Invoke-WebRequest
proxyconfiguratie die is gedefinieerd door omgevingsvariabelen. Zie de sectie Notities van dit artikel.
Belangrijk
De voorbeelden in dit artikel verwijzen naar hosts in het contoso.com
domein. Dit is een fictief domein dat door Microsoft wordt gebruikt voor voorbeelden. De voorbeelden zijn ontworpen om te laten zien hoe u de cmdlets gebruikt.
Omdat de contoso.com
sites echter niet bestaan, werken de voorbeelden niet. Pas de voorbeelden aan hosts in uw omgeving aan.
Vanaf PowerShell 7.4 wordt tekencodering voor aanvragen standaard ingesteld op UTF-8 in plaats van ASCII. Als u een andere codering nodig hebt, moet u het kenmerk charset
instellen in de Content-Type
-header.
Voorbeelden
Voorbeeld 1: Een webaanvraag verzenden
In dit voorbeeld wordt de cmdlet Invoke-WebRequest
gebruikt om een webaanvraag naar de Bing.com-site te verzenden.
$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
De eerste opdracht geeft de aanvraag uit en slaat het antwoord op in de $Response
variabele.
Met de tweede opdracht krijgt u InputField waar de eigenschap Name zich als "* Value"
bevindt. De gefilterde resultaten worden doorgesluisd naar Select-Object
om de eigenschappen Name en Value te selecteren.
Voorbeeld 2: Een stateful webservice gebruiken
In dit voorbeeld ziet u hoe u de cmdlet Invoke-WebRequest
gebruikt met een stateful webservice.
$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
De eerste aanroep naar Invoke-WebRequest
verzendt een aanmeldingsaanvraag. De opdracht geeft een waarde van Session
op voor de waarde van de parameter SessionVariable. Wanneer de opdracht is voltooid, bevat de variabele $LoginResponse
een BasicHtmlWebResponseObject- en bevat de variabele $Session
een WebRequestSession
-object. Hiermee wordt de gebruiker aangemeld bij de site.
De tweede aanroep om Invoke-WebRequest
het profiel van de gebruiker ophaalt. Hiervoor moet de gebruiker zijn aangemeld bij de site. De sessiegegevens die zijn opgeslagen in de variabele $Session
bieden sessiecookies aan de site die tijdens de aanmelding is gemaakt.
Voorbeeld 3: Koppelingen ophalen van een webpagina
In dit voorbeeld worden de koppelingen op een webpagina weergegeven. De cmdlet Invoke-WebRequest
wordt gebruikt om de inhoud van de webpagina op te halen. Vervolgens wordt de eigenschap Koppelingen van het BasicHtmlWebResponseObject gebruikt die Invoke-WebRequest
retourneert en de eigenschap Href van elke koppeling.
(Invoke-WebRequest -Uri "https://aka.ms/pscore6-docs").Links.Href
Voorbeeld 4: Antwoordinhoud naar een bestand schrijven met behulp van de codering die is gedefinieerd op de aangevraagde pagina
In dit voorbeeld wordt de Invoke-WebRequest
-cmdlet gebruikt om de webpagina-inhoud van een PowerShell-documentatiepagina op te halen.
$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()
}
Met de eerste opdracht wordt de pagina opgehaald en wordt het antwoordobject opgeslagen in de $Response
variabele.
Met de tweede opdracht maakt u een StreamWriter- om de antwoordinhoud naar een bestand te schrijven. De eigenschap Codering van het antwoordobject wordt gebruikt om de codering voor het bestand in te stellen.
Met de laatste paar opdrachten wordt de eigenschap Content naar het bestand geschreven en wordt de StreamWriter-verwijderd.
Houd er rekening mee dat de eigenschap codering null is als de webaanvraag geen tekstinhoud retourneert.
Voorbeeld 5: Een bestand met meerdere onderdelen/formuliergegevens verzenden
In dit voorbeeld wordt de Invoke-WebRequest
cmdlet gebruikt om een bestand te uploaden als multipart/form-data
inzending. Het bestand C:\document.txt
wordt verzonden als het formulierveld document
met de Content-Type
van 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'
Voorbeeld 6: Vereenvoudigd meerdere onderdelen/Form-Data indienen
Voor sommige API's zijn multipart/form-data
verzendingen vereist om bestanden en gemengde inhoud te uploaden. In dit voorbeeld ziet u hoe u een gebruikersprofiel bijwerkt.
$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
Voor het profielformulier zijn de volgende velden vereist: firstName
, lastName
, email
, avatar
, birthday
en hobbies
. De API verwacht dat een afbeelding voor de afbeelding van het gebruikersprofiel wordt opgegeven in het veld avatar
. De API accepteert ook meerdere hobbies
vermeldingen die in hetzelfde formulier moeten worden ingediend.
Bij het maken van de $Form
HashTable worden de sleutelnamen gebruikt als formulierveldnamen. Standaard worden de waarden van de HashTable geconverteerd naar tekenreeksen. Als er een System.IO.FileInfo waarde aanwezig is, wordt de bestandsinhoud verzonden. Als een verzameling zoals matrices of lijsten aanwezig is, wordt het formulierveld meerdere keren verzonden.
Met Get-Item
op de sleutel avatar
wordt het FileInfo
-object ingesteld als de waarde. Het resultaat is dat de afbeeldingsgegevens voor jdoe.png
worden verzonden.
Door een lijst op te geven aan de hobbies
sleutel, is het hobbies
veld eenmaal aanwezig in de inzendingen voor elk lijstitem.
Voorbeeld 7: Niet-geslaagde berichten van Invoke-WebRequest
Wanneer Invoke-WebRequest
een HTTP-bericht zonder succes tegenkomt (404, 500, enzovoort), wordt er geen uitvoer geretourneerd en wordt er een afsluitfout gegenereerd. Als u de fout wilt ondervangen en de StatusCode kunt u de uitvoering insluiten in een try/catch
blok.
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
De afsluitfout wordt opgevangen door het catch
blok, waarmee de StatusCode- wordt opgehaald uit het object Exception.
Voorbeeld 8: Meerdere bestanden tegelijk downloaden
De cmdlet Invoke-WebRequest
kan slechts één bestand tegelijk downloaden. In het volgende voorbeeld wordt Start-ThreadJob
gebruikt om meerdere threadtaken te maken om meerdere bestanden tegelijk te downloaden.
$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
}
Voorbeeld 9: Headervalidatie overslaan
De cmdlet Invoke-WebRequest
valideert standaard de waarden van bekende headers met een door standaarden gedefinieerde waardeindeling. In het volgende voorbeeld ziet u hoe deze validatie een fout kan veroorzaken en hoe u de parameter SkipHeaderValidation kunt gebruiken om te voorkomen dat waarden worden gevalideerd voor eindpunten die ongeldig opgemaakte waarden tolereren.
$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 is een service die informatie retourneert over webaanvragen en antwoorden voor probleemoplossing. De $Uri
variabele wordt toegewezen aan het /headers
eindpunt van de service, waarmee de headers van een aanvraag worden geretourneerd als de inhoud in het antwoord.
De If-Match
aanvraagheader is gedefinieerd in RFC-7232-sectie 3.1 en vereist dat de waarde voor die header wordt gedefinieerd met omringende aanhalingstekens. Aan de $InvalidHeaders
variabele wordt een hash-tabel toegewezen waarbij de waarde van If-Match
ongeldig is omdat deze is gedefinieerd als 12345
in plaats van "12345"
.
Het aanroepen van Invoke-WebRequest
met de ongeldige headers retourneert een foutrapportage dat de opgemaakte waarde ongeldig is. De aanvraag wordt niet naar het eindpunt verzonden.
Als u Invoke-WebRequest
aanroept met de parameter SkipHeaderValidation, wordt de validatiefout genegeerd en wordt de aanvraag naar het eindpunt verzonden. Omdat het eindpunt niet-compatibele headerwaarden tolereert, retourneert de cmdlet het antwoordobject zonder fouten.
Voorbeeld 10: Een aanvraag verzenden met HTTP 2.0
In dit voorbeeld worden de koppelingen op een webpagina weergegeven met behulp van het HTTP 2.0-protocol. De cmdlet Invoke-WebRequest
wordt gebruikt om de inhoud van de webpagina op te halen. Vervolgens wordt de eigenschap Koppelingen van het BasicHtmlWebResponseObject gebruikt die Invoke-WebRequest
retourneert en de eigenschap Href van elke koppeling.
(Invoke-WebRequest -Uri 'https://aka.ms/pscore6-docs' -HttpVersion 2.0).Links.Href
Voorbeeld 11: Een aanvraag verzenden naar een Unix-sockettoepassing
Sommige toepassingen, zoals Docker, maken een Unix-socket beschikbaar voor communicatie. In dit voorbeeld wordt een query uitgevoerd voor een lijst met Docker-afbeeldingen door middel van de Docker-API. De cmdlet maakt verbinding met de Docker-daemon met behulp van de Unix-socket.
Invoke-WebRequest -Uri "http://localhost/v1.40/images/json/" -UnixSocket "/var/run/docker.sock"
Parameters
-AllowInsecureRedirect
Hiermee kunt u omleiden van HTTPS naar HTTP. Elke aanvraag die wordt omgeleid van HTTPS naar HTTP, resulteert standaard in een fout en de aanvraag wordt afgebroken om te voorkomen dat onbedoeld in tekst zonder opmaak wordt gecommuniceerd via niet-versleutelde verbindingen. Als u dit gedrag op eigen risico wilt overschrijven, gebruikt u de parameter AllowInsecureRedirect.
Deze parameter is toegevoegd in PowerShell 7.4.
Parametereigenschappen
Type: | SwitchParameter |
Default value: | False |
Ondersteunt jokertekens: | False |
DontShow: | False |
Parametersets
(All)
Position: | Named |
Verplicht: | False |
Waarde uit pijplijn: | False |
Waarde uit pijplijn op eigenschapsnaam: | False |
Waarde van resterende argumenten: | False |
-AllowUnencryptedAuthentication
Hiermee kunt u referenties en geheimen verzenden via niet-versleutelde verbindingen. Het opgeven van referentie of een verificatieoptie standaard met een URI- die niet begint met https://
resulteert in een fout en de aanvraag wordt afgebroken om onbedoeld te voorkomen dat geheimen in tekst zonder opmaak worden gecommuniceerd via niet-versleutelde verbindingen. Als u dit gedrag op eigen risico wilt overschrijven, geeft u de AllowUnencryptedAuthentication parameter op.
Waarschuwing
Het gebruik van deze parameter is niet veilig en wordt niet aanbevolen. Het is alleen beschikbaar voor compatibiliteit met verouderde systemen die geen versleutelde verbindingen kunnen bieden. Gebruik op eigen risico.
Deze functie is toegevoegd in PowerShell 6.0.0.
Parametereigenschappen
Type: | SwitchParameter |
Default value: | False |
Ondersteunt jokertekens: | False |
DontShow: | False |
Parametersets
(All)
Position: | Named |
Verplicht: | False |
Waarde uit pijplijn: | False |
Waarde uit pijplijn op eigenschapsnaam: | False |
Waarde van resterende argumenten: | False |
-Authentication
Hiermee geeft u het expliciete verificatietype op dat moet worden gebruikt voor de aanvraag. De standaardwaarde is None. De parameter Authentication kan niet worden gebruikt met de parameter UseDefaultCredentials.
Beschikbare verificatieopties:
-
None
: Dit is de standaardoptie wanneer verificatie- niet wordt verstrekt. Er wordt geen expliciete verificatie gebruikt. -
Basic
: vereist een referentie. De referenties worden verzonden als een RFC 7617 Basic AuthenticationAuthorization: Basic
header in de indeling vanbase64(user:password)
. -
Bearer
: vereist de parameter -token. Hiermee verzendt u een RFC 6750Authorization: Bearer
header met het opgegeven token. -
OAuth
: vereist de parameter -token. Hiermee verzendt u een RFC 6750Authorization: Bearer
header met het opgegeven token.
Het opgeven van Verificatie overschrijft alle Authorization
headers die worden geleverd aan Headers of zijn opgenomen in WebSession.
Deze functie is toegevoegd in PowerShell 6.0.0.
Parametereigenschappen
Type: | WebAuthenticationType |
Default value: | None |
Geaccepteerde waarden: | None, Basic, Bearer, OAuth |
Ondersteunt jokertekens: | False |
DontShow: | False |
Parametersets
(All)
Position: | Named |
Verplicht: | False |
Waarde uit pijplijn: | False |
Waarde uit pijplijn op eigenschapsnaam: | False |
Waarde van resterende argumenten: | False |
-Body
Specificeert het onderdeel van het verzoek. De hoofdtekst is de inhoud van de aanvraag die de headers volgt.
U kunt ook een body-waarde doorsluizen naar Invoke-WebRequest
.
De parameter Hoofdtekst kan worden gebruikt om een lijst met queryparameters op te geven of de inhoud van het antwoord op te geven. Voor queryparameters gebruikt de cmdlet de System.Net.WebUtility.UrlEncode methode om de sleutel-waardeparen te coderen. Zie voor meer informatie over coderingstekenreeksen voor URL's de verwijzing naar de UrlEncode()-methode.
Wanneer de invoer een POST-aanvraag is en de hoofdtekst een tekenreeks, wordt de waarde links van het eerste gelijkteken (=
) ingesteld als een sleutel in de formuliergegevens en wordt de resterende tekst ingesteld als de waarde. Als u meerdere sleutels wilt opgeven, gebruikt u een IDictionary--object, zoals een hash-tabel, voor de Body.
Wanneer de invoer een GET-aanvraag is en de hoofdtekst een IDictionary (meestal een hash-tabel), wordt de hoofdtekst als queryparameters aan de URI toegevoegd. Voor andere aanvraagtypen (zoals PATCH) wordt de body ingesteld als de inhoud van de aanvraag in de standaardindeling name=value
, waarbij de waarden URL-gecodeerd zijn.
Wanneer de invoer een System.Xml.XmlNode object is en de XML-declaratie een codering opgeeft, wordt die codering gebruikt voor de gegevens in de aanvraag, tenzij deze worden overschreven door de parameter ContentType.
De parameter Body accepteert ook een System.Net.Http.MultipartFormDataContent
-object. Dit vereenvoudigt multipart/form-data
aanvragen. Wanneer een MultipartFormDataContent object wordt opgegeven voor Body, worden alle inhoudsgerelateerde headers die worden geleverd aan de ContentType, Headersof WebSession parameters overschreven door de inhoudskoppen van het MultipartFormDataContent object. Deze functie is toegevoegd in PowerShell 6.0.0.
Parametereigenschappen
Type: | Object |
Default value: | None |
Ondersteunt jokertekens: | False |
DontShow: | False |
Parametersets
(All)
Position: | Named |
Verplicht: | False |
Waarde uit pijplijn: | True |
Waarde uit pijplijn op eigenschapsnaam: | False |
Waarde van resterende argumenten: | False |
-Certificate
Hiermee geeft u het clientcertificaat op dat wordt gebruikt voor een beveiligde webaanvraag. Voer een variabele in die een certificaat of een opdracht of expressie bevat die het certificaat ophaalt.
Als u een certificaat wilt zoeken, gebruikt u Get-PfxCertificate
of de Get-ChildItem
-cmdlet in het certificaatstation (Cert:
). Als het certificaat niet geldig is of niet over voldoende autoriteit beschikt, mislukt de opdracht.
Parametereigenschappen
Type: | X509Certificate |
Default value: | None |
Ondersteunt jokertekens: | False |
DontShow: | False |
Parametersets
(All)
Position: | Named |
Verplicht: | False |
Waarde uit pijplijn: | False |
Waarde uit pijplijn op eigenschapsnaam: | False |
Waarde van resterende argumenten: | False |
-CertificateThumbprint
Hiermee geeft u het certificaat voor de digitale openbare sleutel (X509) van een gebruikersaccount op dat gemachtigd is om de aanvraag te verzenden. Voer de vingerafdruk van het certificaat in.
Certificaten worden gebruikt in verificatie op basis van clientcertificaten. Certificaten kunnen alleen worden toegewezen aan lokale gebruikersaccounts, niet aan domeinaccounts.
Als u de vingerafdruk van het certificaat wilt zien, gebruikt u de opdracht Get-Item
of Get-ChildItem
om het certificaat in Cert:\CurrentUser\My
te vinden.
Opmerking
Deze functie wordt alleen ondersteund op Windows-besturingssysteemplatforms.
Parametereigenschappen
Type: | String |
Default value: | None |
Ondersteunt jokertekens: | False |
DontShow: | False |
Parametersets
(All)
Position: | Named |
Verplicht: | False |
Waarde uit pijplijn: | False |
Waarde uit pijplijn op eigenschapsnaam: | False |
Waarde van resterende argumenten: | False |
-ConnectionTimeoutSeconds
Hiermee geeft u op hoe lang de aanvraag in behandeling kan zijn voordat er een time-out optreedt. Voer een waarde in seconden in. De standaardwaarde, 0, geeft een onbepaalde time-out op.
Het kan tot 15 seconden duren voordat een DNS-query (Domain Name System) retourneert of een time-out optreedt. Als uw aanvraag een hostnaam bevat waarvoor oplossing is vereist en u ConnectionTimeoutSeconds instelt op een waarde die groter is dan nul, maar minder dan 15 seconden, kan het 15 seconden of langer duren voordat een WebException- wordt gegenereerd en er een time-out optreedt voor uw aanvraag.
Deze parameter vervangt de parameter TimeoutSec in PowerShell 7.4. U kunt TimeoutSec- als alias gebruiken voor ConnectionTimeoutSeconds.
Parametereigenschappen
Type: | Int32 |
Default value: | None |
Ondersteunt jokertekens: | False |
DontShow: | False |
Aliassen: | TimeoutSec |
Parametersets
(All)
Position: | Named |
Verplicht: | False |
Waarde uit pijplijn: | False |
Waarde uit pijplijn op eigenschapsnaam: | False |
Waarde van resterende argumenten: | False |
-ContentType
Hiermee geeft u het inhoudstype van de webaanvraag op.
Als de waarde voor ContentType de coderingsindeling (zoals charset
) bevat, gebruikt de cmdlet die indeling om de hoofdtekst van de webaanvraag te coderen. Als de ContentType- geen coderingsindeling opgeeft, wordt in plaats daarvan de standaardcoderingsindeling gebruikt. Een voorbeeld van een ContentType met een coderingsindeling is text/plain; charset=iso-8859-5
, waarmee het Latijns/Cyrillisch alfabet wordt opgegeven.
Als u de parameter weglaat, kan het inhoudstype afwijken op basis van de HTTP-methode die u gebruikt:
- Voor een POST-methode wordt het inhoudstype
application/x-www-form-urlencoded
- Voor een PUT-methode wordt het inhoudstype
application/json
- Voor andere methoden wordt het inhoudstype niet opgegeven in de aanvraag
Als u de parameter InFile gebruikt om een bestand te uploaden, moet u het inhoudstype instellen.
Meestal moet het type worden application/octet-stream
. U moet echter het inhoudstype instellen op basis van de vereisten van het eindpunt.
ContentType- wordt overschreven wanneer de Body een MultipartFormDataContent object is.
Als u vanaf PowerShell 7.4 deze parameter en de parameter Headers gebruikt om de Content-Type
header te definiëren, wordt de waarde gebruikt die is opgegeven in de parameter ContentType.
Parametereigenschappen
Type: | String |
Default value: | None |
Ondersteunt jokertekens: | False |
DontShow: | False |
Parametersets
(All)
Position: | Named |
Verplicht: | False |
Waarde uit pijplijn: | False |
Waarde uit pijplijn op eigenschapsnaam: | False |
Waarde van resterende argumenten: | False |
-Credential
Hiermee geeft u een gebruikersaccount op dat gemachtigd is om de aanvraag te verzenden. De standaardwaarde is de huidige gebruiker.
Typ een gebruikersnaam, zoals User01 of Domain01\User01, of voer een PSCredential--object in dat is gegenereerd door de Get-Credential
-cmdlet.
Referentie kan alleen worden gebruikt of in combinatie met bepaalde verificatie- parameteropties. Als het alleen wordt gebruikt, levert het alleen inloggegevens aan de externe server indien de externe server een authenticatie-uitdaging verzendt. Bij gebruik met opties voor verificatie worden de referenties expliciet verzonden.
Referenties worden opgeslagen in een PSCredential-object en het wachtwoord wordt opgeslagen als een SecureString.
Opmerking
Zie voor meer informatie over SecureString gegevensbeveiliging Hoe veilig is SecureString?.
Parametereigenschappen
Type: | PSCredential |
Default value: | Current user |
Ondersteunt jokertekens: | False |
DontShow: | False |
Parametersets
(All)
Position: | Named |
Verplicht: | False |
Waarde uit pijplijn: | False |
Waarde uit pijplijn op eigenschapsnaam: | False |
Waarde van resterende argumenten: | False |
-CustomMethod
Hiermee geeft u een aangepaste methode op die wordt gebruikt voor de webaanvraag. Dit kan worden gebruikt als de aanvraagmethode die is vereist voor het eindpunt, geen beschikbare optie is op de Methode. Methode en CustomMethod- kunnen niet samen worden gebruikt.
In dit voorbeeld wordt een TEST
HTTP-aanvraag naar de API verzonden:
Invoke-WebRequest -Uri 'https://api.contoso.com/widget/' -CustomMethod 'TEST'
Deze functie is toegevoegd in PowerShell 6.0.0.
Parametereigenschappen
Type: | String |
Default value: | None |
Ondersteunt jokertekens: | False |
DontShow: | False |
Aliassen: | CENTIMETER |
Parametersets
CustomMethod
Position: | Named |
Verplicht: | True |
Waarde uit pijplijn: | False |
Waarde uit pijplijn op eigenschapsnaam: | False |
Waarde van resterende argumenten: | False |
CustomMethodNoProxy
Position: | Named |
Verplicht: | True |
Waarde uit pijplijn: | False |
Waarde uit pijplijn op eigenschapsnaam: | False |
Waarde van resterende argumenten: | False |
-DisableKeepAlive
Geeft aan dat de cmdlet de KeepAlive--waarde in de HTTP-header instelt op False. Standaard is KeepAlive-Waar. KeepAlive- brengt een permanente verbinding tot stand met de server om volgende aanvragen te vergemakkelijken.
Parametereigenschappen
Type: | SwitchParameter |
Default value: | False |
Ondersteunt jokertekens: | False |
DontShow: | False |
Parametersets
(All)
Position: | Named |
Verplicht: | False |
Waarde uit pijplijn: | False |
Waarde uit pijplijn op eigenschapsnaam: | False |
Waarde van resterende argumenten: | False |
-Form
Converteert een woordenlijst naar een multipart/form-data
inzending.
Formulier mag niet worden gebruikt met Body.
Als ContentType wordt gebruikt, wordt deze genegeerd.
De sleutels van de woordenlijst worden gebruikt als de veldnamen van het formulier. Formulierwaarden worden standaard geconverteerd naar tekenreekswaarden.
Als de waarde een System.IO.FileInfo object is, wordt de inhoud van het binaire bestand verzonden. De naam van het bestand wordt verzonden als de bestandsnaam eigenschap. Het MIME-type wordt ingesteld als application/octet-stream
.
Get-Item
kan worden gebruikt om het leveren van het System.IO.FileInfo--object te vereenvoudigen.
$Form = @{
resume = Get-Item 'C:\Users\jdoe\Documents\John Doe.pdf'
}
Als de waarde een verzamelingstype is, zoals matrices of lijsten, wordt het for-veld meerdere keren verzonden. De waarden van de lijst worden standaard behandeld als tekenreeksen. Als de waarde een System.IO.FileInfo object is, wordt de inhoud van het binaire bestand verzonden. Geneste collecties worden niet ondersteund.
$Form = @{
tags = 'Vacation', 'Italy', '2017'
pictures = Get-ChildItem 'C:\Users\jdoe\Pictures\2017-Italy\'
}
In het bovenstaande voorbeeld wordt het veld tags
drie keer in de vorm opgegeven, één keer voor elk van Vacation
, Italy
en 2017
. Het pictures
veld wordt ook eenmaal verzonden voor elk bestand in de map 2017-Italy
. De binaire inhoud van de bestanden in die map worden verzonden als de waarden.
Deze functie is toegevoegd in PowerShell 6.1.0.
Parametereigenschappen
Type: | IDictionary |
Default value: | None |
Ondersteunt jokertekens: | False |
DontShow: | False |
Parametersets
(All)
Position: | Named |
Verplicht: | False |
Waarde uit pijplijn: | False |
Waarde uit pijplijn op eigenschapsnaam: | False |
Waarde van resterende argumenten: | False |
-Headers
Hiermee specificeert u de headers van het webverzoek. Voer een hash-tabel of woordenlijst in.
Inhoudsgerelateerde headers, zoals Content-Type
worden overschreven wanneer een MultipartFormDataContent-object wordt opgegeven voor Body.
Als u deze parameter in PowerShell 7.4 gebruikt om de Content-Type
header te definiëren en parameter ContentType te gebruiken, wordt de waarde die is opgegeven in de parameter ContentType gebruikt.
Parametereigenschappen
Type: | IDictionary |
Default value: | None |
Ondersteunt jokertekens: | False |
DontShow: | False |
Parametersets
(All)
Position: | Named |
Verplicht: | False |
Waarde uit pijplijn: | False |
Waarde uit pijplijn op eigenschapsnaam: | False |
Waarde van resterende argumenten: | False |
-HttpVersion
Hiermee geeft u de HTTP-versie die voor de aanvraag wordt gebruikt. De standaardwaarde is 1.1
.
Geldige waarden zijn:
- 1.0
- 1.1
- 2.0
- 3.0
Parametereigenschappen
Type: | Version |
Default value: | 1.1 |
Ondersteunt jokertekens: | False |
DontShow: | False |
Parametersets
(All)
Position: | Named |
Verplicht: | False |
Waarde uit pijplijn: | False |
Waarde uit pijplijn op eigenschapsnaam: | False |
Waarde van resterende argumenten: | False |
-InFile
Hiermee haalt u de inhoud van de hoofdtekst van de webaanvraag op uit een bestand. Voer een pad en bestandsnaam in. Als u het pad weglaat, is de standaardlocatie de huidige locatie.
U moet ook het inhoudstype van de aanvraag instellen. Als u bijvoorbeeld een bestand wilt uploaden, moet u het inhoudstype instellen. Meestal moet het type worden application/octet-stream
. U moet echter het inhoudstype instellen op basis van de vereisten van het eindpunt.
Parametereigenschappen
Type: | String |
Default value: | None |
Ondersteunt jokertekens: | False |
DontShow: | False |
Parametersets
(All)
Position: | Named |
Verplicht: | False |
Waarde uit pijplijn: | False |
Waarde uit pijplijn op eigenschapsnaam: | False |
Waarde van resterende argumenten: | False |
-MaximumRedirection
Hiermee geeft u op hoe vaak PowerShell een verbinding omleidt naar een alternatieve URI (Uniform Resource Identifier) voordat de verbinding mislukt. De standaardwaarde is 5. Een waarde van 0 (nul) voorkomt alle omleidingen.
Parametereigenschappen
Type: | Int32 |
Default value: | 5 |
Ondersteunt jokertekens: | False |
DontShow: | False |
Parametersets
(All)
Position: | Named |
Verplicht: | False |
Waarde uit pijplijn: | False |
Waarde uit pijplijn op eigenschapsnaam: | False |
Waarde van resterende argumenten: | False |
-MaximumRetryCount
Hiermee geeft u op hoe vaak PowerShell een verbinding opnieuw probeert uit te proberen wanneer een foutcode tussen 400 en 599, inclusief of 304 wordt ontvangen. Zie ook parameter RetryIntervalSec voor het opgeven van het interval tussen nieuwe pogingen.
Parametereigenschappen
Type: | Int32 |
Default value: | None |
Ondersteunt jokertekens: | False |
DontShow: | False |
Parametersets
(All)
Position: | Named |
Verplicht: | False |
Waarde uit pijplijn: | False |
Waarde uit pijplijn op eigenschapsnaam: | False |
Waarde van resterende argumenten: | False |
-Method
Hiermee geeft u de methode op die wordt gebruikt voor de webaanvraag. De acceptabele waarden voor deze parameter zijn:
Default
Delete
Get
Head
Merge
Options
Patch
Post
Put
Trace
De parameter CustomMethod kan worden gebruikt voor aanvraagmethoden die hierboven niet worden vermeld.
Parametereigenschappen
Type: | WebRequestMethod |
Default value: | None |
Geaccepteerde waarden: | Default, Get, Head, Post, Put, Delete, Trace, Options, Merge, Patch |
Ondersteunt jokertekens: | False |
DontShow: | False |
Parametersets
StandardMethod
Position: | Named |
Verplicht: | False |
Waarde uit pijplijn: | False |
Waarde uit pijplijn op eigenschapsnaam: | False |
Waarde van resterende argumenten: | False |
StandardMethodNoProxy
Position: | Named |
Verplicht: | False |
Waarde uit pijplijn: | False |
Waarde uit pijplijn op eigenschapsnaam: | False |
Waarde van resterende argumenten: | False |
-NoProxy
Geeft aan dat de cmdlet geen proxy mag gebruiken om de bestemming te bereiken. Wanneer u de proxy die in de omgeving is geconfigureerd, moet omzeilen, gebruikt u deze switch. Deze functie is toegevoegd in PowerShell 6.0.0.
Parametereigenschappen
Type: | SwitchParameter |
Default value: | False |
Ondersteunt jokertekens: | False |
DontShow: | False |
Parametersets
StandardMethodNoProxy
Position: | Named |
Verplicht: | True |
Waarde uit pijplijn: | False |
Waarde uit pijplijn op eigenschapsnaam: | False |
Waarde van resterende argumenten: | False |
CustomMethodNoProxy
Position: | Named |
Verplicht: | True |
Waarde uit pijplijn: | False |
Waarde uit pijplijn op eigenschapsnaam: | False |
Waarde van resterende argumenten: | False |
-OperationTimeoutSeconds
Deze time-out is van toepassing op gegevens die in een stream worden gelezen, niet op de stroomtijd als geheel. De standaardwaarde, 0, geeft een onbepaalde time-out op.
Als u de waarde instelt op 30 seconden, betekent dit dat elke vertraging van meer dan 30 seconden tussen gegevens in de stream de aanvraag beëindigt. Een groot bestand dat enkele minuten duurt om te downloaden, wordt pas beëindigd als de stream langer dan 30 seconden vastlopen.
Parametereigenschappen
Type: | Int32 |
Default value: | None |
Ondersteunt jokertekens: | False |
DontShow: | False |
Parametersets
(All)
Position: | Named |
Verplicht: | False |
Waarde uit pijplijn: | False |
Waarde uit pijplijn op eigenschapsnaam: | False |
Waarde van resterende argumenten: | False |
-OutFile
Standaard retourneert Invoke-WebRequest
de resultaten naar de pijplijn. Wanneer u de parameter OutFile gebruikt, worden de resultaten opgeslagen in het opgegeven bestand en niet geretourneerd naar de pijplijn. Voer een pad en bestandsnaam in. Als u de resultaten naar een bestand en naar de pijplijn wilt verzenden, voegt u de parameter PassThru toe.
Als u het pad weglaat, is de standaardlocatie de huidige locatie. De naam wordt behandeld als een letterlijk pad.
Namen die haakjes ([]
) bevatten, moeten tussen enkele aanhalingstekens ('
) worden geplaatst.
Vanaf PowerShell 7.4 kunt u een mappad opgeven zonder de bestandsnaam. Wanneer u dit doet, gebruikt de opdracht de bestandsnaam uit het laatste segment van de opgeloste URI na omleidingen. Wanneer u een mappad opgeeft voor OutFile-, kunt u de parameter Hervatten niet gebruiken.
Parametereigenschappen
Type: | String |
Default value: | None |
Ondersteunt jokertekens: | False |
DontShow: | False |
Parametersets
(All)
Position: | Named |
Verplicht: | False |
Waarde uit pijplijn: | False |
Waarde uit pijplijn op eigenschapsnaam: | False |
Waarde van resterende argumenten: | False |
-PassThru
Geeft aan dat de cmdlet de resultaten retourneert, naast het schrijven ervan naar een bestand. Deze parameter is alleen geldig wanneer de parameter OutFile ook wordt gebruikt in de opdracht.
Parametereigenschappen
Type: | SwitchParameter |
Default value: | False |
Ondersteunt jokertekens: | False |
DontShow: | False |
Parametersets
(All)
Position: | Named |
Verplicht: | False |
Waarde uit pijplijn: | False |
Waarde uit pijplijn op eigenschapsnaam: | False |
Waarde van resterende argumenten: | False |
-PreserveAuthorizationOnRedirect
Geeft aan dat de cmdlet de Authorization
header moet behouden, wanneer deze aanwezig is, tussen omleidingen.
De cmdlet verwijdert standaard de Authorization
-koptekst voordat deze wordt omgeleid. Als u deze parameter opgeeft, wordt deze logica uitgeschakeld voor gevallen waarin de header naar de omleidingslocatie moet worden verzonden.
Deze functie is toegevoegd in PowerShell 6.0.0.
Parametereigenschappen
Type: | SwitchParameter |
Default value: | False |
Ondersteunt jokertekens: | False |
DontShow: | False |
Parametersets
(All)
Position: | Named |
Verplicht: | False |
Waarde uit pijplijn: | False |
Waarde uit pijplijn op eigenschapsnaam: | False |
Waarde van resterende argumenten: | False |
-PreserveHttpMethodOnRedirect
Geeft aan dat de cmdlet de methode van de aanvraag bij omleidingen moet behouden.
De cmdlet wijzigt standaard de methode in GET
wanneer deze wordt omgeleid. Als u deze parameter opgeeft, wordt deze logica uitgeschakeld om ervoor te zorgen dat de beoogde methode kan worden gebruikt met omleiding.
Deze functie is toegevoegd in PowerShell 7.4.
Parametereigenschappen
Type: | SwitchParameter |
Default value: | False |
Ondersteunt jokertekens: | False |
DontShow: | False |
Parametersets
(All)
Position: | Named |
Verplicht: | False |
Waarde uit pijplijn: | False |
Waarde uit pijplijn op eigenschapsnaam: | False |
Waarde van resterende argumenten: | False |
-Proxy
Hiermee geeft u een proxyserver voor de aanvraag op, in plaats van rechtstreeks verbinding te maken met de internetresource. Voer de URI van een netwerkproxyserver in.
Parametereigenschappen
Type: | Uri |
Default value: | None |
Ondersteunt jokertekens: | False |
DontShow: | False |
Parametersets
StandardMethod
Position: | Named |
Verplicht: | False |
Waarde uit pijplijn: | False |
Waarde uit pijplijn op eigenschapsnaam: | False |
Waarde van resterende argumenten: | False |
CustomMethod
Position: | Named |
Verplicht: | False |
Waarde uit pijplijn: | False |
Waarde uit pijplijn op eigenschapsnaam: | False |
Waarde van resterende argumenten: | False |
-ProxyCredential
Hiermee geeft u een gebruikersaccount op dat gemachtigd is om de proxyserver te gebruiken die is opgegeven door de parameter Proxy. De standaardwaarde is de huidige gebruiker.
Typ een gebruikersnaam, zoals User01
of Domain01\User01
, of voer een PSCredential--object in, zoals een object dat is gegenereerd door de Get-Credential
-cmdlet.
Deze parameter is alleen geldig wanneer de parameter Proxy ook wordt gebruikt in de opdracht. U kunt de parameters ProxyCredential en ProxyUseDefaultCredentials niet in dezelfde opdracht gebruiken.
Parametereigenschappen
Type: | PSCredential |
Default value: | Current user |
Ondersteunt jokertekens: | False |
DontShow: | False |
Parametersets
StandardMethod
Position: | Named |
Verplicht: | False |
Waarde uit pijplijn: | False |
Waarde uit pijplijn op eigenschapsnaam: | False |
Waarde van resterende argumenten: | False |
CustomMethod
Position: | Named |
Verplicht: | False |
Waarde uit pijplijn: | False |
Waarde uit pijplijn op eigenschapsnaam: | False |
Waarde van resterende argumenten: | False |
-ProxyUseDefaultCredentials
Geeft aan dat de cmdlet de referenties van de huidige gebruiker gebruikt voor toegang tot de proxyserver die is opgegeven door de parameter Proxy.
Deze parameter is alleen geldig wanneer de parameter Proxy ook wordt gebruikt in de opdracht. U kunt de parameters ProxyCredential en ProxyUseDefaultCredentials niet in dezelfde opdracht gebruiken.
Parametereigenschappen
Type: | SwitchParameter |
Default value: | False |
Ondersteunt jokertekens: | False |
DontShow: | False |
Parametersets
StandardMethod
Position: | Named |
Verplicht: | False |
Waarde uit pijplijn: | False |
Waarde uit pijplijn op eigenschapsnaam: | False |
Waarde van resterende argumenten: | False |
CustomMethod
Position: | Named |
Verplicht: | False |
Waarde uit pijplijn: | False |
Waarde uit pijplijn op eigenschapsnaam: | False |
Waarde van resterende argumenten: | False |
-Resume
Voert een beste poging uit om het downloaden van een gedeeltelijk bestand te hervatten. Cv- vereist OutFile-.
Hervatten werkt alleen op de grootte van het lokale bestand en het externe bestand en voert geen andere validatie uit om te verifiëren dat het lokale bestand en het externe bestand hetzelfde zijn.
Als de lokale bestandsgrootte kleiner is dan de externe bestandsgrootte, probeert de cmdlet het downloaden van het bestand te hervatten en de resterende bytes toe te voegen aan het einde van het bestand.
Als de lokale bestandsgrootte hetzelfde is als de externe bestandsgrootte, wordt er geen actie ondernomen en wordt ervan uitgegaan dat de download al is voltooid door de cmdlet.
Als de lokale bestandsgrootte groter is dan de externe bestandsgrootte, wordt het lokale bestand overschreven en wordt het hele externe bestand opnieuw gedownload. Dit gedrag is hetzelfde alsof je OutFile gebruikt zonder Hervatten.
Als de externe server geen ondersteuning biedt voor het hervatten van downloaden, wordt het lokale bestand overschreven en wordt het hele externe bestand opnieuw gedownload. Dit gedrag is hetzelfde alsof je OutFile gebruikt zonder Hervatten.
Als het lokale bestand niet bestaat, wordt het lokale bestand gemaakt en wordt het hele externe bestand gedownload. Dit gedrag is hetzelfde alsof je OutFile gebruikt zonder Hervatten.
Deze functie is toegevoegd in PowerShell 6.1.0.
Parametereigenschappen
Type: | SwitchParameter |
Default value: | False |
Ondersteunt jokertekens: | False |
DontShow: | False |
Parametersets
(All)
Position: | Named |
Verplicht: | False |
Waarde uit pijplijn: | False |
Waarde uit pijplijn op eigenschapsnaam: | False |
Waarde van resterende argumenten: | False |
-RetryIntervalSec
Hiermee geeft u het interval op tussen nieuwe pogingen voor de verbinding wanneer een foutcode tussen 400 en 599, inclusief of 304 wordt ontvangen. Zie ook parameter MaximumRetryCount voor het opgeven van het aantal nieuwe pogingen. De waarde moet tussen 1
en [int]::MaxValue
zijn.
Wanneer de foutcode 429 is en het antwoord de eigenschap Opnieuw proberen na in de headers bevat, gebruikt de cmdlet die waarde voor het interval voor opnieuw proberen, zelfs als deze parameter is opgegeven.
Parametereigenschappen
Type: | Int32 |
Default value: | 5 |
Ondersteunt jokertekens: | False |
DontShow: | False |
Parametersets
(All)
Position: | Named |
Verplicht: | False |
Waarde uit pijplijn: | False |
Waarde uit pijplijn op eigenschapsnaam: | False |
Waarde van resterende argumenten: | False |
-SessionVariable
Hiermee geeft u een variabele op waarvoor deze cmdlet een webaanvraagsessie maakt en opslaat in de waarde.
Voer een variabelenaam in zonder het dollarteken ($
) symbool.
Wanneer u een sessievariabele opgeeft, Invoke-WebRequest
een sessieobject voor webaanvragen maakt en dit toewijst aan een variabele met de opgegeven naam in uw PowerShell-sessie. U kunt de variabele in uw sessie gebruiken zodra de opdracht is voltooid.
Vóór PowerShell 7.4 is de sessie met webaanvragen geen permanente verbinding. Het is een object dat informatie bevat over de verbinding en de aanvraag, waaronder cookies, referenties, de maximale omleidingswaarde en de tekenreeks van de gebruikersagent. U kunt deze gebruiken om status en gegevens te delen tussen webaanvragen.
Vanaf PowerShell 7.4 blijft de webaanvraagsessie persistent zolang de eigenschappen van de sessie niet worden overschreven in een volgende aanvraag. Wanneer dit het geval is, maakt de cmdlet de sessie opnieuw aan met de nieuwe waarden. De permanente sessies verminderen de overhead voor herhaalde aanvragen, waardoor ze veel sneller worden.
Als u de sessie met webaanvragen wilt gebruiken in volgende webaanvragen, geeft u de sessievariabele op in de waarde van de WebSession parameter. PowerShell gebruikt de gegevens in het sessieobject voor webaanvragen bij het tot stand brengen van de nieuwe verbinding. Als u een waarde in de webaanvraagsessie wilt overschrijven, gebruikt u een cmdlet-parameter, zoals UserAgent of Credential. Parameterwaarden hebben voorrang op waarden in de webaanvraagsessie.
U kunt de SessionVariable en WebSession parameters niet gebruiken in dezelfde opdracht.
Parametereigenschappen
Type: | String |
Default value: | None |
Ondersteunt jokertekens: | False |
DontShow: | False |
Aliassen: | SV |
Parametersets
(All)
Position: | Named |
Verplicht: | False |
Waarde uit pijplijn: | False |
Waarde uit pijplijn op eigenschapsnaam: | False |
Waarde van resterende argumenten: | False |
-SkipCertificateCheck
Slaat certificaatvalidatiecontroles over. Dit omvat alle validaties, zoals vervaldatum, intrekking, vertrouwde basisinstantie, enzovoort.
Waarschuwing
Het gebruik van deze parameter is niet veilig en wordt niet aanbevolen. Deze schakelaar is alleen bedoeld voor gebruik bij bekende hosts met een zelfondertekend certificaat voor testdoeleinden. Gebruik op eigen risico.
Deze functie is toegevoegd in PowerShell 6.0.0.
Parametereigenschappen
Type: | SwitchParameter |
Default value: | False |
Ondersteunt jokertekens: | False |
DontShow: | False |
Parametersets
(All)
Position: | Named |
Verplicht: | False |
Waarde uit pijplijn: | False |
Waarde uit pijplijn op eigenschapsnaam: | False |
Waarde van resterende argumenten: | False |
-SkipHeaderValidation
Geeft aan dat de cmdlet zonder validatie headers aan de aanvraag moet toevoegen.
Deze schakeloptie moet worden gebruikt voor sites waarvoor headerwaarden zijn vereist die niet voldoen aan standaarden. Door deze schakeloptie op te geven, wordt validatie uitgeschakeld, zodat de waarde ongecontroleerd kan worden doorgegeven. Wanneer dit is opgegeven, worden alle headers zonder validatie toegevoegd.
Met deze schakeloptie wordt validatie uitgeschakeld voor waarden die zijn doorgegeven aan de parameters ContentType, Headers en User Agent.
Deze functie is toegevoegd in PowerShell 6.0.0.
Parametereigenschappen
Type: | SwitchParameter |
Default value: | False |
Ondersteunt jokertekens: | False |
DontShow: | False |
Parametersets
(All)
Position: | Named |
Verplicht: | False |
Waarde uit pijplijn: | False |
Waarde uit pijplijn op eigenschapsnaam: | False |
Waarde van resterende argumenten: | False |
-SkipHttpErrorCheck
Deze parameter zorgt ervoor dat de cmdlet http-foutstatussen negeert en reacties blijft verwerken. De foutreacties worden naar de pijplijn geschreven alsof ze zijn geslaagd.
Deze parameter is geïntroduceerd in PowerShell 7.
Parametereigenschappen
Type: | SwitchParameter |
Default value: | False |
Ondersteunt jokertekens: | False |
DontShow: | False |
Parametersets
(All)
Position: | Named |
Verplicht: | False |
Waarde uit pijplijn: | False |
Waarde uit pijplijn op eigenschapsnaam: | False |
Waarde van resterende argumenten: | False |
-SslProtocol
Hiermee stelt u de SSL/TLS-protocollen in die zijn toegestaan voor de webaanvraag. Standaard zijn alle SSL/TLS-protocollen die door het systeem worden ondersteund, toegestaan. SslProtocol- kunt u beperken tot specifieke protocollen voor nalevingsdoeleinden.
Deze waarden worden gedefinieerd als een opsomming op basis van vlaggen. U kunt meerdere waarden combineren om meerdere vlaggen in te stellen met behulp van deze parameter. De waarden kunnen worden doorgegeven aan de parameter SslProtocol als een matrix met waarden of als een door komma's gescheiden tekenreeks van deze waarden. De cmdlet combineert de waarden met behulp van een binaire OF-bewerking. Het doorgeven van waarden als een matrix is de eenvoudigste optie en u kunt ook tabvoltooiing gebruiken voor de waarden. U kunt mogelijk niet meerdere opties definiëren op alle platforms.
Opmerking
Op niet-Windows-platforms is het mogelijk om Tls
of Tls12
als optie te leveren. Ondersteuning voor Tls13
is niet beschikbaar op alle besturingssystemen en moet per besturingssysteem worden geverifieerd.
Deze functie is toegevoegd in PowerShell 6.0.0 en ondersteuning voor Tls13
is toegevoegd in PowerShell 7.1.
Parametereigenschappen
Type: | WebSslProtocol |
Default value: | None |
Geaccepteerde waarden: | Default, Tls, Tls11, Tls12 |
Ondersteunt jokertekens: | False |
DontShow: | False |
Parametersets
(All)
Position: | Named |
Verplicht: | False |
Waarde uit pijplijn: | False |
Waarde uit pijplijn op eigenschapsnaam: | False |
Waarde van resterende argumenten: | False |
-Token
Het OAuth- of Bearer-token dat in de aanvraag moet worden opgenomen. token is vereist voor bepaalde verificatie- opties. Het kan niet onafhankelijk worden gebruikt.
token neemt een SecureString
met het token. Als u het token handmatig wilt opgeven, gebruikt u het volgende:
Invoke-WebRequest -Uri $uri -Authentication OAuth -Token (Read-Host -AsSecureString)
Deze parameter is geïntroduceerd in PowerShell 6.0.
Parametereigenschappen
Type: | SecureString |
Default value: | None |
Ondersteunt jokertekens: | False |
DontShow: | False |
Parametersets
(All)
Position: | Named |
Verplicht: | False |
Waarde uit pijplijn: | False |
Waarde uit pijplijn op eigenschapsnaam: | False |
Waarde van resterende argumenten: | False |
-TransferEncoding
Hiermee geeft u een waarde op voor de http-antwoordheader voor overdrachtscodering. De acceptabele waarden voor deze parameter zijn:
Chunked
Compress
Deflate
GZip
Identity
Parametereigenschappen
Type: | String |
Default value: | None |
Geaccepteerde waarden: | chunked, compress, deflate, gzip, identity |
Ondersteunt jokertekens: | False |
DontShow: | False |
Parametersets
(All)
Position: | Named |
Verplicht: | False |
Waarde uit pijplijn: | False |
Waarde uit pijplijn op eigenschapsnaam: | False |
Waarde van resterende argumenten: | False |
-UnixSocket
Hiermee geeft u de naam van de Unix-socket waarmee u verbinding wilt maken. Deze parameter wordt ondersteund op Unix-systemen en Windows-versie 1803 en hoger. Zie de blogpost Windows/WSL Interop met AF_UNIX voor meer informatie over Windows-ondersteuning voor Unix-sockets.
Deze parameter is toegevoegd in PowerShell 7.4.
Parametereigenschappen
Type: | UnixDomainSocketEndPoint |
Default value: | None |
Ondersteunt jokertekens: | False |
DontShow: | False |
Parametersets
(All)
Position: | Named |
Verplicht: | False |
Waarde uit pijplijn: | False |
Waarde uit pijplijn op eigenschapsnaam: | False |
Waarde van resterende argumenten: | False |
-Uri
Hiermee geeft u de URI (Uniform Resource Identifier) van de internetresource waarnaar de webaanvraag wordt verzonden. Voer een URI in. Deze parameter ondersteunt alleen HTTP of HTTPS.
Deze parameter is vereist. De parameternaam URI- is optioneel.
Parametereigenschappen
Type: | Uri |
Default value: | None |
Ondersteunt jokertekens: | False |
DontShow: | False |
Parametersets
(All)
Position: | 0 |
Verplicht: | True |
Waarde uit pijplijn: | False |
Waarde uit pijplijn op eigenschapsnaam: | False |
Waarde van resterende argumenten: | False |
-UseBasicParsing
Deze parameter is afgeschaft. Vanaf PowerShell 6.0.0.0 gebruiken alle webaanvragen alleen basisparsering. Deze parameter is alleen opgenomen voor compatibiliteit met eerdere versies en elk gebruik ervan heeft geen effect op de werking van de cmdlet.
Parametereigenschappen
Type: | SwitchParameter |
Default value: | False |
Ondersteunt jokertekens: | False |
DontShow: | False |
Parametersets
(All)
Position: | Named |
Verplicht: | False |
Waarde uit pijplijn: | False |
Waarde uit pijplijn op eigenschapsnaam: | False |
Waarde van resterende argumenten: | False |
-UseDefaultCredentials
Geeft aan dat de cmdlet de referenties van de huidige gebruiker gebruikt om de webaanvraag te verzenden. Dit kan niet worden gebruikt met verificatie of referentie- en wordt mogelijk niet ondersteund op alle platforms.
Parametereigenschappen
Type: | SwitchParameter |
Default value: | False |
Ondersteunt jokertekens: | False |
DontShow: | False |
Parametersets
(All)
Position: | Named |
Verplicht: | False |
Waarde uit pijplijn: | False |
Waarde uit pijplijn op eigenschapsnaam: | False |
Waarde van resterende argumenten: | False |
-UserAgent
Hiermee stelt u een gebruikersagent-tekenreeks voor de webaanvraag in.
De standaardgebruikersagent is vergelijkbaar met Mozilla/5.0 (Windows NT 10.0; Microsoft Windows 10.0.15063; en-US) PowerShell/6.0.0
met kleine variaties voor elk besturingssysteem en platform.
Als u een website wilt testen met de standaardtekenreeks van de gebruikersagent die door de meeste internetbrowsers wordt gebruikt, gebruikt u de eigenschappen van de klasse PSUserAgent, zoals Chrome, Firefox, InternetExplorer, Opera en Safari.
De volgende opdracht maakt bijvoorbeeld gebruik van de tekenreeks van de gebruikersagent voor Internet Explorer: Invoke-WebRequest -Uri https://website.com/ -UserAgent ([Microsoft.PowerShell.Commands.PSUserAgent]::InternetExplorer)
Parametereigenschappen
Type: | String |
Default value: | None |
Ondersteunt jokertekens: | False |
DontShow: | False |
Parametersets
(All)
Position: | Named |
Verplicht: | False |
Waarde uit pijplijn: | False |
Waarde uit pijplijn op eigenschapsnaam: | False |
Waarde van resterende argumenten: | False |
-WebSession
Specificeert een webverzoeksessie. Voer de naam van de variabele in, inclusief het dollarteken ($
).
Als u een waarde in de webaanvraagsessie wilt overschrijven, gebruikt u een cmdlet-parameter, zoals UserAgent of Credential. Parameterwaarden hebben voorrang op waarden in de webaanvraagsessie. Inhoudsgerelateerde headers, zoals Content-Type
, worden ook overschreven wanneer een MultipartFormDataContent object wordt geleverd voor Body.
In tegenstelling tot een externe sessie is de webaanvraagsessie geen permanente verbinding. Het is een object dat informatie bevat over de verbinding en de aanvraag, waaronder cookies, referenties, de maximale omleidingswaarde en de tekenreeks van de gebruikersagent. U kunt deze gebruiken om status en gegevens te delen tussen webaanvragen.
Als u een webaanvraagsessie wilt maken, voert u een variabelenaam in, zonder dollarteken, in de waarde van de parameter SessionVariable van een Invoke-WebRequest
-opdracht.
Invoke-WebRequest
maakt de sessie en slaat deze op in de variabele. In volgende opdrachten gebruikt u de variabele als de waarde van de parameter WebSession.
U kunt de SessionVariable en WebSession parameters niet gebruiken in dezelfde opdracht.
Parametereigenschappen
Type: | WebRequestSession |
Default value: | None |
Ondersteunt jokertekens: | False |
DontShow: | False |
Parametersets
(All)
Position: | Named |
Verplicht: | False |
Waarde uit pijplijn: | False |
Waarde uit pijplijn op eigenschapsnaam: | False |
Waarde van resterende argumenten: | False |
CommonParameters
Deze cmdlet ondersteunt de algemene parameters: -Debug, -ErrorAction, -ErrorVariable, -InformationAction, -InformationVariable, -OutBuffer, -OutVariable, -PipelineVariable, -ProgressAction, -Verbose, -WarningAction en -WarningVariable. Zie about_CommonParametersvoor meer informatie.
Invoerwaarden
Object
U kunt de hoofdtekst van een webaanvraag doorsluisen naar deze cmdlet.
Uitvoerwaarden
BasicHtmlWebResponseObject
Deze cmdlet retourneert het antwoordobject dat het resultaat van de webaanvraag vertegenwoordigt.
Notities
PowerShell bevat de volgende aliassen voor Invoke-WebRequest
:
- Alle platforms:
iwr
Vanaf PowerShell 6.0.0.0 Invoke-WebRequest
biedt alleen ondersteuning voor basisparsering.
Zie BasicHtmlWebResponseObjectvoor meer informatie.
Vanwege wijzigingen in .NET Core 3.1 gebruikt PowerShell 7.0 en hoger de eigenschap HttpClient.DefaultProxy om de proxyconfiguratie te bepalen.
De waarde van deze eigenschap wordt bepaald door uw platform:
- voor Windows: leest proxyconfiguratie uit omgevingsvariabelen. Als deze variabelen niet zijn gedefinieerd, wordt de eigenschap afgeleid van de proxy-instellingen van de gebruiker.
- Voor macOS-: leest proxyconfiguratie uit omgevingsvariabelen. Als deze variabelen niet zijn gedefinieerd, wordt de eigenschap afgeleid van de proxy-instellingen van het systeem.
- voor Linux-: leest proxyconfiguratie uit omgevingsvariabelen. Als deze variabelen niet zijn gedefinieerd, initialiseert de eigenschap een niet-geconfigureerd exemplaar dat alle adressen omzeilt.
De omgevingsvariabelen die worden gebruikt voor DefaultProxy
initialisatie op Windows- en Unix-platforms zijn:
-
HTTP_PROXY
: de hostnaam of het IP-adres van de proxyserver die wordt gebruikt voor HTTP-aanvragen. -
HTTPS_PROXY
: de hostnaam of het IP-adres van de proxyserver die wordt gebruikt voor HTTPS-aanvragen. -
ALL_PROXY
: de hostnaam of het IP-adres van de proxyserver die wordt gebruikt op HTTP- en HTTPS-aanvragen voor het gevalHTTP_PROXY
ofHTTPS_PROXY
niet zijn gedefinieerd. -
NO_PROXY
: een door komma's gescheiden lijst met hostnamen die moeten worden uitgesloten van proxying.
PowerShell 7.4 heeft ondersteuning toegevoegd voor het Brotli-compressie-algoritme.