我有一个正在运行的应用程序,但今天它决定休息所以我认为谷歌已经做了一些改变。 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);
};
`
答案 0 :(得分:0)
如果未提供必填字段或参数,提供的值无效或提供的字段组合无效,则表示您收到error 400。
尝试将重复的父项添加到云端硬盘项时,也会抛出此错误。当尝试添加将在目录图中创建循环的父级时,也可以抛出它。
有关如何在Google云端硬盘中上传Google表格格式的详细信息,请查看以下相关的SO问题: