我正在尝试创建一个由包含 JSON 请求作为负载的 HttpRequest 触发的逻辑应用程序。在此 JSON 内部,一个字段包含文件:
{
"EntityId": "45643",
"SharedGuid": "00000000-0000-0000-0000-000000000000",
"Document": {
"DocumentName": "MyFileName.pdf",
"File": "JVBERi0xLjMKJfv8/f4KMS.....lJUVPRg=="
}}
此"file"内容由客户应用程序使用以下 C# 函数生成:File.ReadAllBytes(“此处为本地路径”)。
我设法将字节数组上传到 blob 存储。但文件一旦上传到 Blob 存储中就无效。
我在 JSON 架构定义中尝试了不同的文件内容:字符串、二进制、应用程序/八位字节流。
任何帮助将不胜感激。
最佳答案
你的httprequest代码中是否做了将字节转换为Base64String的操作,就像下面的代码:
byte[] b = File.ReadAllBytes(@"filepath");
string s = Convert.ToBase64String(b);
根据您提供的文件内容,看来您已将其转换为上面的base64string,因此我提供以下解决方案:
对于此要求,您可以在“解析 JSON”操作中将响应数据解析为字符串(不需要在模式中使用“二进制”),然后在“创建 blob”操作中使用 base64ToBinary() 方法,请引用如下截图:
base64ToBinary(body('Parse_JSON')?['Document']?['File'])
希望对你有帮助~
如果仍有任何问题,请随时告诉我。
关于Azure 逻辑应用程序 - 如何将文件从字节数组上传到 Azure Blob 存储,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60177164/