当前位置:   article > 正文

ASP.NET Core MVC+Quartz实现定时任务可视化管理页面_quartz.net winform界面

quartz.net winform界面

在前一篇文章,我们了解了如何通过.NET6+Quartz开发基于控制台应用程序的定时任务,今天继续在之前的基础上,进一步讲解基于ASP.NET Core MVC+Quartz实现定时任务的可视化管理页面,仅供学习分享使用,如有不足之处,还请指正。

涉及知识点

  1. Quartz组件,关于Quartz组件的基本介绍,可参考前一篇文章或官网。
  2. GZY.Quartz.MUI,基于Quartz的定时任务维护UI,具有新增,删除,启动,停止等功能,之处DLL和WebAPI接口调用两种模式。

创建ASP.NET Core MVC项目

在Visual Studio 2022中,首先创建基于ASP.NET Core MVC 的项目,根据步骤进行创建即可,如下所示:

安装组件

项目创建成功后,通过NuGet包管理器,安装对应组件,本示例仅演示Quartz相关内容,所以只需要安装相关组件即可,如下所示:

组件注入

组件安装后,需要在Progrom.cs中进行注入,才可以在启动时加载对应内容。如下所示:

  1. using GZY.Quartz.MUI.Extensions;
  2. using QuartzAdmin.QuartzA;
  3. var builder = WebApplication.CreateBuilder(args);
  4. // Add services to the container.
  5. builder.Services.AddControllersWithViews();
  6. builder.Services.AddControllers();
  7. //1. 添加QuartzUI服务
  8. builder.Services.AddQuartzUI();
  9. //2. 添加基于DLL模式的Quartz任务支持
  10. builder.Services.AddQuartzClassJobs();
  11. var app = builder.Build();
  12. // Configure the HTTP request pipeline.
  13. if (!app.Environment.IsDevelopment())
  14. {
  15. app.UseExceptionHandler("/Home/Error");
  16. // The default HSTS value is 30 days. You may want to change this for production scenarios, see https://aka.ms/aspnetcore-hsts.
  17. app.UseHsts();
  18. }
  19. app.UseHttpsRedirection();
  20. app.UseStaticFiles();
  21. app.UseRouting();
  22. app.UseAuthorization();
  23. //3.使用Quartz组件
  24. app.UseQuartz();
  25. app.MapControllerRoute(
  26. name: "default",
  27. pattern: "{controller=Home}/{action=Index}/{id?}");
  28. //在Use中注册单例实例
  29. app.Use(async (context, next) =>
  30. {
  31. if (next != null)
  32. {
  33. await next.Invoke();
  34. }
  35. });
  36. app.Run();

运行测试

在配置好后,运行程序,默认打开的是首页,手动输入网址https://localhost:7172/QuartzUI,即可看到Quartz管理页面,如下所示:

基于DLL的定时任务

在小型项目中,如果为了定时任务,再去创建WebAPI接口,会比较麻烦,所以基于DLL方式的任务更常见,在Quartz框架下,创建基于DLL方式的任务,需要实现IJobService接口,此接口是GZY.Quartz.MUI组件库自带的默认接口,如下所示:

  1. using GZY.Quartz.MUI.BaseService;
  2. namespace QuartzAdmin.QuartzA.Job
  3. {
  4. public class TestJob : IJobService
  5. {
  6. public string ExecuteService(string parameter)
  7. {
  8. Console.WriteLine($"测试任务被执行了:{parameter}.");
  9. return String.Empty;
  10. }
  11. }
  12. }

任务创建成功后,在页面新建任务时,选择DLL方式,会自动识别TestJob,选择即可,如下所示:

基于WebAPI的定时任务

基于WebAPI的定时任务,是所有的WebAPI接口都可以作为调用的任务,无需特殊处理。在ASP.NET Core MVC项目中,默认情况下是支持WebAPI的,首先创建测试WebAPI接口,如下所示:

  1. using Microsoft.AspNetCore.Http;
  2. using Microsoft.AspNetCore.Mvc;
  3. namespace QuartzAdmin.Controllers
  4. {
  5. [Route("api/[controller]/[action]")]
  6. [ApiController]
  7. public class TestApiController : ControllerBase
  8. {
  9. [HttpGet]
  10. public void Test(string parameters)
  11. {
  12. Console.WriteLine($"test web api {parameters},---{DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss")}");
  13. }
  14. }
  15. }

在任务管理页面,新建任务,任务类型选择API,URL就是WebAPI的接口网址,如下所示:

启动与暂停任务

默认情况下,创建的任务是停止状态,选择任务,开启任务即可。如果任务正在运行,也可以暂停任务。或者删除任务。如下所示:

 查看任务执行记录

通过点击具体任务右侧的执行记录按钮,可以查看执行日志。如果有执行过程中有错误,也会显示,成功则不显示任何信息,如下所示:

好了,以上就是ASP.NET Core MVC+Quartz开发定时任务管理页面的全部内容,旨在抛砖引玉,一起学习,共同进步。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/很楠不爱3/article/detail/506391
推荐阅读
相关标签
  

闽ICP备14008679号