Viv*_*vek 15 .net c# asp.net-web-api owin
我正在运行一个基于Owin Selfhost的WebApi,我在其中输入了一个API未处理的异常记录器
config.Services.Add(typeof(IExceptionLogger), _apiExceptionLogger);
Run Code Online (Sandbox Code Playgroud)
ApiExceptionLogger的相关部分:
public override void Log(ExceptionLoggerContext context)
{
if (context == null || context.ExceptionContext == null) return;
Logger.Error("Unhandled exception from Web API", context.ExceptionContext.Exception);
}
Run Code Online (Sandbox Code Playgroud)
它定期捕获和记录的情况是客户端请求数据集然后在发送结果(JSON)时关闭连接的人 - 用chrome发出请求,然后在所有结果返回之前点击X按钮: P
我已经粘贴了下面的堆栈跟踪以获得完整性,只想知道两件事:
我没有深入研究套接字级别发生的事件序列,到目前为止,这只是一个日志记录的麻烦.
System.Net.Http.HttpRequestException: Error while copying content to a stream. ---> System.IO.IOException ---> System.Net.HttpListenerException: The I/O operation has been aborted because of either a thread exit or an application request
at System.Net.HttpResponseStream.EndWrite(IAsyncResult asyncResult)
at Microsoft.Owin.Host.HttpListener.RequestProcessing.ExceptionFilterStream.EndWrite(IAsyncResult asyncResult)
--- End of inner exception stack trace ---
at Microsoft.Owin.Host.HttpListener.RequestProcessing.ExceptionFilterStream.EndWrite(IAsyncResult asyncResult)
at System.Threading.Tasks.TaskFactory`1.FromAsyncCoreLogic(IAsyncResult iar, Func`2 endFunction, Action`1 endAction, Task`1 promise, Boolean requiresSynchronization)
--- End of inner exception stack trace ---
at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)
at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)
at System.Web.Http.Owin.HttpMessageHandlerAdapter.<SendResponseContentAsync>d__20.MoveNext() at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)
at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)
at System.Web.Http.Owin.HttpMessageHandlerAdapter.<SendResponseContentAsync>d__20.MoveNext()
Run Code Online (Sandbox Code Playgroud)