Azure Logic App-如何从字节数组将文件上传到Azure Blob存储

问题描述 投票:0回答:1

我正在尝试创建由HttpRequest触发的逻辑应用,该HttpApp包含JSON请求作为有效载荷。在此JSON的内部,一个字段包含文件:

{
"EntityId": "45643",
"SharedGuid": "00000000-0000-0000-0000-000000000000",
"Document": {
    "DocumentName": "MyFileName.pdf",
    "File": "JVBERi0xLjMKJfv8/f4KMS.....lJUVPRg=="
}}

此“文件”内容是由客户应用程序使用以下C#函数生成的:File.ReadAllBytes(“本地路径在此处”)。

我设法将字节数组上传到Blob存储。但是,一旦将文件上传到Blob存储中,该文件便无效。

我尝试了JSON模式定义中文件的其他文件内容,例如:字符串,二进制,应用程序/八位位组流。

This is how my Logic App looks now

任何帮助将不胜感激。

azure stream azure-storage-blobs azure-logic-apps azure-blob-storage
1个回答
0
投票

您是否执行了将字节转换为httprequest代码中的Base64String的操作,就像下面的代码一样:

byte[] b = File.ReadAllBytes(@"filepath");
string s = Convert.ToBase64String(b);

根据您提供的文件内容,似乎您已如上所述将其转换为base64string,所以我在下面提供了解决方案:

为此要求,您可以在“解析JSON”操作中将响应数据解析为字符串(不需要在架构中使用“二进制”),然后在“创建blob”操作中使用base64ToBinary()方法,请请参阅如下所示的屏幕截图:

enter image description here“ Blob内容”中的表达式为:

base64ToBinary(body('Parse_JSON')?['Document']?['File'])

希望有帮助〜

如果仍有问题,请随时告诉我。

© www.soinside.com 2019 - 2024. All rights reserved.