SignalR отправляет несколько запросов на одно изменение базы данных - PullRequest
0 голосов
/ 03 июня 2019

Я создал простое уведомление, используя SignalR, но сейчас я столкнулся с проблемой.Я не знаю, нормально ли это, так как я впервые использую SignalR в моем проекте.Проблема заключается в том, что при изменении базы данных в Интернете будут отправляться несколько запросов.

Вот мой код:

Global.asax

string connString = ConfigurationManager.ConnectionStrings
    ["spms_notif"].ConnectionString;
    protected void Application_Start()
    {
        AreaRegistration.RegisterAllAreas();
        FilterConfig.RegisterGlobalFilters(GlobalFilters.Filters);
        RouteConfig.RegisterRoutes(RouteTable.Routes);
        BundleConfig.RegisterBundles(BundleTable.Bundles);
        // SQL Dependecy starts here
        SqlDependency.Start(connString);
    }
    protected void Application_End()
    {
        //Stop SQL dependency
        SqlDependency.Stop(connString);
    }

Сигнал R Hub

NotificationHub

 [HubMethodName("sendNotification")]
    public static void SendNotification()
    {
        IHubContext context = GlobalHost.ConnectionManager.GetHubContext<NotificationHub>();
        context.Clients.All.updateNotification();
    }

И мой класс

NotificationRepository

public IEnumerable<NotificationModel> GetAllMessages()
    {
        var notif = new List<NotificationModel>();
        using (var connection = new SqlConnection(_connString))
        {
            connection.Open();
            using (var command = new SqlCommand(@"SELECT id, eid, description, IsRead FROM dbo.spms_tbl_notification WHERE IsRead = 0 and ActionCode = 1 and eid = "+Account.UserInfo.eid+" ORDER BY AlwaysOnTop DESC", connection))
            {
                command.Notification = null;

                var dependency = new SqlDependency(command);
                dependency.OnChange += new OnChangeEventHandler(dependency_OnChange);

                if (connection.State == ConnectionState.Closed)
                    connection.Open();

                var reader = command.ExecuteReader();

                while (reader.Read())
                {
                    NotificationModel value = new NotificationModel();
                    value.id = Convert.ToString(reader.GetValue(0));
                    value.eid = Convert.ToString(reader.GetValue(1));
                    value.description = Convert.ToString(reader.GetValue(2));
                    notif.Add(value);
                }
            }
        }
        return notif;
    }

private void dependency_OnChange(object sender, SqlNotificationEventArgs e)
    {
        if (e.Type == SqlNotificationType.Change)
        {
            NotificationHub.SendNotification();
        }
    }

И на моей стороне клиента

<script>
$(function () {
    // Declare a proxy to reference the hub.
    var notifications = $.connection.notificationHub;

    //debugger;
    // Create a function that the hub can call to broadcast messages.
    notifications.client.updateNotification = function () {
        getAllMessages()

    };
    // Start the connection.
    $.connection.hub.start().done(function () {
        //alert("connection started")
        getAllMessages();
    }).fail(function (e) {
        alert(e);
    });
});

function getAllMessages() {
    var tbl = $('#messagesTable');
    $.ajax({
        url: '@Url.Action("Get", "Notification")',
        contentType: 'application/html ; charset:utf-8',
        type: 'GET',
        dataType: 'json'
    }).success(function (result) {
        $("#notif_body").html("");
        console.log('length: ' + result.length);
        $('.count_notif').html(result.length);
        $.each(result, function (i, v) {
            $("#notif_body").append('<li>' +
                    '<a href="#">' +
                        '' + v.description + '' +
                    '</a>' +
                '</li>');
        });
        console.log("DATA CAPTURED");
    }).error(function () {
        console.log("ERROR CAPTURING DATA");
    });
}

</script>

Таблица, используемая в SqlDependecy

The Table used in SqlDependecy

Несколько запросов

The multiple request

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...