加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > asp.Net > 正文

.net – 尝试激活“MyDbContext”时无法解析“DatabaseConfigura

发布时间:2020-12-16 07:29:37 所属栏目:asp.Net 来源:网络整理
导读:我在ASP.NET MVC Beta 6中使用依赖注入时遇到问题.在Startup.ConfigureServices方法中,我注册了 DatabaseConfiguration和MyDbContext类.项目启动时,我收到以下错误: Unable to resolve service for type 'DatabaseConfiguration' while attempting to activ
我在ASP.NET MVC Beta 6中使用依赖注入时遇到问题.在Startup.ConfigureServices方法中,我注册了 DatabaseConfiguration和MyDbContext类.项目启动时,我收到以下错误:

Unable to resolve service for type 'DatabaseConfiguration' while attempting to activate 'MyDbContext'.

我不确定为什么这样就无法解析DatabaseConfiguration类型.据我所知,它已正确注册.

我错过了什么?

// ASP.NET 5 Beta 6 Project 
public void ConfigureServices(IServiceCollection services) {
    services.Configure<DatabaseConfiguration>(appSettings => ConfigurationBinder.Bind(appSettings,this.Configuration.GetConfigurationSection(nameof(DatabaseConfiguration))));

    services.AddTransient<MyDbContext>();

    services.AddMvc();
}

public class ValuesController : Controller {
    public ValuesController(MintoDbContext tenantRepo) { // ... }

    // ...
}

// The following classes are in a Class Libary.
public class MyDbContext : DbContext {
    public MyDbContext(DatabaseConfiguration databaseConfiguration) { // ... }
}

public class DatabaseConfiguration {
    public string ConnectionString { get; set; }
}

解决方法

你的config.json应该是这样的:

{
  "DatabaseConfiguration": {
      "ConnectionString": "yourconnectionstringhere"
    }
}

那你的DI代码应该是这样的:

services.Configure<DatabaseConfiguration>(configuration.GetConfigurationSection("DatabaseConfiguration"));

但是你真正得到的是一个

IOptions<DatabaseConfiguration>

所以你需要更改DBContext的构造函数来接收它

然后在你的DBContext中,你得到如下的连接字符串:

string connectionString = databaseConfiguration.Options.ConnectionString;

或者您可以获得DatabaseConfiguration的实例

DatabaseConfiguration dbConfig = databaseConfiguration.Options;

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读