Google Drive Api v3如何使用Google表格格式上传? 400响应

时间:2016-12-13 11:25:53

标签: javascript google-api google-drive-api google-client google-api-js-client

我有一个正在运行的应用程序,但今天它决定休息所以我认为谷歌已经做了一些改变。 CSV数据传递给我的函数,然后上传文件并将其转换为谷歌工作表格式(这就是它所做的)

我正在使用JS,并且在文档中没有关于如何使用V3的示例。我已经读过,而不是在客户端的请求参数中运行' true:您只需指定所需的mimeType,API就会为您执行此操作。

这里是说明文档中的内容 - >

  

https://developers.google.com/drive/v3/web/migration#other_changes

     

现在,通过在资源正文中设置适当的目标mimeType,而不是指定?convert = true来请求导入到Google Docs格式。

这是我现在正在查看的代码。每当我将mimeType保留为400 error

时,它都会返回'application/vnd.google-apps.spreadsheet'
gapiService.uploadCSVToGoogleSheet =function(data, sheetTitle) {
      // create file


      cnsl("in gapiService.uploadCSVToGoogleSheet()!!!", "start");


      gapi.client.load('drive', 'v3',

         upload

      );

      function upload (){

          var fileData = new Blob(data, {type: "text/csv-creation", fileName: "testName"});

          const boundary = '-------314159265358979323846';
          const delimiter = "\r\n--" + boundary + "\r\n";
          const close_delim = "\r\n--" + boundary + "--";

          var reader = new FileReader();
          reader.readAsBinaryString(fileData);

          reader.onload = function (e) {
              console.log("loaded reader ");

              console.log(contentType);
              var metadata = {
                  'name': sheetTitle + "-" + getCurrentDate(),
                  'mimeType': 'application/vnd.google-apps.spreadsheet'
              };

              var base64Data = btoa(reader.result);
              var multipartRequestBody =
                  delimiter +
                  'Content-Type: application/json\r\n\r\n' +
                  JSON.stringify(metadata) +
                  delimiter +
                  'Content-Type: ' + contentType + '\r\n' +
                  'Content-Transfer-Encoding: base64\r\n' +
                  '\r\n' +
                  base64Data +
                  close_delim;

              // POST INFO
              var request = gapi.client.request({
                  'path': '/upload/drive/v3/files',
                  'method': 'POST',
                  'params': {

                         'uploadType': 'multipart'
                      //  'convert': true
                 },

                  'headers': {
                      'Content-Type': 'multipart/mixed; boundary="' + boundary + '"'
                  },
                  'body': multipartRequestBody
              });

              request.execute(gapiService.afterFileInsert);

          } //endof reader onload

      }



      function getCurrentDate() {
          console.log("in get GetCurrentDATE");
          var today = new Date();
          var dd = today.getDate();
          var mm = today.getMonth() + 1; //January is 0!
          var yyyy = today.getFullYear();

          if (dd < 10) {
              dd = '0' + dd
          }

          if (mm < 10) {
              mm = '0' + mm
          }

          today = mm + '_' + dd + '_' + yyyy;
          return today;
      };

      // console.log(fileData, null, 0);

  };

`

1 个答案:

答案 0 :(得分:0)

如果未提供必填字段或参数,提供的值无效或提供的字段组合无效,则表示您收到error 400

尝试将重复的父项添加到云端硬盘项时,也会抛出此错误。当尝试添加将在目录图中创建循环的父级时,也可以抛出它。

有关如何在Google云端硬盘中上传Google表格格式的详细信息,请查看以下相关的SO问题: