gpt4 book ai didi

multithreading - asp.net mvc 3应用程序需要写一行,然后等待该行被更新,然后再更新UI

转载 作者:行者123 更新时间:2023-12-03 13:05:10 26 4
gpt4 key购买 nike

我正在研究MVC 3 Web应用程序(.NET Framework 4,IIS7),该应用程序充当基于某些传统技术构建的自定义ID打印机的前端。无需深入探讨细节,单击“打印”时,Web应用程序会将带有卡信息的行写入数据库并返回。然后,后端的服务人员将接起该行并处理卡的实际打印。后端服务完成后,它将使用指示成功或失败的状态列更新该行。

现在,应用程序通过jQuery ajax POST数据,并且一旦将行写入数据库, Controller 就会返回成功并显示给用户。由于我已经描述了设置,因此这可能会或可能不会实际反射(reflect)现实,因为服务或证卡打印机可能会出现问题。

我们有一个新要求,即根据服务对行的更新,使UI“等待”更新成功或失败。它已经通过jquery ajax调用以异步方式在客户端设置,并且我不担心在前端处理它。我已经看过SignalR之类的东西,并且涵盖了这部分。

我正在寻找的是有关如何在Web服务器端正确处理的信息(链接和文章,而不是解决方案)。我不想阻止从早期请求中定期轮询数据库时要打印的传入请求。从高层次上讲,我想知道最好的方法是设置 Controller 和必要的后台进程,这将:

  • 接受请求并将行写入数据库
  • 设置后台轮询过程,然后将控制权返回给ASP.net
  • 如此频繁地轮询数据库,直到更新行(或达到超时)为止
  • 向客户端返回答案

  • 我不是线程专家,但是如果做得不正确,我足够知道我处于危险境地。任何帮助是极大的赞赏。

    最佳答案

    我会发表评论,但是我没有足够的代表。

    为什么将重点放在将服务器推送到UI上?您说表单将行写到数据库中,然后在屏幕上显示“成功”,这可能不是真实状态。在打印过程中的任何时候,您都可以查询数据库并找到最新状态吗?

    有什么阻止您让UI每X秒用最新状态更新页面的一部分吗?让UI提取信息,而不是由服务器将其推出。

    我有一个页面,显示来自数据库的日志记录。每天都有一个过程开始,它将更多的记录写入日志,并且具有自动刷新功能来监视该过程非常有用。
    在该页面上,我有一个Ajax表单,该表单向 Controller 发出请求,该 Controller 在局部 View 中输出一个新表。该局部 View 被放入Ajax表单的UpdateTargetId中。对于自动刷新,我利用javascript setInterval()函数每X秒提交一次Ajax表单。还可以指定其他回调,例如OnSuccess,您可以在其中检查特定的返回条件。

    AjaxOptions class for Ajax.BeginForm

    Example form

    setInterval() from w3schools

    关于multithreading - asp.net mvc 3应用程序需要写一行,然后等待该行被更新,然后再更新UI,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14530301/

    26 4 0
    Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
    广告合作:1813099741@qq.com 6ren.com