如何使用Spring Integration将“资产”POJO传递给S3MessageHandler并更改存储桶?
我希望能够根据资产中的文件夹将存储桶更改为“root-bucket / a / b / c”。
每个资产都可能具有不同的子路径。
@Bean
IntegrationFlow flowUploadAssetToS3()
{
return flow -> flow
.channel(this.channelUploadAsset)
.channel(c -> c.queue(10))
.publishSubscribeChannel(c -> c
.subscribe(s -> s
// Publish the asset?
.<File>handle((p, h) -> this.publishS3Asset(
p,
(Asset)h.get("asset")))
// Set the action
.enrichHeaders(e -> e
.header("s3Command", Command.UPLOAD.name()))
// Upload the file
.handle(this.s3MessageHandler())));
}
MessageHandler s3MessageHandler()
{
return new S3MessageHandler(amazonS3, "root-bucket");
}
感谢下面的回答,我的工作原理如下:
final String bucket = "'my-root";
final Expression bucketExpression = PARSER.parseExpression(bucket);
final Expression keyExpression = PARSER.parseExpression("headers['asset'].bucket");
final S3MessageHandler handler = new S3MessageHandler(amazonS3, bucketExpression);
handler.setKeyExpression(keyExpression);
return handler;
答案 0 :(得分:0)
有- 1
选项是SpEL,可以解析bucketExpression
中的存储分区:
requestMessage
另请注意, private static SpelExpressionParser PARSER = new SpelExpressionParser();
MessageHandler s3MessageHandler() {
Expression bucketExpression =
PARSER.parseExpression("payload.bucketProperty");
return new S3MessageHandler(amazonS3, bucketExpression);
}
不是存储桶名称。您应该考虑区分bucket和root-bucket/a/b/c.
来构建那个复杂的子文件夹路径。为此目的,key
选项具有类似功能,可以针对keyExpression
解决存储桶中的密钥。