繁体   English   中英

Microsoft.Azure.Functions.Worker.Diagnostics.Exceptions.FunctionInputConverterException while processing a blob trigger in Azure Function .net 5

[英]Microsoft.Azure.Functions.Worker.Diagnostics.Exceptions.FunctionInputConverterException while processing a blob trigger in Azure Function .net 5

我有一个用 C#、.Net 5 编写的 Az Function,配置有这样的 blob 触发器:

<PackageReference Include="Microsoft.Azure.Functions.Worker.Extensions.Storage" Version="4.0.4" />
<PackageReference Include="Microsoft.Azure.Functions.Worker.Sdk" Version="1.0.1" OutputItemType="Analyzer" />
<PackageReference Include="Microsoft.Azure.Functions.Worker" Version="1.0.0" />

并且触发器配置为期望 Stream

 [Function("function_name")]
    public static async Task Run([BlobTrigger("datatoingest/{name}", Connection = "STORAGE")] Stream myBlob, string name,
        ILogger logger)

如果我在本地部署它或在本地调试它,一旦它触发并检测到一个新 blob 说明它无法将其转换为类型为“System.ReadOnlyMemory”的“System.IO.Stream”类型,我就会收到以下异常

Result: Failure Exception: Microsoft.Azure.Functions.Worker.Diagnostics.Exceptions.FunctionInputConverterException: Error converting 1 input parameters for Function 'nicos_nyctrips_ingestion': Cannot convert input parameter 'myBlob' to type 'System.IO.Stream' from type 'System .ReadOnlyMemory`1[[System.Byte, System.Private.CoreLib, Version=5.0.0.0, Culture=neutral, PublicKeyToken=7cec85d7bea7798e]]'。 在 Microsoft.Azure.Functions.Worker.Context.Features.DefaultModelBindingFeature.BindFunctionInput(FunctionContext context) 在 D:\a\1\s\src\DotNetWorker.Core\Context\Features\DefaultModelBindingFeature.cs:line 70 at Microsoft.Z3A580F1428203673 .Functions.Worker.Invocation.DefaultFunctionExecutor.ExecuteAsync(FunctionContext context) 在 D:\a\1\s\src\DotNetWorker.Core\Invocation\DefaultFunctionExecutor.cs:Microsoft.Azure.Functions.Worker.OutputBindings.OutputBindingsMiddleware 的第 37 行.Invoke(FunctionContext context, FunctionExecutionDelegate next) in D:\a\1\s\src\DotNetWorker.Core\OutputBindings\OutputBindingsMiddleware.cs:第 13 行 Microsoft.Azure.Functions.Worker.GrpcWorker.InvocationRequestHandlerAsync(InvocationRequest request, IFunctionApplication应用程序,IInvocationFeaturesFactory invocationFeaturesFactory,ObjectSerializer 序列化程序,IOutputBindingsInfoProvider outputBi ndingsInfoProvider) 在 D:\a\1\s\src\DotNetWorker.Grpc\GrpcWorker.cs:line 169 堆栈:在 Microsoft.Azure.Functions.Worker.Context.Features.DefaultModelBindingFeature.BindFunctionInput(FunctionContext context) 在 D:\ a\1\s\src\DotNetWorker.Core\Context\Features\DefaultModelBindingFeature.cs:第 70 行 Microsoft.Azure.Functions.Worker.Invocation.DefaultFunctionExecutor.ExecuteAsync(FunctionContext context) 在 D:\a\1\s\ src\DotNetWorker.Core\Invocation\DefaultFunctionExecutor.cs:第 37 行 Microsoft.Azure.Functions.Worker.OutputBindings.OutputBindingsMiddleware.Invoke(FunctionContext context, FunctionExecutionDelegate next) in D:\a\1\s\src\DotNetWorker.Core \OutputBindings\OutputBindingsMiddleware.cs:第 13 行,位于 Microsoft.Azure.Functions.Worker.GrpcWorker.InvocationRequestHandlerAsync(InvocationRequest 请求,IFunctionsApplication 应用程序,IInvocationFeaturesFactory 调用 D:\a\1\s\src\DotNetWorker.Grpc\GrpcWorker.cs:line 169 中的 onFeaturesFactory、ObjectSerializer 序列化程序、IOutputBindingsInfoProvider outputBindingsInfoProvider)

根据 github 中的 PG 组对这里问题的回答

这是当今工作人员绑定的限制。 我们计划在即将发布的版本中解决这个问题,但目前我无法分享 ETA。

在同一行中,它提到了以下内容:

它可以将 stream 更改为 byte[]。 至少作为一种解决方法。

如果您只是尝试从文本文件中解析 json,则可以将Stream输入替换为string object。

还要注意 ILogger 使用FunctionContext的配置更改。

[Function("function_name")]
public static async Task Run([BlobTrigger("datatoingest/{filename}", Connection = "STORAGE")] string inputBlob, string filename, FunctionContext context)
{
    var logger = context.GetLogger("function_name");
    logger.LogInformation($"C# Blob trigger function Processed blob\n Name: {filename} \n Data: {inputBlob}");
    var request = JsonConvert.DeserializeObject<MyObject>(inputBlob);
    ....
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM