2

@Nvicoの優れた回答に基づいて、ファイルをGoogleドライブにアップロードできました。問題は、回答のコードが毎回新しいファイルを作成することです。すでに作成されたファイルIDを指定して、そのコンテンツを直接更新する方法があります(ファイルを使用: update api) 新しいものを作成せずに?

現在、私の解決策は、Files:delete api を使用して、ファイルを更新して古いファイルを削除し、@Nvico コードを使用して新しいファイルを作成することです。

4

1 に答える 1

3

drive.files.insert エンドポイントを使用する代わりに、ほぼ同じコードを使用して、更新要求を drive.files.update エンドポイントに送信できます。

/**
 * Update existing file.
 *
 * @param {String} fileId ID of the file to update.
 * @param {Object} fileMetadata existing Drive file's metadata.
 * @param {File} fileData File object to read data from.
 * @param {Function} callback Callback function to call when the request is complete.
 */
function updateFile(fileId, fileMetadata, fileData, callback) {
  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) {
    var contentType = fileData.type || 'application/octect-stream';
    // Updating the metadata is optional and you can instead use the value from drive.files.get.
    var base64Data = btoa(reader.result);
    var multipartRequestBody =
        delimiter +
        'Content-Type: application/json\r\n\r\n' +
        JSON.stringify(fileMetadata) +
        delimiter +
        'Content-Type: ' + contentType + '\r\n' +
        'Content-Transfer-Encoding: base64\r\n' +
        '\r\n' +
        base64Data +
        close_delim;

    var request = gapi.client.request({
        'path': '/upload/drive/v2/files/' + fileId,
        'method': 'PUT',
        'params': {'uploadType': 'multipart', 'alt': 'json'},
        'headers': {
          'Content-Type': 'multipart/mixed; boundary="' + boundary + '"'
        },
        'body': multipartRequestBody});
    if (!callback) {
      callback = function(file) {
        console.log(file)
      };
    }
    request.execute(callback);
  }
}

主な違いは、リクエスト URL とメソッドにあります。

PUT /upload/drive/v2/files/<FILE_ID>
于 2012-08-14T15:59:39.530 に答える