【问题标题】:How to download attachment from gmail api using javascript?如何使用 javascript 从 gmail api 下载附件?
【发布时间】:2016-02-22 02:47:50
【问题描述】:

我正在创建一个网络应用程序来使用 gmail api 阅读我的电子邮件。所有方法都有效(users.messages.list、users.messages.get 等)并显示在 console.log 和我的页面 HTML 中。我注意到的一件事是我必须使用 atob 来解码 body.data 并插入我的 HTML。现在我必须下载或阅读示例 file.docx 的附件,我在回调后使用这个示例 here 我注意到我也必须解码,但如果我这样做了,那里没有下载或阅读的链接,只有microsoft word的一些代码。如果我复制此代码并创建一个文档并粘贴它,则说明文件已损坏。

我的代码:

function getAttachments(messageID, parts, callback) {
    //console.log(parts);
    var attachId = parts.body.attachmentId;
    var request = gapi.client.gmail.users.messages.attachments.get({
        'id': attachId,
        'messageId': messageID,
        'userId': 'me'
    });
    request.execute(function (attachment) {
        callback(parts.filename, parts.mimeType, attachment);
    });
}

if (att.length > 0) {
    for (var i in att) {
        getAttachments(response.id, att[i], function (filename, mimeType, attachment) {
            console.clear();
            console.log(filename, mimeType, attachment);
            console.log(atob(attachment.data.replace(/-/g, '+').replace(/_/g, '/')));
            inline.append('<a href="" style="display: block">' + filename + '</a>');
        });
    }
}

更新

我找到了解决方案here

【问题讨论】:

  • window.location = 'data:'+mimeType+';base64,'+attachment.data.replace(/-/g, '+').replace(/_/g, '/');怎么样
  • 它成功了,但是当我点击我的链接时,浏览器开始下载名为“download.doc”的下载,有没有办法下载真实姓名的文档?当我尝试下载像 .rar (11MB) 这样的大文件时,我意识到它不起作用。
  • 代码为:var link = 'data:' + mimeType + ';base64,' + attachment.data.replace(/-/g, '+').replace(/_/g, '/'); inline.append('&lt;a href="' + link + '" style="display: block"&gt;' + filename + '&lt;/a&gt;');
  • 当我使用 gapi.client.gmail.users.messages.attachments.get 然后它通过 gmail 是未定义的......以及如何通过授权..Plz

标签: javascript gmail-api


【解决方案1】:

试试这个解决方案。

HTML

<a id="download-attach" download="filename"/>

JS

function getAttachments(messageID, parts, callback) {
    var attachId = parts.body.attachmentId;
    var request = gapi.client.gmail.users.messages.attachments.get({
      'id': attachId,
      'messageId': messageID,
      'userId': 'me'
    });
    request.execute(function (attachment) {
      callback(parts.filename, parts.mimeType, attachment);
    });
  }

if (att.length > 0) {
    for (var i in att) {
       getAttachments(response.id, att[i], function (filename, mimeType, attachment) {

       let dataBase64Rep = attachment.data.replace(/-/g, '+').replace(/_/g, '/')

       let urlBlob = b64toBlob(dataBase64Rep, mimeType, attachment.size)

       let dlnk = document.getElementById('download-attach')
       dlnk.href = urlBlob
       dlnk.download = filename
       dlnk.click()
       URL.revokeObjectURL(urlBlob)
   }
}

function b64toBlob (b64Data, contentType, sliceSize) {
  contentType = contentType || ''
  sliceSize = sliceSize || 512

  var byteCharacters = atob(b64Data)
  var byteArrays = []

  for (var offset = 0; offset < byteCharacters.length; offset += sliceSize) {
    var slice = byteCharacters.slice(offset, offset + sliceSize)

    var byteNumbers = new Array(slice.length)
    for (var i = 0; i < slice.length; i++) {
      byteNumbers[i] = slice.charCodeAt(i)
    }

    var byteArray = new Uint8Array(byteNumbers)

    byteArrays.push(byteArray)
  }

  var blob = new Blob(byteArrays, {type: contentType})
  let urlBlob = URL.createObjectURL(blob)
  return urlBlob
}

【讨论】:

    猜你喜欢
    • 2014-11-08
    • 2022-11-11
    • 2018-12-15
    • 2016-03-02
    • 1970-01-01
    • 2022-08-24
    • 2016-03-28
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多