首页 > 解决方案 > 在 AWS Lambda 和 Node.js 12.x 中使用自定义字体

问题描述

我正在尝试创建一个 AWS Lambda 函数来对图像应用水印效果。原始图像将从 S3 中提取,应用水印并将结果上传回 S3。

我正在使用Sharp使用以下代码创建这些组合:

await sharp(inputImage)
              .rotate()
              .composite([{ input: new Buffer.from(watermark), tile: true, gravity: 'northwest' }])

带有自定义水印 SVG

watermark = `<svg ... <text x="50%" y="100%" style="font-family:'Open Sans';font-weight:400;font-size:75px;font-style:normal;fill:rgba(128,128,128,1);stroke:none;" text-anchor="middle">${event.watermarkName}</text></g></svg>`;

在 SVG 内部有一个文本元素,我动态更改它以包含指定的字符串。例如,我可以(c) Company Name在一个图像(c) John Doe上放置另一个图像。

该代码在我的机器上运行时有效,但是一旦在具有 Node.js 12.x 运行时的 Lambda 函数中,这就是结果 文本水印示例

如您所见,我指定Open Sans了要使用的字体。实际上,我将OpenSans-Regular.ttf文件放入/fonts/,创建了一个fonts.conf文件并按照此问题FONTCONFIG_PATH='/var/task/fonts'中的描述设置了一个。

尽管如此,字体仍然无法正常工作。有人对我如何解决这个问题有建议吗?

标签: amazon-web-servicesfontsaws-lambdasharp

解决方案


好吧,询问 Stackoverflow 帮助我自己找到了答案,所以我分享一下,以防将来有人偶然发现这个问题。

AWS Lambda 本身似乎甚至不支持基本字体。因此,您需要将 onw 字体作为文件包含在部署 zip 文件中。

就我而言,这有效:

  • 创建一个/fonts文件夹并在其中放置所有需要的文件(在我的情况下OpenSans-Regular.ttf)。

  • fonts.conf在此文件夹中放置一个名为的文件

    <?xml version="1.0"?>
    <!DOCTYPE fontconfig SYSTEM "fonts.dtd">
    <fontconfig>
       <dir>/var/task/fonts/</dir>
       <cachedir>/tmp/fonts-cache/</cachedir>
       <config></config>
    </fontconfig>
    
  • 通过创建环境变量告诉 Lambda 配置文件在哪里

     FONTCONFIG_PATH='./fonts'
    

瞧!

工作示例


推荐阅读