服务' Abp.Quartz.IQuartzScheduleJobManager'没有注册

时间:2018-06-08 11:00:22

标签: c# asp.net-core dependency-injection aspnetboilerplate quartz

我已经为ASP.NET Boilerplate(v3.7.0)下载了.NET Core + Vue模板。

我补充说:

[DependsOn(typeof(AbpAutoMapperModule), typeof(AbpQuartzModule))]
public class MyAbpQuartzModule : AbpModule
{
  public override void Initialize()
  {
    IocManager.RegisterAssemblyByConvention(Assembly.GetExecutingAssembly());
  }
}
    xxx.Web.Host 项目中的
  • MyAbpQuartzController.cs
public class MyAbpQuartzController : AbpController
{
  private readonly IQuartzScheduleJobManager _jobManager;

  public MyAbpQuartzController(IQuartzScheduleJobManager jobManager)
  {
      _jobManager = jobManager;
  }

  public async Task<ActionResult> ScheduleJobWithTask()
  {
      await _jobManager.ScheduleAsync<MyLogJob>(
          job =>
          {
              job.WithIdentity("MyLogJobIdentity", "MyGroup")
                  .WithDescription("A job to simply write logs.");
          },
          trigger =>
          {
              trigger.StartNow()
                  .WithSimpleSchedule(schedule =>
                  {
                      schedule.RepeatForever()
                          .WithIntervalInSeconds(5)
                          .Build();
                  });
          });

      return Content("OK, scheduled!");
  }

  public ContentResult TestMyAbpQuartz(string message = "")
  {
      return Content("OK, scheduled!");
  }
}

我调试了 xxx.Web.Host 项目,但它没有用。

http:// localhost:21021 / MyAbpQuartz / TestMyAbpQuartz 页面返回:
&#34;此页面无效 localhost目前无法处理此请求。 HTTP ERROR 500&#34;

我认为QuartzScheduleJobManager没有成功注册。

那么,我该怎么办?

Web.Host/App_Data/log.txt 中的部分错误消息:

ERROR 2018-06-08 19:19:04,161 [5    ] Mvc.ExceptionHandling.AbpExceptionFilter - Can't create component 'MyNetCoreWithVueProject.Web.Host.Controllers.MyAbpQuartzController' as it has dependencies to be satisfied.

'MyNetCoreWithVueProject.Web.Host.Controllers.MyAbpQuartzController' is waiting for the following dependencies:
- Service 'Abp.Quartz.IQuartzScheduleJobManager' which was not registered.

Castle.MicroKernel.Handlers.HandlerException: Can't create component 'MyNetCoreWithVueProject.Web.Host.Controllers.MyAbpQuartzController' as it has dependencies to be satisfied.

'MyNetCoreWithVueProject.Web.Host.Controllers.MyAbpQuartzController' is waiting for the following dependencies:
- Service 'Abp.Quartz.IQuartzScheduleJobManager' which was not registered.

   at Castle.MicroKernel.Handlers.DefaultHandler.AssertNotWaitingForDependency()
   at Castle.MicroKernel.Handlers.DefaultHandler.ResolveCore(CreationContext context, Boolean requiresDecommission, Boolean instanceRequired, Burden& burden)
   at Castle.MicroKernel.Handlers.DefaultHandler.Resolve(CreationContext context, Boolean instanceRequired)
   at Castle.MicroKernel.DefaultKernel.ResolveComponent(IHandler handler, Type service, IDictionary additionalArguments, IReleasePolicy policy)
   at Castle.MicroKernel.DefaultKernel.Castle.MicroKernel.IKernelInternal.Resolve(Type service, IDictionary arguments, IReleasePolicy policy)
   at Castle.Windsor.MsDependencyInjection.ScopedWindsorServiceProvider.GetServiceInternal(Type serviceType, Boolean isOptional) in D:\Github\castle-windsor-ms-adapter\src\Castle.Windsor.MsDependencyInjection\ScopedWindsorServiceProvider.cs:line 55
   at Microsoft.AspNetCore.Mvc.Controllers.ControllerFactoryProvider.<>c__DisplayClass5_0.<CreateControllerFactory>g__CreateController|0(ControllerContext controllerContext)
   at Microsoft.AspNetCore.Mvc.Internal.ControllerActionInvoker.Next(State& next, Scope& scope, Object& state, Boolean& isCompleted)
   at Microsoft.AspNetCore.Mvc.Internal.ControllerActionInvoker.<InvokeInnerFilterAsync>d__14.MoveNext()
--- End of stack trace from previous location where exception was thrown ---
   at System.Runtime.ExceptionServices.ExceptionDispatchInfo.Throw()
   at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)
   at Microsoft.AspNetCore.Mvc.Internal.ResourceInvoker.<InvokeNextExceptionFilterAsync>d__23.MoveNext()
INFO  2018-06-08 19:19:04,967 [5    ] ore.Mvc.Internal.ControllerActionInvoker - Executed action MyNetCoreWithVueProject.Web.Host.Controllers.MyAbpQuartzController.TestMyAbpQuartz (MyNetCoreWithVueProject.Web.Host) in 833.6801ms
ERROR 2018-06-08 19:19:05,059 [5    ] Microsoft.AspNetCore.Server.Kestrel      - Connection id "0HLED66DNH26L", Request id "0HLED66DNH26L:00000004": An unhandled exception was thrown by the application.
Castle.MicroKernel.Handlers.HandlerException: Can't create component 'MyNetCoreWithVueProject.Web.Host.Controllers.MyAbpQuartzController' as it has dependencies to be satisfied.

2 个答案:

答案 0 :(得分:0)

如果要注册不符合传统注册规则的特定类。 ASP.NET Boilerplate提供ITransientDependency,IPerWebRequestDependency和ISingletonDependency接口作为快捷方式。

public interface IQuartzScheduleJobManager
{
    //...
}

public class QuartzScheduleJobManager: IQuartzScheduleJobManager, ITransientDependency
{
    //...
}

答案 1 :(得分:0)

IQuartzScheduleJobManager应由AbpQuartzModule注册。

我发现[DependsOn(typeof(AbpQuartzModule))]已经MyAbpQuartzModule了。

[DependsOn(typeof(MyAbpQuartzModule))]添加到*WebHostModule

[DependsOn(
    typeof(AbpProjectNameWebCoreModule),
    typeof(MyAbpQuartzModule))]
public class AbpProjectNameWebHostModule : AbpModule