以下是一个示例解决方案,用于将S3对象路径传递给AWS Lambda函数进行图像处理。
首先,您需要创建一个Lambda函数,用于处理图像。以下是一个示例的Node.js代码:
const AWS = require('aws-sdk');
const S3 = new AWS.S3();
const Sharp = require('sharp');
exports.handler = async (event, context, callback) => {
try {
// 从事件中获取S3对象路径
const s3ObjectPath = event.Records[0].s3.object.key;
// 从S3下载图像文件到临时目录
const image = await S3.getObject({ Bucket: 'your-bucket-name', Key: s3ObjectPath }).promise();
// 使用Sharp库处理图像(示例:将图像大小调整为200x200)
const processedImage = await Sharp(image.Body)
.resize(200, 200)
.toBuffer();
// 将处理后的图像上传到S3
await S3.putObject({
Bucket: 'your-bucket-name',
Key: `processed/${s3ObjectPath}`, // 修改为您希望保存文件的路径和名称
Body: processedImage,
}).promise();
callback(null, 'Image processed successfully');
} catch (error) {
callback(error);
}
};
接下来,您需要创建一个S3事件触发器,以便在S3对象创建时触发Lambda函数。在AWS控制台的Lambda服务页面上,选择您创建的Lambda函数,然后在函数配置页面的"触发器"部分添加一个S3触发器。配置触发器时,选择您要监视对象创建的S3存储桶和前缀。
当您在S3存储桶中上传新的图像文件时,该文件路径将传递给Lambda函数进行处理。函数将下载图像文件,对其进行处理,然后将处理后的图像上传到S3存储桶中。
请确保您已正确配置AWS SDK和Sharp库,以便在Lambda函数中使用它们。