J. *_*non 7 c# dependency-injection appsettings asp.net-core-mvc
假设我使用新的DepencyInjection框架在新的ASP.Net/vNext中配置我的类和依赖项.
我该如何使用,如何获取预定义的配置设置?
public void ConfigureServices(IServiceCollection services)
{
// Add Application settings to the services container.
services.Configure<AppSettings>(Configuration.GetSubKey("AppSettings"));
// Add EF services to the services container.
services.AddEntityFramework()
.AddSqlServer()
.AddDbContext<ApplicationDbContext>(options =>
options.UseSqlServer(Configuration["Data:DefaultConnection:ConnectionString"]));
// Add Identity services to the services container.
services.AddIdentity<ApplicationUser, IdentityRole>()
.AddEntityFrameworkStores<ApplicationDbContext>()
.AddDefaultTokenProviders();
// Configure the options for the authentication middleware.
// You can add options for Google, Twitter and other middleware as shown below.
// For more information see http://go.microsoft.com/fwlink/?LinkID=532715
services.Configure<FacebookAuthenticationOptions>(options =>
{
options.AppId = Configuration["Authentication:Facebook:AppId"];
options.AppSecret = Configuration["Authentication:Facebook:AppSecret"];
});
services.Configure<MicrosoftAccountAuthenticationOptions>(options =>
{
options.ClientId = Configuration["Authentication:MicrosoftAccount:ClientId"];
options.ClientSecret = Configuration["Authentication:MicrosoftAccount:ClientSecret"];
});
// Add MVC services to the services container.
services.AddMvc();
services.AddSingleton(a =>
{
//AppSettings settingsModel = ?? //GET CONFIGURATION SETTINGS FILLED
// TECHNICAL ARTIFICE TO RETRIEVE CURRENT SETTINGS
//var settingsModel = new AppSettings();
//var config = Configuration.GetSubKey("AppSettings");
//foreach (var item in typeof(AppSettings).GetProperties().Where(b => b.CanWrite))
{
//item.SetValue(settingsModel, config.Get(item.Name));
}
return new FooService(settingsModel);
});
//Uncomment the following line to add Web API services which makes it easier to port Web API 2 controllers.
//You will also need to add the Microsoft.AspNet.Mvc.WebApiCompatShim package to the 'dependencies' section of project.json.
services.AddWebApiConventions();
}
Run Code Online (Sandbox Code Playgroud)
您可以通过IOptions<AppSettings>
在其构造函数中注入DI服务来在您的FooService中获取AppSettings .
该IOptions<>
界面是名为Options Model的一部分,用于在整个应用程序中访问POCO样式设置(例如:您的AppSettings).类似的呼声services.Configure<AppSettings>(
和services.Configure<FacebookAuthenticationOptions>(options =>
你上面的例子中,实际登记而这又被称作DI服务中使用DI服务OptionsManager
解析的请求时IOptions<>
.
例:
public class FooService
{
private readonly AppSettings _settings;
public FooService(IOptions<AppSettings> options)
{
_settings = options.Options;
}
....
....
}
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
2837 次 |
最近记录: |