以下代码在 Windows Server 上的 PowerShell 中完美运行
$user = "XXXXX"
$pass = "XXXXX"
$base64AuthInfo = [Convert]::ToBase64String([Text.Encoding]::ASCII.GetBytes(("{0}:{1}" -f $user, $pass)))
$headers = New-Object "System.Collections.Generic.Dictionary[[String],[String]]"
$headers.Add('Authorization',('Basic {0}' -f $base64AuthInfo))
$headers.Add('Accept','application/json')
#$FilePath = 'C:\Upload\User Entitlement Export.csv';
$FilePath = '/Users/XXXXXX/Downloads/User Entitlement Export.csv';
$URL = 'https://XXXXXXXXXXX.com/sys_import.do?sysparm_transform_after_load=true&sysparm_import_set_tablename=u_alm_entitlement_user';
$fileBytes = [System.IO.File]::ReadAllBytes($FilePath);
$fileEnc = [System.Text.Encoding]::GetEncoding('UTF-8').GetString($fileBytes);
$boundary = [System.Guid]::NewGuid().ToString();
#$boundary = 'another cool boundary';
$LF = "`r`n";
$bodyLines = (
"--$boundary",
"Content-Disposition: form-data; name=`"file`"; filename=`"User Entitlement Export.csv`"",
"Content-Type: application/octet-stream$LF",
$fileEnc,
"--$boundary--$LF"
) -join $LF
Write-Host $bodyLines;
Invoke-RestMethod -Proxy http://XXXXXXX:8080 -ProxyUseDefaultCredentials -Uri $URL -Method Post -ContentType "multipart/form-data; boundary=`"$boundary`"" -Body $bodyLines -Headers $headers
但是当我在 Mac 上的 PowerShell 核心中运行时,我收到以下错误:
Invoke-RestMethod : The format of value 'multipart/form-data;charset=utf-8;boundary="d0d0dccd-698c-48b8-8770-6bcc7d29f609"' is invalid.
At /Users/laurensbrand/Downloads/uploadCSV.ps1:33 char:1
+ Invoke-RestMethod -Uri $URL -Method Post -ContentType "multipart/form ...
+ ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+ CategoryInfo : NotSpecified: (:) [Invoke-RestMethod], FormatException
+ FullyQualifiedErrorId : System.FormatException,Microsoft.PowerShell.Commands.InvokeRestMethodCommand
知道这里有什么问题吗?非常感谢提前。