javascript - 谷歌选择器选择文件回调
问题描述
我已经集成并尝试使用 google picker api google picker api 但我可以将回调转换为文件吗?所以我可以将文件上传到我的服务器
function pickerCallback(data) {
if (data.action == google.picker.Action.PICKED) {
var fileId = data.docs[0].id; alert('The user selected: ' + fileId);
}
}
解决方案
获得 后fileId
,您可以按照使用 Drive API 下载文件的文档中的说明下载文件
不幸的是,没有浏览器 Javascript 的示例,但您使用例如XML HttpRequests。
样本:
//provided you already have the following line from previous steps:
oauthToken = authResult.access_token;
var doc = data[google.picker.Response.DOCUMENTS][0];
var mimeType = doc[google.picker.Document.MIME_TYPE];
var xhr = new XMLHttpRequest();
xhr.open("GET", "https://www.googleapis.com/drive/v3/files/"+fileId+'?alt=media', true);
xhr.setRequestHeader('Authorization','Bearer '+oauthToken);
xhr.responseType = 'arraybuffer'
xhr.onload = function(){
var base64 = 'data:' + mimeType + ';base64,' + base64ArrayBuffer(xhr.response);
//now you have the file content as binary data (ArrayBuffer) - proceed as desired
}
xhr.send();
笔记:
您可以根据您的情况修改xhr.responseType
为 egblob
或其他responseType 。
或者,您也可以对“https://www.googleapis.com/drive/v3/files”执行Fetch 请求以获取文件 blob。
推荐阅读
- c - 如何解决以下代码中的逻辑错误
- python - 具有“持续时间”变量的累积图
- angular - Angular Amplify init Cognito:默认情况下缺少配置文件配置
- python - 当 nan==nan 为 False 时,为什么 (nan,)==(nan,) 为 True?
- firebase - 如何向firebase中的列表字段添加值?
- python - Django(REST 框架)每隔一个调用返回一个空列表
- php - 为什么会话变量为空导航下一页?
- flutter - 如何将提供程序与地图一起使用,以便每个小部件都在听该地图中的不同键?
- python - 如何在Django中显示小于特定数字的值
- python - 使用二维数组列表搜索函数 Python