自动刷新页面调用 web 服务

Posted

技术标签:

【中文标题】自动刷新页面调用 web 服务【英文标题】:Automatically refresh page calling web services 【发布时间】:2019-04-29 16:50:38 【问题描述】:

我是 Angular 新手,当数据库中的数据发生变化时,我有一个关于从 Web 服务检索数据的问题。

我正在处理的系统有 2 个“部分”:一个运行前台(不是 Angular)的 Windows 应用程序和一个在复杂的不同位置的 6 个平板电脑上运行的 Angular 应用程序。该综合体相当小,所有系统都具有良好、持续的网络连接。

前台应用程序(不是 Angular)在主办公室运行。它用于在当前客户“登记”到综合体时使用当前客户的姓名更新 SQL Server 数据库,还用于将客户从综合体中的一个位置“移动”到另一个位置和/或“签出”客户综合体。 此应用程序是 Windows 应用程序,它使用 ADO.NET 和 SQL Server 存储过程直接访问数据库。这是目前无法更改的旧版应用程序。

另一部分是 Angular 6 应用程序,可通过网页从 6 个平板电脑访问。功能是让用户 1) 查看当前客户列表及其在综合体中的位置 2) 将客户从一个位置“移动”到另一个位置 3) 从综合体中“检查”客户。

通过调用 RESTful Web 服务(用 C# 和 .NET Core 编写)来执行特定操作: A) 获取当前客户列表及其位置, B) 将客户“移动”到不同的位置 C)从综合体中“检查”客户 数据存储在 SQL Server 数据库中。 UI 使用各种 PrimeNG 组件(下拉菜单、选项卡和表格)。

通过阅读各种文章、博客和帖子,在我看来,有一种方法可以在服务器上的数据发生更改时触发客户端进行更新,因为主要的“操作方法”示例之一是“聊天”应用程序当有人输入新消息时,它会在应用程序中更新。

我无法确定当客户搬家或退房时如何在平板电脑上进行更新。我考虑过使用计时器或刷新,但如果刷新发生时平板电脑的客户位置正在平板电脑上更新,那么该方法似乎可能会导致问题,如果数据库数据没有被更改,则会导致大量不必要的流量,或者刷新可能不会在正确的时间发生以显示客户更改(刷新可能发生在更新之前,但随后更新发生在下一次数据库更新之前)。

现在我有一个“刷新”按钮,它调用网络服务来获取客户和位置,但这需要用户手动激活它,他们可能不记得这样做,因此数据不正确。

任何指针将不胜感激。

Angular 6 应用程序的结构如下: 1. 客户信息(姓名、日期、时间)和位置的单独接口 2. 为特定操作调用 Web 服务的“数据”服务 3. 一个“本地”服务,包含调用“数据”服务的逻辑,操作从“数据”服务调用返回的数据 4. 处理 UI 事件、显示错误消息和 toast 消息的“主”组件 5. 作为 UI 的 html 页面

main.component.ts:

this.localService.GetCustomers().subscribe(p => this.people = p);

local.service.ts

GetCustomers()
    this.customers = this.dataService.GetCustomers();

data.service.ts

   GetCustomers()
       return this.httpClient.get<ICustomer[]>(this.urlBase + this.urlGetCustomers);
    

【问题讨论】:

【参考方案1】:

您可以像这样使用 setInterval 调用每个间隔的 API

this.interval = setInterval(() => 
        this.localService.GetCustomers().subscribe(p => this.people = p);
 , 5000); // 5 second is interval to refresh page

但是你这样调用API不是很好的解决方案,如果并发用户增加,它和拒绝服务一样。

如果你的后端是Java,我建议你改成web socket来实现服务。实时请求的性能更好。

包https://www.npmjs.com/package/websocket

如果你的后端是 ASP.NET Web API,你可以使用 SignalR Package https://www.npmjs.com/package/@aspnet/signalr

我们在Web APISignalR之间测试过这种情况,如果你使用WebAPI,浏览器的CPU和内存增长很快,我们选择SignalR作为解决方案。

如果您的后端并不总是发生变化,您可以在后端使用cached 以获得更好的网络服务器性能。

如果你使用 SQL Server,你可以使用 SQL Dependency 来通知来自 SQL 的最新更新(添加新客户、更新或删除客户) 关于使用SQL DependencySignalR的参考

https://techbrij.com/database-change-notifications-asp-net-signalr-sqldependency

【讨论】:

谢谢。 SignalR 看起来很有希望。由于一些限制和要求,我不太确定 SQL 依赖关系。我现在正在查看网络套接字或 SignalR。【参考方案2】:

您可以每 X 秒进行一次轮询,并在每次请求时更新您的数据。或者您可以使用网络套接字。 第一种方法,参考这个答案https://***.com/a/42920844/7179294 另请查看此答案以获取更多详细信息https://***.com/a/54629027/7179294

【讨论】:

谢谢。出于几个原因,我真的想避免使用轮询选项。 我给你的第二个答案包含其他方法,它们显然比轮询要困难一些,但是检查它们, 唉,由于某种原因,我关于查看网络套接字或 SignalR 的评论的剩余部分被遗漏了【参考方案3】:

我们可以将数据从服务器推送到浏览器,通常使用 websocket。在这种情况下,数据源和数据接收者需要与同一个 websocket 服务器进行通信,它的工作方式类似于发布-订阅模式。如果您无法修改您的前台应用程序,您的问题更多是关于如何触发数据更改事件。 SQL Server 本身无法做到这一点,我看到有一些关于如何在 SQL Server 中观察数据变化的讨论,但我没有经验。我认为您需要一个组件来观察数据变化并将数据发送到服务器端的 websocket 服务器。如果您无法做到这一点,似乎从浏览器轮询以提取数据将是您唯一的选择。

【讨论】:

谢谢。在这一点上,我倾向于网络套接字或 SignalR。即使使用 SQL Broker 和 SQL Dependency,整个 SQL Server 更改通知似乎也是最大的障碍。我可能会考虑尝试使用触发器来实现 SQL Server 通知

以上是关于自动刷新页面调用 web 服务的主要内容,如果未能解决你的问题,请参考以下文章

ajax+jsp自动刷新

javascript页面自动刷新,然后调用函数

web发布新版本,前端页面如何自动刷新

使用 AJAX 自动刷新在 Web 应用程序上超时会话的方法

Servlet自动刷新页面

WEB页面自动刷新的实现