.NET Core ConfigureServices

节选自这里

ConfigureServices是Startup类中可以选择定义的一个方法,作用即实现了依赖注入(DI)的配置,只有把服务添加到服务容器中才能让这些服务可以通过依赖注入的形式在应用中使用。方法参数如下:

  • IServiceCollection:整个ASP.NET Core 默认带有依赖注入(DI),IServiceCollection是依赖注入的容器,首先创建一个类(Foo)和接口(IFoo),代码清单如下:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;

namespace WebApplication1
{
   public interface IFoo
    {
        string GetFoo();
    }
}
using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;

namespace WebApplication1
{
    public class Foo : IFoo
    {
        public string GetFoo()
        {
            return "foo";
        }
    }
}

在ConfigureServices 中将接口和实现注入至容器

public void ConfigureServices(IServiceCollection services)
{
    services.AddTransient<IFoo, Foo>();
}

如果想在每次Http请求后都使用IFoo的GetFoo()方法来处理,上面讲到可以在Configure方法中注册函数,在注册过程中由于使用了依赖注入(DI),因此可以直接通过 RequestServices.GetRequiredService<IFoo>() 泛型方法将IFoo对象在容器中取出。

app.Run((context) =>
{
       var str = context.RequestServices.GetRequiredService<IFoo>().GetFoo();
       return context.Response.WriteAsync(str);
});

除了自己的接口外,还支持通过扩展方法添加更多的注入方法,比如EntityFramework、mvc框架都实现自己的添加方法。

public void ConfigureServices(IServiceCollection services)
{
    // Add framework services.
    services.AddDbContext<ApplicationDbContext>(options =>
        options.UseSqlServer(Configuration.GetConnectionString("DefaultConnection")));

    services.AddIdentity<ApplicationUser, IdentityRole>()
        .AddEntityFrameworkStores<ApplicationDbContext>()
        .AddDefaultTokenProviders();

    services.AddMvc();

    // Add application services.
     services.AddTransient<IFoo, Foo>();

}

 

转载于:https://www.cnblogs.com/shuangzimuchangzhu/p/8458296.html

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
.NET Core 中,可以使用 Hangfire 库来实现定时任务。Hangfire 是一个开源的 .NET 库,可以用于在 .NET.NET Core 应用程序中执行后台任务和定时任务。 以下是使用 Hangfire 实现定时任务的步骤: 1. 安装 Hangfire 库 在 Visual Studio 中,打开 NuGet 包管理器控制台,输入以下命令来安装 Hangfire 库: ``` Install-Package Hangfire ``` 2. 配置 Hangfire 在 .NET Core 应用程序的 Startup.cs 文件中,添加以下代码来配置 Hangfire: ```csharp public void ConfigureServices(IServiceCollection services) { // 添加 Hangfire 服务 services.AddHangfire(config => { // 配置 Hangfire 数据库连接字符串 config.UseSqlServerConnectionString(Configuration.GetConnectionString("Hangfire")); }); // 注册 Hangfire 服务 services.AddHangfireServer(); } public void Configure(IApplicationBuilder app, IWebHostEnvironment env) { // 启用 Hangfire 面板 app.UseHangfireDashboard(); } ``` 其中,`UseSqlServerConnectionString` 方法用于配置 Hangfire 数据库连接字符串,`AddHangfireServer` 方法用于注册 Hangfire 服务,`UseHangfireDashboard` 方法用于启用 Hangfire 面板。 3. 创建定时任务 在 .NET Core 应用程序中,可以使用 Hangfire 提供的 `RecurringJob` 类来创建定时任务。以下是一个例子: ```csharp RecurringJob.AddOrUpdate(() => Console.WriteLine("Hello, Hangfire!"), Cron.Minutely); ``` 上述代码会在每分钟执行一次 Console.WriteLine 方法。 4. 启动定时任务 在 .NET Core 应用程序中,可以使用以下代码来启动 Hangfire 定时任务: ```csharp app.UseHangfireServer(); ``` 5. 运行应用程序 现在,可以运行 .NET Core 应用程序,并访问 Hangfire 面板来查看定时任务的状态和执行情况。 希望这些信息对你有所帮助,如果你需要更详细的信息,可以参考 Hangfire 官方文档。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值