Asp.Net Core Controller에서 SignalR Core Hub 메서드 호출
이 문서에서는 SignalR Core Hub 메서드를 호출하는 방법을 살펴보겠습니다. ASP.NET Core 컨트롤러 내에서. 이 기능을 사용하면 연결된 클라이언트와의 서버 측 통신을 통해 이벤트를 브로드캐스트하거나 실시간 데이터를 업데이트할 수 있습니다.
문제 개요
제공된 시나리오에서 ASP.NET 핵심 애플리케이션은 작업 완료 시 Windows 서비스로부터 요청을 받습니다. 작업은 이 이벤트에 대해 연결된 모든 SignalR Core 클라이언트에 알리는 것입니다. 그러나 Windows 서비스는 SignalR에 대한 연결을 직접 설정할 수 없습니다.
해결 방법 1: HubContext를 컨트롤러에 삽입
한 가지 접근 방식은 적절한 HubContext를 컨트롤러 클래스에 삽입하는 것입니다. . 이를 통해 컨트롤러의 작업 메서드에서 허브 메서드를 직접 호출할 수 있습니다.
[Route("API/vardesigncomm")] public class VarDesignCommController : Controller { [HttpPut("ProcessVarDesignCommResponse/{id}")] public async Task<IActionResult> ProcessVarDesignCommResponse(int id) { await this.HubContext.Clients.All.InvokeAsync("Completed", id); return new JsonResult(true); } private IHubContext<VarDesignHub> HubContext { get; set; } }
이 접근 방식을 사용하면 연결된 모든 클라이언트와 직접 통신할 수 있지만 클라이언트 수에 따라 성능에 영향을 미칠 수 있습니다.
해결책 2: 형식화된 허브 및 클라이언트 인터페이스
또 다른 접근 방식은 형식화된 클라이언트 인터페이스를 정의하고 형식화된 클라이언트 인터페이스를 사용하여 해당 허브에서 상속합니다. 이를 통해 특정 메소드 호출을 위해 유형화된 HubContext를 컨트롤러에 삽입할 수 있습니다.
유형화된 클라이언트 인터페이스:
public interface ITypedHubClient { Task BroadcastMessage(string name, string message); }
유형화된 클라이언트 인터페이스에서 상속되는 허브 :
public class ChatHub : Hub<ITypedHubClient> { public void Send(string name, string message) { Clients.All.BroadcastMessage(name, message); } }
컨트롤러 주입 및 메서드 호출:
[Route("api/demo")] public class DemoController : Controller { IHubContext<ChatHub, ITypedHubClient> _chatHubContext; public DemoController(IHubContext<ChatHub, ITypedHubClient> chatHubContext) { _chatHubContext = chatHubContext; } [HttpGet] public IEnumerable<string> Get() { _chatHubContext.Clients.All.BroadcastMessage("test", "test"); return new string[] { "value1", "value2" }; } }
이 접근 방식을 사용하면 클라이언트와 더욱 대상이 명확하고 효율적으로 커뮤니케이션할 수 있습니다.
위 내용은 ASP.NET Core 컨트롤러에서 SignalR Core Hub 메서드를 호출하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!