1

Curl 正在发布,但 Google AppScript 没有使用相同的凭据。

我试图让谷歌应用脚​​本将当前文档作为 html 内容发布到新的 Jive 文档

// 以下 curl 命令完美运行

curl -u USERNAMEHERE:PASSWORDHERE -H "Content-Type: application/json" --data '{ "type": "document", "content": { "type": "text/html", "text":"<h1>HOORAY</h1> a Document is born"}, "subject": "TEST WORKED"}' https://MYJIVEURL.com/api/core/v3/places/XXXXXXXX/contents

// Apps 脚本现在抛出 401 并失败

function pleaseWork() {
  var encode = Utilities.base64Encode('USER:PASS', Utilities.Charset.UTF_8);
  var docbody = DocumentApp.getActiveDocument().getBody();
  var subject = DocumentApp.getActiveDocument().getName();
  var url = "https://JIVEURL/api/core/v3/places/XXXXXX/contents";

  var option = {
    authorization: "Basic " + encode,
    contentType: "application/json",
    method: 'post',
    payload: JSON.stringify({
      subject: subject,
      type: "document",
      content: {
        type: 'text/html',
        text: docbody
      },
    })
  }

  var response = UrlFetchApp.fetch(url, option).getContentText()

}```




Theres no other errors to speak of in the AppScript editor. So I must be leaving something out. I just don't know what that is
4

1 回答 1

0

第1部分 -payload

params对象有一个名为“payload”的参数,它应该包含您要作为字符串化 JSON 发送的数据。因此,您应该执行以下操作,而不是直接引用content,subject和(顺便说一句,可以通过参数和通过相应参数设置的内容类型):typeUrlFEtchAppcontentTypemethod

var option = {
  //other parameters here;
  method : 'post',
  contentType : 'application/json',
  payload : JSON.stringify( {
  content : '',
  subject : '',
  type    : ''
  } )
}

第2部分 -headers

尽管看起来很随意,但并非所有参数都应该移动到对象的顶级属性中params。可以通过这种方式设置一组封闭的属性(请参阅参考资料)。授权仍应设置为 a header,因此:

var option = {
  //other parameters here;
  headers : {
    Authorization : 'Basic ' + yourAuth
  },
  method : 'post',
  contentType : 'application/json',
  payload : JSON.stringify( {
    content : '',
    subject : '',
    type    : ''
  } )
}

有用的链接

  1. UrlFetchApp.fetch() 参考
于 2019-06-25T11:53:10.180 回答