System.Threading.Tasks.TaskCanceledException: 已取消一个任务

本文分析了在访问网站时遇到的 ASP.NET WebAPI 异步任务取消引发 AggregateException 的原因及解决策略。重点讨论了 AJAX 请求与页面刷新之间的相互作用,以及如何避免此类异常情况。
摘要由CSDN通过智能技术生成
Exception: System.AggregateException: 发生一个或多个错误。 ---> System.Threading.Tasks.TaskCanceledException: 已取消一个任务。
System.Web.Http.Dispatcher.HttpRoutingDispatcher.SendAsync(System.Net.Http.HttpRequestMessage request, 
System.Threading.CancellationToken cancellationToken) > 
System.Net.Http.HttpMessageInvoker.SendAsync(System.Net.Http.HttpRequestMessage request, System.Threading.CancellationToken cancellationToken) > 
System.Web.Http.Dispatcher.HttpControllerDispatcher.SendAsync(System.Net.Http.HttpRequestMessage request, 
System.Threading.CancellationToken cancellationToken) > System.Runtime.CompilerServices.AsyncMethodBuilderCore.Start() > 
System.Web.Http.Dispatcher.HttpControllerDispatcher+<SendAsync>d__1.MoveNext() > 
System.Web.Http.Controllers.ActionFilterResult.ExecuteAsync() > 
System.Runtime.CompilerServices.AsyncMethodBuilderCore.Start() > 
System.Web.Http.Controllers.ActionFilterResult+<ExecuteAsync>d__2.MoveNext() > 
System.Web.Http.Controllers.ApiControllerActionInvoker.InvokeActionAsyncCore(System.Web.Http.Controllers.HttpActionContext actionContext, 
System.Threading.CancellationToken cancellationToken) > System.Runtime.CompilerServices.AsyncMethodBuilderCore.Start() > 
System.Web.Http.Controllers.ApiControllerActionInvoker+<InvokeActionAsyncCore>d__0.MoveNext() > 
System.Web.Http.Controllers.ReflectedHttpActionDescriptor.ExecuteAsync(System.Web.Http.Controllers.HttpControllerContext controllerContext, 
System.Collections.Generic.IDictionary`2[System.String,System.Object] arguments, System.Threading.CancellationToken cancellationToken) > 
System.Web.Http.Controllers.ReflectedHttpActionDescriptor+ActionExecutor+<>c__DisplayClass12.<GetExecutor>b__8(System.Object instance, System.Object[] methodParameters) > 
?.lambda_method(System.Runtime.CompilerServices.Closure , System.Object , System.Object[] ) > 


今天查看网站日志时,发现不少这种错误信息。

访问一个页面时,AJAX 请求 ASP.NET Web API 。多次点击刷新,出错。

原因:页面加载  =》 ajax 触发 web api =》  页面刷新 =》web api 的任务被取消 ;   web api 是异步编程, 任务取消时,会触发  AggregateException 导常。

日志记录时,遇到 AggregateException 时,直接忽略。

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值