ASP.NET SignalR HubPipelineModule
8597 단어 pipeline
다음 방법은 IHubPipelineModule에서 솔리드로 정의하는 것입니다.
public interface IHubPipelineModule
{
Func<IHubIncomingInvokerContext, Task<object>> BuildIncoming(Func<IHubIncomingInvokerContext, Task<object>> invoke);
Func<IHubOutgoingInvokerContext, Task> BuildOutgoing(Func<IHubOutgoingInvokerContext, Task> send);
Func<IHub, Task> BuildConnect(Func<IHub, Task> connect);
Func<IHub, Task> BuildReconnect(Func<IHub, Task> reconnect);
Func<IHub, Task> BuildDisconnect(Func<IHub, Task> disconnect);
Func<HubDescriptor, IRequest, bool> BuildAuthorizeConnect(Func<HubDescriptor, IRequest, bool> authorizeConnect);
Func<HubDescriptor, IRequest, IList<string>, IList<string>> BuildRejoiningGroups(Func<HubDescriptor, IRequest, IList<string>, IList<string>> rejoiningGroups);
}
.csharpcode, .csharpcode pre
{
font-size: small;
color: black;
font-family: consolas, "Courier New", courier, monospace;
background-color: #ffffff;
/*white-space: pre;*/
}
.csharpcode pre { margin: 0em; }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000ff; }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
{
background-color: #f4f4f4;
width: 100%;
margin: 0em;
}
.csharpcode .lnum { color: #606060; }
너무 복잡한 부탁이 있는 것 같지 않아요?서두를 필요 없어요.HubPipelineModule류는 이미 우리를 위해 대부분의 기능을 실현했고 대부분 상황에서 충분히 사용할 수 있어요. 이 천둥이 안에 있는 방법을 계승하면 돼요.
public abstract class HubPipelineModule : IHubPipelineModule
{
protected virtual bool OnBeforeAuthorizeConnect(HubDescriptor hubDescriptor, IRequest request);
protected virtual bool OnBeforeConnect(IHub hub);
protected virtual void OnAfterConnect(IHub hub);
protected virtual bool OnBeforeReconnect(IHub hub);
protected virtual void OnAfterReconnect(IHub hub);
protected virtual bool OnBeforeOutgoing(IHubOutgoingInvokerContext context);
protected virtual void OnAfterOutgoing(IHubOutgoingInvokerContext context);
protected virtual bool OnBeforeDisconnect(IHub hub);
protected virtual void OnAfterDisconnect(IHub hub);
protected virtual bool OnBeforeIncoming(IHubIncomingInvokerContext context);
protected virtual object OnAfterIncoming(object result, IHubIncomingInvokerContext context);
protected virtual void OnIncomingError(Exception ex, IHubIncomingInvokerContext context);
}
.csharpcode, .csharpcode pre
{
font-size: small;
color: black;
font-family: consolas, "Courier New", courier, monospace;
background-color: #ffffff;
/*white-space: pre;*/
}
.csharpcode pre { margin: 0em; }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000ff; }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
{
background-color: #f4f4f4;
width: 100%;
margin: 0em;
}
.csharpcode .lnum { color: #606060; }
이 코드는 ASP와 맞지 않습니까?NET 웹 API 및 ASP.NET MVC의 ActionFilter가 비슷하네요.여기서 OnBefore라고 하는 메서드가 false로 돌아가면 즉시 종료됩니다.
public class AntiClickModule : HubPipelineModule
{
public AntiClickModule()
{
Interval = 1000;
}
public int Interval { get; set; }
private readonly ConcurrentDictionary<string, DateTime> _connections = new ConcurrentDictionary<string, DateTime>();
protected override void OnAfterDisconnect(IHub hub)
{
DateTime lastDateTime;
_connections.TryRemove(hub.Context.ConnectionId, out lastDateTime);
}
protected override bool OnBeforeIncoming(IHubIncomingInvokerContext context)
{
var now = DateTime.Now;
var connectionId = context.Hub.Context.ConnectionId;
DateTime lastDateTime;
if (_connections.TryGetValue(connectionId, out lastDateTime))
{
var span = now - lastDateTime;
if (span.TotalMilliseconds < Interval)
{
return false;
}
}
_connections.AddOrUpdate(connectionId, now, (_, __) => now);
return true;
}
}
각 ID에 연결할 때 요청한 시간을 기록하고 다음 요청의 간격을 간단히 확인합니다.만약 두 요청 사이의 시간 차이가 우리가 설정한 시간 간격보다 적으면 바로 되돌아옵니다.
GlobalHost를 사용하는 모듈 Global에 추가할 수 있습니다.asax.cs
protected void Application_Start(object sender, EventArgs e)
{
GlobalHost.HubPipeline.AddModule(new AntiClickModule());
}
.csharpcode, .csharpcode pre
{
font-size: small;
color: black;
font-family: consolas, "Courier New", courier, monospace;
background-color: #ffffff;
/*white-space: pre;*/
}
.csharpcode pre { margin: 0em; }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000ff; }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
{
background-color: #f4f4f4;
width: 100%;
margin: 0em;
}
.csharpcode .lnum { color: #606060; }
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
Linux 패키지 관리를 위한 GitLab CD 파이프라인모두 좋은 하루! 모두 잘 지내고 계시길 바랍니다. 최근 프로젝트를 통해 GitLab, Ansible, Docker 및 Shell 스크립트와 같은 기술을 사용할 수 있었습니다. GitLab 파이프라인을 사용하여 여러...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.