У меня есть код скрипта ниже, он использует curl для этой операции, я хочу повторить то же самое с помощью Invoke-WebRequest из PowerShell. Как это сделать?
$FX_USER=$args[0]
$FX_PWD=$args[1]
$FX_JOBID=$args[2]
$REGION=$args[3]
$FX_HOST=$args[4]
$runId=$(curl -k --header "Content-Type: application/json;charset=UTF-8" -X POST -d '{}' -u ""${FX_USER}":"${FX_PWD}"" ""${FX_HOST}"/api/v1/runs/job/${FX_JOBID}?region=${REGION}" | jq -r '."data"|."id"')
Write-Host "runId = $runId"
решение1
$FX_USER=$args[0]
$FX_PWD=$args[1]
$FX_JOBID=$args[2]
$REGION=$args[3]
$TAGS=$args[4]
$SUITES=$args[5]
$CATEGORIES=$args[6]
$FX_HOST=$args[7]
Write-Host "user = ${FX_USER}"
Write-Host "region = ${REGION}"
Write-Host "jobid = ${FX_JOBID}"
Write-Host "hostname = ${FX_HOST}"
$pair = "${FX_USER}:${FX_PWD}"
Write-Host "$pair"
$bytes = [System.Text.Encoding]::ASCII.GetBytes($pair)
$base64 = [System.Convert]::ToBase64String($bytes)
Write-Host "$base64"
$basicAuthValue = "Basic $base64"
Write-Host "$basicAuthValue"
$headers = @{ Authorization = $basicAuthValue }
Write-Host "$headers"
add-type @"
using System.Net;
using System.Security.Cryptography.X509Certificates;
public class TrustAllCertsPolicy : ICertificatePolicy {
public bool CheckValidationResult(
ServicePoint srvPoint, X509Certificate certificate,
WebRequest request, int certificateProblem) {
return true;
}
}
"@
$AllProtocols = [System.Net.SecurityProtocolType]'Ssl3,Tls,Tls11,Tls12'
[System.Net.ServicePointManager]::SecurityProtocol = $AllProtocols
[System.Net.ServicePointManager]::CertificatePolicy = New-Object TrustAllCertsPolicy
$runId=$((Invoke-WebRequest -Uri "${FX_HOST}/api/v1/runs/job/${FX_JOBID}?region=${REGION}" -Headers $headers -Method POST -ContentType "application/json;charset=UTF-8" ) | ConvertFrom-Json | select -expand data | select -expand id)
Write-Host "runId = $runId"
решение2
# get function / cmdlet details
(Get-Command -Name Invoke-WebRequest).Parameters
Get-help -Name Invoke-WebRequest -Full
Get-help -Name Invoke-WebRequest -Online
Get-help -Name Invoke-WebRequest -Examples
Вы хотя бы пробовали то, что вы делаете с Invoke-WebRequest, чтобы увидеть, успешно это или нет? Какие ошибки вы обнаружили.
PowerShell использует curl как псевдоним для Invoke-WebRequest. Конечно, это не одно и то же, и поэтому они не могут быть реплицированы одинаково.
Веб-командлеты были улучшены PSCore (Windows / Linux / OSX) по сравнению с PSv5x и ниже. Чтобы убедиться, что у вас не возникнут проблемы с подключением к сайту, обязательно используйте ...
[Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12
...в вашем коде. PSCore предназначен для работы параллельно с Windows PowerShell, но не заменяет его.
Использование командлета cUrl против Invoke-WebRequest
$headers = @{
'X-JFrog-Art-Api' = $apiKey
"Content-Type" = "application/json"
"Accept" = "application/json"
}
Invoke-WebRequest -InFile $file -Method Put -Uri "$ARTIFACTORY_HOST/third-party/test/readme.md" -Headers $headers -Verbose
curl -T readme.md "${ARTIFACTORY_HOST}/third-party/test/readme.md " \
-H "X-JFrog-Art-Api: ${apiKey}" \
-H "Content-Type: application/json" \
-H "Accept: application/json"
Вы также можете использовать curl.exe непосредственно в PowerShell, если захотите,так же, как и с любым другим внешним exe-файлом.