Я пробовал все комбинации, о которых я могу думать, чтобы сделать эту работу. Что мне нужно, чтобы отправить в New Basecamp API как поле POST
, чтобы он принял мои данные POST?Google Apps Script Basecamp POST
Мой код:
function getFilterBy() {
var url = "https://basecamp.com/****/api/v1/projects/*****.json";
var payload = {"name" : "myapp", "description" : "no desc mls"};
var opt = {
"contentType" : "application/json",
"method" : "POST",
"headers":{ "User-Agent": "myapp ([email protected])",
"Authorization" :"Basic " + Utilities.base64Encode("user" + ":" + "pass")},
"validateHttpsCertificates" :false,
"muteHttpExceptions" : true,
"payload" : payload
};
var response = UrlFetchApp.fetch(url, opt);
var text = response.getContentText();
Logger.log(text);
}
Моя Ошибка:
lexical error: invalid char in json text.
description=no+desc+mls&name=Ho
(right here) ------^
Я попытался Utilities.jsonStringify
, но не повезло. Я знаю его ошибку noob, но я просто не могу понять это. Если есть место, где вы знаете, где я могу получить эту информацию, это было бы феноменально.
Спасибо!
UPDATE 1
function getFilterBy() {
var url = "https://basecamp.com/****/api/v1/projects/****.json";
var payload = {name : 'myApp Change'};
var opt = {
"contentType" : "application/json",
"method" : "POST",
"headers":{ "User-Agent": "myApp ([email protected])",
"Authorization" :"Basic " + Utilities.base64Encode("user" + ":" + "pass")},
"validateHttpsCertificates" :false,
"muteHttpExceptions" : true,
"payload" : Utilities.jsonStringify(payload)
};
var response = UrlFetchApp.fetch(url, opt);
var text = response.getContentText();
Logger.log(text);
}
Урожайность Err:
<body>
<div class="dialog">
<div class="innercol">
<h1>Hmm, that isn’t right</h1>
<h2>You may have typed the URL incorrectly.</h2>
<p>Check to make sure you’ve got the spelling, capitalization, etc. exactly right.</p>
</div>
</div>
<p id="back" class="back">
<a href="javascript:window.history.back();">← Back to previous page</a>
</p>
<script type="text/javascript">
if (window.history.length <= 1) document.getElementById("back").style.display = "none";
</script>
</body>
это делает работу, чтобы создать новый проект, но не редактировать существующий проект в течение некоторого ре сын. –
Вы не должны получать указанную вами ошибку, если это так. Вы получаете другую ошибку - это не должно касаться «недопустимого символа в json-тексте». –
Приносим извинения, я добавил обновление. Спасибо. –