所以我一直在关注SignalR和ASP.NET Async的Steven Sanderson的TechDays Talk。我遇到了以下行为的问题
public class SomeController : AsyncController
{
static TaskCompletionSource<String> _nextMessage
= new TaskCompletionSource<string>();
[HttpPost]
public ActionResult PostMessage(string message)
{
_nextMessage = new TaskCompletionSource<string>();
oldNextMessage.SetResult(message);
return Content("success");
}
public async void GetMessages()
{
Response.ContentType = "text/event-stream";
while (true)
{
var message = await _nextMessage.Task;
Response.Write("data: " + message + "\n\n");
Response.Flush();
}
}
}
GetMessages在首次调用时似乎阻塞,但一旦超时,它就会按预期开始工作。
所以我加载了发布和运行GetMessages的javascript。在第一次调用GetMessages时,它会挂起(如预期的那样)
await _nextMessage.Task;
但它不会让我从任何地方(包括浏览器的其他实例)调用PostMessage这是在我的开发机器上,所以它可能是一个线程问题,但我认为这个的全部目的是允许线程处理多个事情。除了第一次超时之后,它开始按预期工作,我可以发布,并立即获得响应。但是,如果我刷新页面,我会遇到同样的问题。有想法该怎么解决这个吗?顺便说一下,我正在使用Eventsource,但是当我进行长轮询时会发生同样的问题,例如。
public async Task<string> GetNextMessage()
{
return await _nextMessage.Task;
}
使用javascript循环函数调用GetNextMessage()
答案 0 :(得分:1)
这是我最后用的东西
[SessionState(SessionStateBehavior.Disabled)]
public class SomeController : AsyncController
{
static TaskCompletionSource<String> _nextMessage =
new TaskCompletionSource<string>();
public void PostMessage(string message)
{
var CreationJObj = FormUtils.AsciiToJObject(Request.Form[0]);
var CreationObj = FormUtils.FromJObject<MessageDisplayVO>(CreationJObj);
Parallel.Invoke(() => { _nextMessage.SetResult(CreationObj.Message); });
_nextMessage = new TaskCompletionSource<string>();
}
public async void GetMessages()
{
Response.ContentType = "text/event-stream";
var oldMessage = _nextMessage;
var message = await oldMessage.Task;
Response.Write("data: " + message + "\n\n");
Response.Flush();
}
}