Google Script CacheService 在 sendMail 中为 inlineImages 缓存图像

Fab*_*ian 3 sendmail google-apps-script

我想将图像存储在 Google Script 的缓存服务中,然后将此图像作为内嵌图像插入 HTML 邮件中。

我已经尝试让它发挥作用,但到目前为止还没有成功。记录器中以下代码的错误是“无效参数:附件”。如果我检查它显示 sendMail() 中的 var 图标是一个 blob:

function onOpen(e){
  var icon = DriveApp.getFileById('ID').getBlob().setName('icon');
  var cache = CacheService.getDocumentCache().put('icon', icon);
  }

function sendMail() {

  var icon = CacheService.getDocumentCache().get('icon');

  var email = 'test@example.de';
  var subject = 'test';
  var txt = 'test';
  var html = '<img src="cid:icon"/>';

   MailApp.sendEmail(email, subject, txt, {htmlBody: html, name : 'test', inlineImages:{icon:icon}});

}
Run Code Online (Sandbox Code Playgroud)

令人惊讶的是,如果我这样做:

 function sendMail() {

      var icon = DriveApp.getFileById('ID').getBlob().setName('icon');

      var email = 'test@example.de';
      var subject = 'test';
      var txt = 'test';
      var html = '<img src="cid:icon"/>';

       MailApp.sendEmail(email, subject, txt, {htmlBody: html, name : 'test', inlineImages:{icon:icon}});

    }
Run Code Online (Sandbox Code Playgroud)

效果很好。我的代码有什么问题?

Evg*_*tok 5

Google缓存服务仅接受字符串值,而您尝试将一个明显不同类型的 blob 推入其中。一旦你把它变成合适的字符串 - 那就没问题了。

为了确保我们正确保存它,我们应该使用base64encode。

尝试更换

var cache = CacheService.getDocumentCache().put('icon', icon);
Run Code Online (Sandbox Code Playgroud)

var cache = CacheService.getDocumentCache()
cache.put('icon', Utilities.base64Encode(icon.getBytes()));
Run Code Online (Sandbox Code Playgroud)

分别地,当您获取缓存值时,您将需要从我们的字符串创建一个新的 blob 对象。

首先我们创建空 blob 并读取缓存值:

var iconBlob = Utilities.newBlob("")
var cachedValue = cache.get('icon');
Run Code Online (Sandbox Code Playgroud)

然后你可以像这样使用它:

iconBlob.setBytes(Utilities.base64Decode(cachedValue ))
iconBlob.setName('yourname')
iconBlob.setContentType('image/png')
Run Code Online (Sandbox Code Playgroud)

您可以在参考中检查这两种方法。如果将对象字符串化,您还可以以相同的方式将对象保存在缓存服务中。