我想使用Google Drive API v3创建包含内容的文件。我已通过OAuth进行身份验证并加载了Drive API。声明类似于以下工作(但生成没有内容的文件):
gapi.client.drive.files.create({
"name": "settings",
}).execute();
不幸的是,我无法弄清楚如何创建一个包含内容的文件。我找不到使用Drive API v3的JavaScript示例。我需要传递一些特殊参数吗?
为简单起见,假设我有一个类似'{“名称”:“test”}的字符串,它是JSON格式,应该是创建文件的内容。
答案 0 :(得分:16)
不幸的是,我没有找到只使用谷歌驱动器API的答案,而是我遵循了Gerardo的评论并使用了谷歌请求api。以下是将文件上传到Google云端硬盘的功能。
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);
}
答案 1 :(得分:5)
这是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;
}
});
您需要使用connect/authorise
中的任何一个following scopeshttps://www.googleapis.com/auth/drive
https://www.googleapis.com/auth/drive.file
编辑:可以通过将mimeType
从application/vnd.google-apps.folder
更改为支持的google mime types之一来创建Google文件(文档,工作表等)。 HOWEVER ,截至目前,无法将任何内容上传到已创建的文件中。
要上传文件,请使用solution provided by @Geminus。请注意,您可以上传文本文件或csv文件,并将其内容类型分别设置为google doc或google sheet,google将尝试转换它。我已经测试了这个文本 - > doc,它有效。
答案 2 :(得分:0)
使用 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);
});
答案 3 :(得分:-1)
这在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);
});
答案 4 :(得分:-1)
/* 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) { });
}