gpt4 book ai didi

json - smartsheet api更新行错误1004。您无权

转载 作者:行者123 更新时间:2023-12-02 23:54:44 24 4
gpt4 key购买 nike

我正在尝试使用Powershell和API更新单元格,但出现错误:1004您无权执行此操作。我已经删除了ID。 。 。

我有30天的试用期。在使用API​​进行更新之前,我需要购买某种程度的支持吗?该表在我的帐户上,我是所有者。书写纸角色不包含在所有者中吗?

我正在使用Powershell 5.1发出http请求-这是我的脚本。它首先获取正确的工作表ID,然后将我感兴趣的行和列放入哈希表中,然后尝试更新工作表,但是尽管我是所有者,但我未经授权。

# access account of jjj.mmm@ddd.com
$apiKey = "3ccfgk..."
$url = "https://api.smartsheet.com/2.0/sheets/"
$get_headers = @{"Authorization" = "Bearer " + $apiKey}
$put_headers = @{"Authorization" = "Bearer " + $apiKey, "Content-Type: application/json" }

# get all the sheets
$response = Invoke-RestMethod -Uri $url -Headers $get_headers
$rd = $response.data
$json = ConvertTo-Json $rd

# find the Forecast sheet
$sheet_id = $rd | Where {$_.name -eq "Forecast Intermediary Sheet"} | Select -ExpandProperty id
"Sheet ID: $sheet_id"

#get the Forecast sheet
$surl = "$url$sheet_id"
$surl
$response = Invoke-RestMethod -Uri $surl -Headers $get_headers
$response | Format-List

# iterate over the rows and get the active ones
$active_rows = @{}
foreach ($row in $response.rows) {
if ($row.rowNumber -ge 14) {
if ($row.cells[2].value -Match "Active") {
$active_rows.Add($row.cells[2].value, $row.id)
}
}
}

# get the col_ids by date
$date_cols = @{}
foreach ($c in $response.columns) {
if ($c.title -as [datetime]) {
$d = $c.title -replace "/20", "/"
$ds = [datetime]::parseexact($d, 'mm/dd/yy', $null)
$date_cols.Add($ds.Tostring("yyyy-mm-dd"), $c.id)
}

}


"UPDATE:"
$rowid = $active_rows["SSL PS Active"]
$colid = $date_cols["2017-11-01"]
"row: $rowid, col: $colid"

$json = '[{ "id": "'+$rowid+'", "cells": [{"columnId": "'+$colid+'","value": "23"} }]'
"JSON: $json"
$purl = "$surl/rows"
"PUT URL: $purl"
$r = Invoke-RestMethod -Method "PUT" -uri $purl -Headers $put_headers -Body $json
$r

以下是脚本的输出。该错误似乎表明它在语法上是正确的,但是OWNER没有足够的权限。
Sheet ID: 5724...
https://api.smartsheet.com/2.0/sheets/5724....
UPDATE:
row: 5668..., col: 5118...
JSON: [{ "id": "5668...", "cells": [{"columnId": "5118...","value": "23"} }]
PUT URL: https://api.smartsheet.com/2.0/sheets/5724.../rows


Invoke-RestMethod : {
"errorCode" : 1004,
"message" : "You are not authorized to perform this action.",
"refId" : "14a7o8lu9sfyj"
}
At \\winfiles\jmoore\powershell\ss_api.ps1:58 char:6
+ $r = Invoke-RestMethod -Method "PUT" -uri $purl -Headers $put_headers ...
+ ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+ CategoryInfo : InvalidOperation: (System.Net.HttpWebRequest:HttpWebRequest) [Invoke-RestMethod],
WebException
+ FullyQualifiedErrorId : WebCmdletWebResponseException,Microsoft.PowerShell.Commands.InvokeRestMethodComand

这是我工作表的元数据
Sheet ID: 5724...
https://api.smartsheet.com/2.0/sheets/5724....


id : 5724...
name : Forecast Intermediary Sheet
version : 2
totalRowCount : 37
accessLevel : OWNER
effectiveAttachmentOptions : {GOOGLE_DRIVE, DROPBOX, ONEDRIVE, EGNYTE...}
ganttEnabled : False
dependenciesEnabled : False
resourceManagementEnabled : False
cellImageUploadEnabled : True
userSettings : @{criticalPathEnabled=False; displaySummaryTasks=True}
permalink : https://app.smartsheet.com/b/home?lx=LCTEj6F0xWNKWWxFUuLH0w
createdAt : 2017-11-22T22:34:51Z
modifiedAt : 2017-11-22T22:34:51Z
columns : {@{id=6985...; index=0; title=Column1; type=TEXT_NUMBER; primary=True;
validation=False; width=64}, @{id=1356...; index=1; title=Column2;
type=PICKLIST; options=System.Object[]; validation=False; width=64},
@{id=5859...; index=2; title=Column3; type=TEXT_NUMBER; validation=False;



....

最佳答案

您应该能够使用试用版Smartsheet帐户拥有的API访问 token 来进行API调用,并且可以肯定地使用自己拥有的API访问 token 来更新自己拥有的工作表。

我怀疑1004错误响应是由于$put_headers的内容格式不正确引起的。也就是说,Smartsheet无法准确解析您尝试在$put_headers中指定的 header ,以识别授权 header 并读取其值。当Smartsheet在入站API请求中看不到授权 header 时,它将以1004 You are not authorized to perform this action.错误响应进行响应。

若要解决此问题,建议您使用Fiddler之类的工具来检查出站“更新行”请求,并特别注意请求中存在哪些 header 。然后,如果发现请求中不存在授权 header ,则需要弄清楚如何在PowerShell中指定多个请求 header ,并相应地更新代码来重新设置$put_headers的值。

更新(添加PowerShell代码):

我不是PowerShell专家,但是您可以尝试替换以下行:
$put_headers = @{"Authorization" = "Bearer " + $apiKey, "Content-Type: application/json"}
用这些行代替:

$put_headers = @{}
$put_headers.Add("Authorization", "Bearer " + $apiKey)
$put_headers.Add("Content-Type", "application/json")

关于json - smartsheet api更新行错误1004。您无权,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47446081/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com