shgx_tz_mom/ZR.Tasks/TaskScheduler/Job_HttpRequest.cs

45 lines
1.5 KiB
C#
Raw Normal View History

2022-04-03 13:00:30 +08:00
using Infrastructure;
using Infrastructure.Attribute;
using Quartz;
using Quartz.Impl;
using Quartz.Impl.Triggers;
2022-05-10 11:18:12 +08:00
using System;
2022-04-03 13:00:30 +08:00
using System.Threading.Tasks;
using ZR.Service.System.IService;
namespace ZR.Tasks.TaskScheduler
{
2022-05-10 11:18:12 +08:00
/// <summary>
/// 定时任务http请求
/// </summary>
2022-04-03 13:00:30 +08:00
[AppService(ServiceType = typeof(Job_HttpRequest), ServiceLifetime = LifeTime.Scoped)]
internal class Job_HttpRequest : JobBase, IJob
{
private readonly ISysTasksQzService tasksQzService;
private readonly NLog.Logger logger = NLog.LogManager.GetCurrentClassLogger();
2022-04-03 13:00:30 +08:00
public Job_HttpRequest(ISysTasksQzService tasksQzService)
{
this.tasksQzService = tasksQzService;
}
public async Task Execute(IJobExecutionContext context)
{
await ExecuteJob(context, async () => await Run(context));
}
public async Task Run(IJobExecutionContext context)
{
AbstractTrigger trigger = (context as JobExecutionContextImpl).Trigger as AbstractTrigger;
var info = await tasksQzService.GetByIdAsync(trigger.Name);
2022-05-10 11:18:12 +08:00
if (info != null)
{
var result = await HttpHelper.HttpGetAsync("http://" + info.ApiUrl);
logger.Info($"任务【{info.Name}】网络请求执行结果=" + result);
}
else
{
throw new CustomException("任务网络请求执行失败,任务不存在");
2022-05-10 11:18:12 +08:00
}
2022-04-03 13:00:30 +08:00
}
}
}