Azure Function SignalR |协商功能|出现500错误代码失败

时间:2019-04-09 05:29:04

标签: c# azure azure-functions negotiate azure-signalr

我已经使用extensions.csproj安装了Microsoft.Azure.WebJobs.Extensions.SignalRService。

<Project Sdk="Microsoft.NET.Sdk">
  <PropertyGroup>
    <TargetFramework>netstandard2.0</TargetFramework>
    <WarningsAsErrors />
  </PropertyGroup>
  <ItemGroup>
    <PackageReference Include="Microsoft.Azure.WebJobs.Extensions.CosmosDB" Version="3.0.1" />
    <PackageReference Include="Microsoft.Azure.WebJobs.Script.ExtensionsMetadataGenerator" Version="1.0.*" />
    <PackageReference Include="Microsoft.Azure.WebJobs.Extensions.SignalRService" Version="1.0.0" />
  </ItemGroup>
</Project>

我能够使用以下Azure功能通过Azure SignalR服务发布消息。当CosmosDB Collections上执行任何AddOrUpdate()操作时,就会触发该函数,并且它将在集线器中以名称“ fruitUpdated”发送信号。

#r "Microsoft.Azure.DocumentDB.Core"
#r "Microsoft.Azure.WebJobs.Extensions.SignalRService"
using System;
using System.Collections.Generic;
using System.Collections.ObjectModel;
using Microsoft.Azure.Documents;
using Microsoft.Azure.WebJobs.Extensions.SignalRService;

public static void Run(IReadOnlyList<Document> input, ILogger log, ICollector<SignalRMessage> signalRMessages)
{
    if (input != null && input.Count > 0)
    {
        log.LogInformation("Documents modified " + input.Count);
        foreach (var fruit in input)
        {
            signalRMessages.Add( 
                new SignalRMessage 
                {
                    Target = "fruitUpdated",
                    Arguments = new [] { fruit } 
                });
        }
    }
}

但是协商功能现在似乎不起作用。它抛出500错误代码而没有任何线索。以下是示例,

run.csx

#r "Newtonsoft.Json"

using System;
using System.Net;
using Microsoft.AspNetCore.Mvc;
using Microsoft.Extensions.Primitives;
using Newtonsoft.Json;

public static IActionResult Run(HttpRequest req, ILogger log, object connectionInfo)
{
    return (ActionResult)new OkObjectResult(connectionInfo);
}

function.json

{
  "bindings": [
    {
      "authLevel": "anonymous",
      "name": "req",
      "type": "httpTrigger",
      "direction": "in",
      "methods": [
        "get",
        "post"
      ]
    },
    {
      "type": "signalRConnectionInfo",
      "name": "connectionInfo",
      "hubName": "flights",
      "direction": "in",
      "connectionStringSetting": "AzureSignalRConnectionString"
    }
  ]
}

我尝试了所有组合。 在某些情况下,Azure文档令人厌烦!没有输入\输出模式应该被皱眉了。 Azure产品团队应认真对待

SignalR版本彼此不兼容。如果我们在服务器和客户端中使用不同版本的SignalR dll,它们只是被动地消除消息而不会引发错误。

我认为我需要connectionInfo对象的JSON有效负载。你能在这里帮助我吗?

1 个答案:

答案 0 :(得分:0)

我在Serverless360找到了答案。原来是类型问题和方法参数修饰。引用SignalService库和装饰器后,它开始工作。我认为object是基本类型,应该已经收到或已注入connectionInfo。

#r "Newtonsoft.Json"
#r "Microsoft.Azure.WebJobs.Extensions.SignalRService"

using System;
using System.Net;
using Microsoft.AspNetCore.Mvc;
using Microsoft.Extensions.Primitives;
using Newtonsoft.Json;
using Microsoft.Azure.WebJobs.Extensions.SignalRService;

public static IActionResult Run(HttpRequest req, ILogger log, [SignalRConnectionInfo(HubName = "flights")]SignalRConnectionInfo connectionInfo)
{
    return (ActionResult)new OkObjectResult(connectionInfo);
}

现在,协商功能正在按预期方式工作。 希望它对有类似问题的人有所帮助!

用于协商功能的示例输出有效负载

{"url":"https://myazuresignalrservice.service.signalr.net/client/?hub=myhubname","accessToken":"mybeareraccesstoken"}

更新

问题与方法签名中的*[SignalRConnectionInfo(HubName = "fruits")]SignalRConnectionInfo*一起使用,而不是使用。

public static IActionResult Run(HttpRequest req, ILogger log, [SignalRConnectionInfo(HubName = "fruits")]SignalRConnectionInfo connectionInfo) { }

还发布了预期的有效负载,以供您参考。如有任何疑问,请在评论中告知您。