使用 Google Drive Api v3 (javascript) 创建文件

IT技术 javascript google-drive-api
2021-01-15 16:24:07

我想使用 Google Drive API v3 创建一个包含内容的文件。我已通过 OAuth 进行身份验证并加载了 Drive API。类似于以下工作的语句(但生成一个没有内容的文件):

gapi.client.drive.files.create({
    "name": "settings",
}).execute();

不幸的是,我无法弄清楚如何创建一个包含内容的文件。我找不到使用 Drive API v3 的 JavaScript 示例。是否有一些我需要传递的特殊参数?

为简单起见,假设我有一个像 '{"name":"test"}' 这样的字符串,它是 JSON 格式的,应该是所创建文件的内容。

5个回答

不幸的是,我没有找到仅使用 google drive api 的答案,而是按照 Gerardo 的评论并使用了 google request api。下面是一个将文件上传到谷歌驱动器的功能。

var createFileWithJSONContent = function(name,data,callback) {
  const boundary = '-------314159265358979323846';
  const delimiter = "\r\n--" + boundary + "\r\n";
  const close_delim = "\r\n--" + boundary + "--";

  const contentType = 'application/json';

  var metadata = {
      'name': name,
      'mimeType': contentType
    };

    var multipartRequestBody =
        delimiter +
        'Content-Type: application/json\r\n\r\n' +
        JSON.stringify(metadata) +
        delimiter +
        'Content-Type: ' + contentType + '\r\n\r\n' +
        data +
        close_delim;

    var request = gapi.client.request({
        'path': '/upload/drive/v3/files',
        'method': 'POST',
        'params': {'uploadType': 'multipart'},
        'headers': {
          'Content-Type': 'multipart/related; boundary="' + boundary + '"'
        },
        'body': multipartRequestBody});
    if (!callback) {
      callback = function(file) {
        console.log(file)
      };
    }
    request.execute(callback);
}
谢谢你。我快疯了。
2021-03-15 16:24:07
我怎样才能得到这个文件的内容?
2021-03-22 16:24:07
@DavidGiven 发布了一个解决方案 gapi.client.drive
2021-03-23 16:24:07
如果你曾经通过 找到了如何做到这一点gapi.client.drive,我很想知道。
2021-03-27 16:24:07
我的文件夹中有文件并使用 URL 上传如何执行此操作?
2021-04-11 16:24:07

这是解决方案gapi.client.drive

var parentId = '';//some parentId of a folder under which to create the new folder
var fileMetadata = {
  'name' : 'New Folder',
  'mimeType' : 'application/vnd.google-apps.folder',
  'parents': [parentId]
};
gapi.client.drive.files.create({
  resource: fileMetadata,
}).then(function(response) {
  switch(response.status){
    case 200:
      var file = response.result;
      console.log('Created Folder Id: ', file.id);
      break;
    default:
      console.log('Error creating the folder, '+response);
      break;
    }
});

您需要连接/授权以下任一范围

https://www.googleapis.com/auth/drive
https://www.googleapis.com/auth/drive.file

编辑:可以通过将mimeTypefrom更改application/vnd.google-apps.folder为受支持的google mime types之一来创建 google 文件(doc、sheets 等)但是,到目前为止,无法将任何内容上传到创建的文件中。

要上传文件,请使用@Geminus 提供解决方案请注意,您可以上传文本文件或 csv 文件并将其内容类型分别设置为 google doc 或 google sheet,谷歌将尝试对其进行转换。我已经针对 text -> doc 对此进行了测试,并且可以正常工作。

不过,这会创建一个文件夹,而不是一个文件。
2021-03-25 16:24:07
我没有编辑你的答案。我在上面编辑了我的评论(因为我误读了你的代码并且评论是错误的)。
2021-03-26 16:24:07
啊,对!英语是一种愚蠢的语言,不是吗?无论如何,我感谢您的帮助;我仍然想要一个实际的解决方案......
2021-03-26 16:24:07
这实际上创建了一个文件夹,我将很快发布文件的解决方案
2021-03-27 16:24:07
@DavidGiven,我刚刚编辑了我的答案,您可以创建文档/工作表或任何其他受支持的文件类型,但不能用于gapi.client.drive.files.create实际上传内容。
2021-03-30 16:24:07

使用gapi.client.drive,无法上传文件内容。您只能上传元数据。

相反,建议直接使用 Google REST API。此解决方案使用一个FormData对象来构建多部分表单主体,这简化了实现,并gapi.auth.getToken()检索所需的访问令牌。该解决方案也适用于Google 共享驱动器

var fileContent = "sample text"; // fileContent can be text, or an Uint8Array, etc.
var file = new Blob([fileContent], {type: "text/plain"});
var metadata = {
    "name": "yourFilename",
    "mimeType": "text/plain",
    "parents": ["folder id or 'root'"], // Google Drive folder id
};

var accessToken = gapi.auth.getToken().access_token;
var form = new FormData();
form.append('metadata', new Blob([JSON.stringify(metadata)], { type: 'application/json' }));
form.append('file', file);

fetch("https://www.googleapis.com/upload/drive/v3/files?uploadType=multipart&supportsAllDrives=true", {
    method: 'POST',
    headers: new Headers({ 'Authorization': 'Bearer ' + accessToken }),
    body: form,
}).then((res) => {
    return res.json();
}).then(function(val) {
    console.log(val);
});

这在 v3 中工作正常:

        var fileMetadata = {
            'name' : 'MaxBarrass',
            'mimeType' : 'application/vnd.google-apps.folder'
        };

        gapi.client.drive.files.create({
            resource: fileMetadata,
            fields: 'id'
        }).execute(function(resp, raw_resp) {
            console.log('Folder Id: ', resp.id);
        });
我意识到这一点,但问题专门询问了有关创建文件的问题。因此,很难理解为什么显示文件夹创建的示例会有用。
2021-03-17 16:24:07
是的,你可以用它创建文件夹......它确实在“gapi.client.drive.files.create”中说“files.create”,它最终是所有节点,所以它们更像是文件而不是文件夹......
2021-03-20 16:24:07
这似乎是用于创建文件夹,而不是文件。
2021-04-01 16:24:07
/*  Now to create a new file */ 
function insertNewFile(folderId) 
{   
    var content = " ";  
    var FolderId = ""; 
    var contentArray = new Array(content.length);
    for (var i = 0; i < contentArray.length; i++) 
    {
        contentArray[i] = content.charCodeAt(i);
    }
    var byteArray = new Uint8Array(contentArray);
    var blob = new Blob([byteArray], {type: 'text/plain'});     
    insertFile(blob, fileInserted, folderId); 
} 
function fileInserted(d) 
{   
    setPercent("100");   
    var FI = FolderId;  
    if(FI !== myRootFolderId)
    {           
        insertFileIntoFolder(FI, d.id);         
        removeFileFromFolder(d.parents[0].id,d.id);     
    }   
    openFile(d.id); 
} 
function insertFileIntoFolder(folderId, fileId) 
{   
    var body = {'id': folderId};   
    var request = gapi.client.drive.parents.insert({
        'fileId': fileId,
        'resource': body   });   
    request.execute(function(resp) { }); 
 } 

来源:https : //gist.github.com/mkaminsky11/8624150

你错过了insertFile(),这实际上是在做这项工作;它与上面@Geminus 的回答相同,使用显式帖子上传数据。
2021-03-30 16:24:07