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

本文分析了在访问网站时遇到的 ASP.NET WebAPI 异步任务取消引发 AggregateException 的原因及解决策略。重点讨论了 AJAX 请求与页面刷新之间的相互作用,以及如何避免此类异常情况。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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 时,直接忽略。

隐藏调用堆栈 在 System.Runtime.ExceptionServices.ExceptionDispatchInfo.Throw() 在 System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task) 在 Microsoft.VisualStudio.Threading.TplExtensions.d__5.MoveNext() --- 引发异常的上一位置中堆栈跟踪的末尾 --- 在 System.Runtime.ExceptionServices.ExceptionDispatchInfo.Throw() 在 System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task) 在 Microsoft.DotNet.DesignTools.Client.Host.ServerProcess.d__29.MoveNext() --- 引发异常的上一位置中堆栈跟踪的末尾 --- 在 System.Runtime.ExceptionServices.ExceptionDispatchInfo.Throw() 在 System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task) 在 Microsoft.DotNet.DesignTools.Client.Host.ServerHostFactory.d__9.MoveNext() --- 引发异常的上一位置中堆栈跟踪的末尾 --- 在 System.Runtime.ExceptionServices.ExceptionDispatchInfo.Throw() 在 System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task) 在 Microsoft.DotNet.DesignTools.Client.DesignToolsClientLoader.d__29.MoveNext() --- 引发异常的上一位置中堆栈跟踪的末尾 --- 在 System.Runtime.ExceptionServices.ExceptionDispatchInfo.Throw() 在 System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task) 在 Microsoft.DotNet.DesignTools.Client.DesignToolsClientLoader.<>c__DisplayClass25_1.<<-ctor>b__1>d.MoveNext() --- 引发异常的上一位置中堆栈跟踪的末尾 --- 在 System.Runtime.ExceptionServices.ExceptionDispatchInfo.Throw() 在 System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task) 在 Microsoft.DotNet.DesignTools.Client.DesignToolsClientLoader.d__27.MoveNext() 怎么解决
03-13
using CommunityToolkit.Mvvm.ComponentModel; using Liudin.Acs; using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; using System.Windows.Media; namespace Liudin.App.ViewModels.bar { public partial class InfoBarViewModel : BaseViewModel { private readonly Singleton config; public InfoBarViewModel(Singleton _config) { config = _config; config._InfoBarContext = SynchronizationContext.Current ?? new SynchronizationContext(); ShowInfo(); } [ObservableProperty] private string infoText = "机器没有上电,请打开电源开关"; [ObservableProperty] private Brush? fontColor = new SolidColorBrush((Color)ColorConverter.ConvertFromString("#006400")); /// <summary> /// 设置字体颜色 0-正常 1-警告 2-错误 /// </summary> /// <param name="lev"></param> private void SetMsgColor(int lev) { switch (lev) { case 0: FontColor = new SolidColorBrush((Color)ColorConverter.ConvertFromString("#006400")); break; case 1: FontColor = Brushes.Orange; break; case 2: FontColor = Brushes.Red; break; } } private void ShowInfo() { try { Task.Run(async () => { while (true) { config._InfoBarContext.Post(_ => { InitInfo(); }, null); await Task.Delay(200); } }); } catch (TaskCanceledException) { /* 处理取消 */ } } private void InitInfo() { string msg = ""; if (JSGS.bPowerOn) { SetMsgColor(2); msg = "机器没有上电,请打开电源开关"; } else if (JSGS.bEStop) { SetMsgColor(2); msg = "急停开关已打开,处理好,关闭急停开关"; } else if (App.Current.m_bBgnHome) { SetMsgColor(1); msg = "机器启动,请回零"; } else if (JSGS.bToHome) { SetMsgColor(1); msg = "急停开关已关闭,请回零"; } else if (JSGS.bAlarm) { SetMsgColor(2); msg = "机器报警,请停止检查"; } else if (JSGS.bHoming) { SetMsgColor(1); msg = "机器正在回零..."; } else if (JLimit(ref msg)) { SetMsgColor(1); } else if (JSGS.bRunning) { SetMsgColor(0); msg = "系统正在自动运行中..."; } else { SetMsgColor(0); msg = "系统准备就绪,等待中..."; } } } }退出软件时,ShowInfo中的While怎么销毁
04-03
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值