【问题标题】:ServiceBusTrigger with enqueueTimeUtc argument fails when triggered via HTTP endpoint通过 HTTP 端点触发时,带有 enqueueTimeUtc 参数的 ServiceBusTrigger 失败
【发布时间】:2026-02-04 03:05:01
【问题描述】:

我正在使用 Visual Studio 2017 在本地 Azure Functions v1 中开发服务总线触发器。我想测试官方文档中的 example,而不必在服务总线中添加消息。所以我通过 Postman 在端点 POST http://localhost:7071/admin/functions/ServiceBusQueueTriggerCSharp 和正文 { "input": "foo" } 触发它。

这会失败并出现脚本主机错误:执行函数时出现异常:ServiceBusQueueTriggerCSharp。 Microsoft.Azure.WebJobs.Host:出现一个或多个错误。异常绑定参数“deliveryCount”。 Microsoft.Azure.WebJobs.Host:绑定数据不包含预期值“deliveryCount”。

我尝试删除 deliveryCount 参数,但在 enqueueTimeUtc 处失败。删除它也有效。有没有办法保留这些参数并在本地测试函数?

我知道这两个参数在通过 HTTP 触发时没有多大意义,但它们可以被赋予默认值。 messageId 有一个非零值。

参考示例:

[FunctionName("ServiceBusQueueTriggerCSharp")]                    
public static void Run(
    [ServiceBusTrigger("myqueue", AccessRights.Manage, Connection = "ServiceBusConnection")] 
    string myQueueItem,
    Int32 deliveryCount,       // this fails
    DateTime enqueuedTimeUtc,  // this fails too
    string messageId,
    TraceWriter log)
{
    log.Info($"C# ServiceBus queue trigger function processed message: {myQueueItem}");
    log.Info($"EnqueuedTimeUtc={enqueuedTimeUtc}");
    log.Info($"DeliveryCount={deliveryCount}");
    log.Info($"MessageId={messageId}");
}

【问题讨论】:

    标签: azure azure-functions


    【解决方案1】:

    到目前为止,如果您希望能够使用这些额外的元数据属性,则需要使用真实的服务总线消息。

    理论上,管理端点可以足够智能,允许您将额外的绑定数据(如本例中的 deliveryCount)作为查询参数传递。我提交了以下功能请求以进行跟踪: https://github.com/Azure/azure-functions-host/issues/2955

    【讨论】:

    • 感谢 Paul 打开功能请求。
    最近更新 更多