问题描述
我正在尝试使用 sql server 配置 elmah。 我看到的配置就是这种形式
public class Startup
{
public void ConfigureServices(IServiceCollection services)
{
...
}
private static void InjectsAuthElements(IServiceCollection services)
{
...
services.AddElmah<sqlErrorLog>(options =>
{
options.Path = "ElmahNewNameForSecurity.axd";
options.OnPermissionCheck = context => context.User.Identity.IsAuthenticated && context.User.IsInRole("Admin");
options.ConnectionString = "MyConnectionString";
});
}
}
我想用 Configuration.GetConnectionString("Default")
之类的东西替换 MyConnectionString。
解决方法
只需添加一个 IConfiguration
接口作为方法的第二个参数,并在调用该方法时传递 Configuration
。
private static void InjectsAuthElements(
IServiceCollection services,IConfiguration configuration)
{
...
services.AddElmah<SqlErrorLog>(options =>
{
options.Path = "ElmahNewNameForSecurity.axd";
options.OnPermissionCheck = context => context.User.Identity.IsAuthenticated && context.User.IsInRole("Admin");
options.ConnectionString = "MyConnectionString";
});
}
,
要获取连接字符串,可以使用IConfiguration
public class Startup
{
private readonly IConfiguration _configuration;
public Startup(IConfiguration configuration)
{
_configuration = configuration;
}
public void ConfigureServices(IServiceCollection services)
{
...
}
private static void InjectsAuthElements(IServiceCollection services)
{
...
services.AddElmah<SqlErrorLog>(options =>
{
options.Path = "ElmahNewNameForSecurity.axd";
options.OnPermissionCheck = context =>
context.User.Identity.IsAuthenticated &&
context.User.IsInRole("Admin");
options.ConnectionString =
_configuration.GetConnectionString("MyConnectionString");
});
}
}
}