【问题标题】:Azure function: Value cannot be null. Parameter name: sourceAzure 函数:值不能为空。参数名称:来源
【发布时间】:2019-06-12 02:21:30
【问题描述】:

最近,当我调用我的 Azure 函数时,每当我尝试向 AddGroup 函数发出 HTTP 请求时,都会看到此异常。

  • 在我更新了一些 NuGet 包(特别是 Newtonsoft JSON 11.0.2)之前它一直有效
  • 当我在本地运行该函数时它工作正常 - 这与 Azure 有关
  • 我已经多次推送新代码并重新启动该功能
  • 这里的其他问题说这可能是连接字符串问题,但同样,它在我的本地计算机上工作,我没有触及连接字符串
  • 当我尝试附加云调试器时,异常会在我的代码中遇到任何断点之前出现。

有什么想法吗?

Time 11:04:02 AM
Exception type Microsoft.Azure.WebJobs.Host.FunctionInvocationException
Exception message Exception while executing function: AddGroup <--- Value cannot be null. Parameter name: source
Host.Results
Microsoft.Azure.WebJobs.Host.FunctionInvocationException: Exception while executing function: AddGroup ---> System.ArgumentNullException: Value cannot be null.

Parameter name: source

   at Microsoft.Azure.WebJobs.Host.Executors.FunctionExecutor.FunctionInvocationFilterInvoker.<InvokeAsync>d__9.MoveNext()

--- End of stack trace from previous location where exception was thrown ---

   at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)

   at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)

   at Microsoft.Azure.WebJobs.Host.Executors.FunctionExecutor.<InvokeAsync>d__24.MoveNext()

--- End of stack trace from previous location where exception was thrown ---

   at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)

   at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)

   at Microsoft.Azure.WebJobs.Host.Executors.FunctionExecutor.<ExecuteWithWatchersAsync>d__23.MoveNext()

--- End of stack trace from previous location where exception was thrown ---

   at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)

   at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)

   at Microsoft.Azure.WebJobs.Host.Executors.FunctionExecutor.<ExecuteWithLoggingAsync>d__22.MoveNext()

--- End of stack trace from previous location where exception was thrown ---

   at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)

   at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)

   at System.Runtime.CompilerServices.TaskAwaiter.ValidateEnd(Task task)

   at Microsoft.Azure.WebJobs.Host.Executors.FunctionExecutor.<ExecuteWithLoggingAsync>d__16.MoveNext()

   --- End of inner exception stack trace ---

   at System.Runtime.ExceptionServices.ExceptionDispatchInfo.Throw()

   at Microsoft.Azure.WebJobs.Host.Executors.FunctionExecutor.<ExecuteWithLoggingAsync>d__16.MoveNext()

--- End of stack trace from previous location where exception was thrown ---

   at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)

   at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)

   at Microsoft.Azure.WebJobs.Host.Executors.FunctionExecutor.<TryExecuteAsync>d__13.MoveNext()

【问题讨论】:

  • 请提供更多详细信息,例如您的代码和框架等。

标签: c# .net azure-functions azure-webjobs


【解决方案1】:

我想通了——我遇到了 NuGet 包冲突。我的一个项目试图引用版本 Newtonsoft Json 9.0.1(Azure Functions SDK 所依赖的)以及另一个项目想要的 11.0.2。我最终让另一个项目也使用了 9.0.1 版本的包。

【讨论】:

【解决方案2】:

我遇到了同样的问题,对我来说,错误的文本实际上有些相关。我们从 Azure 得到的错误的奇怪部分是函数应用部署在一个订阅上运行良好,但在另一个订阅下给了我们这个“值不能为空”错误。我无法说明订阅之间的差异,但我可以解释我们是如何解决问题的。

我们的 Azure Function App 执行一个 async Task 方法。在这个方法中,我们调用了一个可等待的方法,它返回一个IEnumerable&lt;Thing&gt; 类型的Task,其中Thing 是一个简单的数据模型类。被调用的代码如下所示:

var things = await SomeFactory.LoadXmlRequest&lt;Thing&gt;(xml, auth);

紧接着我们需要检查things 是否包含任何数据,因此我们进行了如下检查:

if (things.Any()) { ... }

我团队中一位勇敢的开发人员建议我们先检查things 是否为空,然后再检查它是否包含任何数据。我们将调用修改为如下所示:

if (things != null &amp;&amp; things.Any()) { ... }

这行得通。我们所要做的就是在调用.Any() LINQ 扩展方法之前检查这个对象是否为空。

【讨论】:

    猜你喜欢
    • 2013-04-23
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2020-08-03
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2015-07-25
    相关资源
    最近更新 更多