使用APIKEY通过windows powershell访问ASANA



我在powershell中创建了以下两个代码来访问ASANA。

但是他们两个都不起作用。我总是收到这个错误

"远程服务器返回错误:(401)未经授权。"

感谢您的帮助。如果你有一个工作的C#代码,可以连接到任何只需要APIKey的安全服务器,请发布它。我可以将它转换为powershell代码。

代码1

Function Get-WebResponseString
{
    param (
        [Parameter(Mandatory=$true)]
        [String]$Url,       
        [Parameter(Mandatory=$true)]
        [String]$Method,
        [Parameter(Mandatory=$false)]
        [System.Net.NetworkCredential]$Credential
    )
    $Request = [System.Net.WebRequest]::Create($Url)    
    $Request.Method = $Method
    $Request.ContentType = "application/x-www-form-urlencoded";
    if ($Credential -ne $null)
    {
        $Request.Credentials = $credential
        write-host "****" -foregroundcolor blue
    }
    $Response = $Request.GetResponse()
    $StreamReader = New-Object System.IO.StreamReader $Response.GetResponseStream()
    $StreamReader.ReadToEnd()
} 
$Url = "https://app.asana.com/api/1.0/tasks"
$Username = "MMuthusamy@xxxxxx.xom"
$apikey="xxxxxxxxx"
$credential = New-Object System.Net.NetworkCredential @($Username, $apikey)   
Get-WebResponseString -Url $Url -Credential $credential -Method "GET" 

代码2

$sha = New-Object System.Security.Cryptography.SHA1CryptoServiceProvider 
$apikey="xxxxxxx"
#Add colon
$authinfo=$apikey+":";
$string1 = $authinfo
Write-Host $string1  -ForeGroundColor Green
#Encoding format
$enc = [system.Text.Encoding]::UTF8
#get bytes
$data1 = $enc.GetBytes($string1) 
#Encode
$result1 = $sha.ComputeHash($data1)
#convert to 64 bit
$mykey=[System.Convert]::ToBase64String($result1)
Write-Host $mykey -ForeGroundColor Green
$url = "https://app.asana.com/api/1.0/tasks"
$url="https://app.asana.com/api/1.0/users"
$request = [System.Net.WebRequest]::Create($url)
$authorization = "Authorization: Basic " + $myKey
Write-Host $authorization -ForeGroundColor Green
$request.Headers.Add($authorization)
#$request.Headers.Add("Authorization: BASIC $mykey")
$response = $request.GetResponse()
Write-Host $Response  -ForeGroundColor Green 

(我在Asana工作)

401标头表明问题出在您的授权标头中。

HTTP基本身份验证规范不调用用户名:密码的SHA1哈希。这只是该字符串的直接base64编码。尝试将$authinfo传递给对ToBase64String的调用,而不是散列数据。

最新更新