亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

從不同項目的 appsettings.json 讀取多個連接字符串

從不同項目的 appsettings.json 讀取多個連接字符串

C#
喵喔喔 2022-10-23 16:20:56
我正在使用 .Net core v 2.1 創建 web api。我的解決方案包含不同的項目層(BLL、DAL、Common 等),并且主項目中有一個 appsettings.json 文件。我的 appsettings.json 文件中有多個連接字符串,我想根據控制器中傳遞的參數選擇連接字符串。這是項目結構和代碼:1) api層應用設置.json"ConnectionStrings": {    "CON1": "con1 connectionstring",    "CON2": "con2 connectionstring",    "CON3": "con3 connectionstring"},啟動.cspublic void ConfigureServices(IServiceCollection services){    services.AddSingleton<IConfiguration>(Configuration);}例如。我正在傳遞 conn = "CON1"AccountController.cs[HttpPost][Route("CreateUser")]public IActionResult CreateUser(string conn, string username){    try    {        AccountDL objAccountDL = new AccountDL(); //call account data layer        objAccountDL.CreateUser(conn, username); //conn = "CON1"        return Ok();    }    catch(Exception ex)    {        throw ex;    }}2) dal層AccountDL.cspublic class AccountDL{    IConfiguration _configuration;    OracleConnection _oracleConnection;    public string CreateUser(string conn, string username)    {        AppConfiguration appConfg = new AppConfiguration(_configuration);           _oracleConnection = appConfg.GetConnection(conn);    }}3) 通用配置層應用配置.cspublic class AppConfiguration{    public IConfiguration _configuration { get; }    public AppConfiguration(IConfiguration configuration)    {        _configuration = configuration;    }    public OracleConnection GetConnection(string conn)    {        try        {            string connectionString = _configuration.GetSection("ConnectionStrings").GetSection(conn).Value;            OracleConnection dbConn = new OracleConnection(connectionString);            return dbConn;        }        catch(Exception ex)        {            throw ex;        }    }}現在我將使用這個 dbConn 連接對象進行進一步處理,但是我得到了 System.NullReferenceException: 'Object reference not set to an instance of an object。如果我在同一個 api 層中嘗試所有這些,那么我將根據傳遞的參數獲取連接字符串,但是在重組我的項目后,我想在不同的項目中使用這個連接,即 DAL,我怎樣才能獲得基于參數的連接字符串在不同的項目中?先感謝您。
查看完整描述

1 回答

?
明月笑刀無情

TA貢獻1828條經驗 獲得超4個贊

因此,您可以從 appsettings.json 文件中訪問連接字符串值以獲取GetConnection()這樣的方法 -


應用配置.cs


public OracleConnection GetConnection(string conn)

{

    try

    {

        string connectionString = _configuration["ConnectionStrings:" + conn];

        OracleConnection dbConn = new OracleConnection(connectionString);

        return dbConn;

    }

    catch(Exception ex)

    {

        throw ex;

    }

}

在AccountController.cs控制器中,您需要IConfiguration在該控制器的構造函數中注入對象的依賴關系。


public class AccountController

{

    public IConfiguration _configuration { get; }


    public AccountController(IConfiguration configuration)

    {

        _configuration = configuration;

    }


    [HttpPost]

    [Route("CreateUser")]

    public IActionResult CreateUser(string conn, string username)

    {

        try

        {

            AccountDL objAccountDL = new AccountDL(_configuration); //call account data layer

            objAccountDL.CreateUser(conn, username); //conn = "CON1"

            return Ok();

        }

        catch(Exception ex)

        {

            throw ex;

        }

    }

}

因此您還需要修改AccountDL.cs類。您需要在構造函數或方法參數中傳遞該對象。


public class AccountDL

{

    IConfiguration _configuration;

    OracleConnection _oracleConnection;


    public AccountDL(IConfiguration configuration)

    {

        _configuration = configuration;

    }


    public string CreateUser(string conn, string username)

    {

        AppConfiguration appConfg = new AppConfiguration(_configuration);   

        _oracleConnection = appConfg.GetConnection(conn);

    }

}


查看完整回答
反對 回復 2022-10-23
  • 1 回答
  • 0 關注
  • 147 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號