在Javascript中使用Google calendar API插入方法创建新日历会返回错误400 "Mis

Creating a new calendar using the Google Calendar API insert method in Javascript returns error 400 "Missing title"

本文关键字:返回 日历 错误 Mis quot 新日历 Javascript Google calendar 创建 方法      更新时间:2023-09-26

我正在尝试使用Javascript在我的Google帐户中创建一个新的日历(通过Google Apps Script编辑器)。

首先,为了确保我的Oauth2与日历API一起工作,我发出一个GET请求来获取我的主日历:

var email = 'me@mydomain.com';
var fetchArgs = {};
fetchArgs.headers = {'Authorization': 'Bearer '+ calendarOauth2Service.getAccessToken() };
fetchArgs.method = 'GET';
fetchArgs.muteHttpExceptions = true;
var url = 'https://www.googleapis.com/calendar/v3/calendars/' + email;
var response = UrlFetchApp.fetch(url, fetchArgs);

请求成功并返回此响应:

{
 "kind": "calendar#calendar",
 "etag": "'"xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx'"",
 "id": "me@mydomain.com",
 "summary": "me@mydomain.com",
 "timeZone": "America/New_York"
}

现在我想使用insert方法将日历添加到我的帐户:

var calendarResource = {
       "summary": "test calendar title"
      };
var fetchArgs = {};
fetchArgs.headers = {'Authorization': 'Bearer '+ calendarOauth2Service.getAccessToken() };
fetchArgs.method = "POST";
fetchArgs.data = calendarResource;
fetchArgs.muteHttpExceptions = true;
var url = 'https://www.googleapis.com/calendar/v3/calendars';
var response = UrlFetchApp.fetch(url, fetchArgs);

未创建日历,响应如下:

{
 "error": {
  "errors": [
   {
    "domain": "global",
    "reason": "required",
    "message": "Missing title."
   }
  ],
  "code": 400,
  "message": "Missing title."
 }
}

我已经在这个问题上连续工作了将近20个小时了(一点也不夸张),但我还是搞不懂。我尝试了以下方法:

  1. fetchArgs.data = calendarResource;更改为fetchArgs.body = calendarResource;
  2. fetchArgs.data = calendarResource;变为fetchArgs.resource = calendarResource;
  3. 更改fetchArgs.data = calendarResource;fetchArgs.payload = calendarResource;
  4. 更改fetchArgs.data = calendarResource;fetchArgs.summary = calendarResource;
  5. 更改fetchArgs.data = calendarResource;fetchArgs.title = calendarResource;
  6. fetchArgs.data = calendarResource;移动到fetchArgs.header对象
  7. fetchArgs.method = "POST";移动到fetchArgs.header对象
  8. fetchArgs.contentType = 'application/json;添加到fetchArgs对象和fetchArgs.header对象
  9. 还有很多其他的事情,现在想不起来了

SO上没有那么多与此相关的问题。这些是我一直在尝试的东西:

Google Calendar REST API错误

谷歌日历。插入API返回400 'required'

这是我最初的问题,我试图在我的谷歌应用程序域上为另一个日历做这件事,但由于我无法做到这一点,我决定创建这个问题,以从等式中删除域范围内的委托问题,只是专注于API调用。

另外,还有一件事值得一提:我能够使用Google Calendar API Calendar: insert documentation页面上的API Explorer成功创建日历。

它告诉我请求是这样的:

POST https://www.googleapis.com/calendar/v3/calendars
{
 "summary": "test calendar title"
}

结果是这样的:

200 OK
- HIDE HEADERS -
cache-control:  no-cache, no-store, max-age=0, must-revalidate
content-encoding:  gzip
content-length:  193
content-type:  application/json; charset=UTF-8
date:  Sat, 22 Aug 2015 14:34:05 GMT
etag:  "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx"
expires:  Fri, 01 Jan 1990 00:00:00 GMT
pragma:  no-cache
server:  GSE
vary:  Origin, X-Origin
{
 "kind": "calendar#calendar",
 "etag": "'"xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx'"",
 "id": "mydomain.com_xxxxxxxxxxxxxxxxxxxxx@group.calendar.google.com",
 "summary": "test calendar title"
}

任何想法?

根据luc的回答更新工作代码:

资源需要被字符串化(Google Apps Script调试器显示它是一个对象,而不是字符串)。

var calendarResource = {
       "summary": "test calendar title"
      };
var fetchArgs = {};
fetchArgs.headers = {'Authorization': 'Bearer '+ calendarOauth2Service.getAccessToken() };
fetchArgs.method = "POST";
fetchArgs.payload = JSON.stringify(calendarResource);
fetchArgs.muteHttpExceptions = true;
var url = 'https://www.googleapis.com/calendar/v3/calendars';
var response = UrlFetchApp.fetch(url, fetchArgs);

首先,我怀疑您应该设置有效负载,而不是数据。其次,传入的对象不会被解释为JSON,除非你告诉它(JSON.stringify(calendarResource))。


对于在浏览器环境中使用JavaScript的用户:

调试时,您应该尝试打印最终发送的请求(或通过开发人员工具在浏览器中查看),并将其与资源管理器中的请求进行比较。

使用JavaScript客户端库也可以省去一些麻烦。你看过这个教程吗?https://developers.google.com/google-apps/calendar/quickstart/js