我有一个应用程序,其中有一些 Controller 的操作调用缓慢的第 3 方 Web 服务。这些操作是使用页面中的 AJAX 调用来调用的。
我可以使用异步 Controller 来释放 ASP.NET 线程池,这很棒。但是 session 呢?如果我使用 InProc session 并发出“慢速操作”请求,则特定用户无法向应用程序发出任何请求,因为他的 session 被第一个“慢速”调用锁定。
在 PHP 中有一个方法 session_write_close()
我可以使用如下:
- 接受用户的慢动作请求
- 根据 session 数据检查用户访问 Controller /操作的权限
- 如果需要,向 session 写入一些内容
- 调用
session_write_close()
。 从此请求关闭 session ,来自同一用户的任何其他请求都可以访问它 - 进行慢速调用(可能以某种异步方式)
我知道我可以使用 [SessionState]
属性在 Controller 级别禁用 session 状态,但这不是解决方案。
有什么想法吗?
最佳答案
我认为这可能有几种情况。
1) 在 Controller 工厂中进行更改,并将其更改为生成没有 session 或使用某些自定义 session 实现的 Controller
关于ASP.NET MVC : how to prevent a session lock?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12265490/