如何从库中访问连接字符串

问题描述 投票:4回答:4

我在一个单独的类库项目中有一个Web项目(mvc)和数据访问层。我需要访问位于该库项目中的app.config中的连接字符串。

ConfigurationManager.ConnectionStrings [0] .ConnectionString提取了一些奇怪的东西。我在库的配置和web项目的配置文件中都没有这种设置。

App.config看起来像这样:

<?xml version="1.0" encoding="utf-8" ?>
 <configuration>
  <connectionStrings>
   <add name="DALConnectionString" connectionString="User ID=sa;Password=pass;Initial     Catalog=db;Data Source=srv\SQL2005;" />
 </connectionStrings>
</configuration>
c# web-config connection-string app-config class-library
4个回答
5
投票

默认情况下,类库无法访问配置文件。

类库的客户端(在本例中是您的Web项目)可以提供配置设置。

因此,将所有相关设置(连接字符串)放在Web的配置文件中。类库中的ConfigurationManager代码将使用Web项目配置设置。


7
投票

在这种情况下,你的图书馆应该使用dependency injectioninversion of control

您在数据访问层(DAL)库中的类应将连接字符串作为constructor argumentproperty value

这将确保您的DAL也可以在其他项目中使用,并且不依赖于您的mvc Web应用程序。

让使用DAL的代码从配置文件中读取连接字符串并将其注入到类的构造函数中。


0
投票

你应该在web.config中添加上面显示的片段,然后在运行时配置管理器即使在你的类库中运行也会使用它。


0
投票

您无法访问DLL的app.config。

app.config仅适用于入口点程序集或web.config用于Web项目。

尝试将连接复制到入口点配置或通过解析配置XML来加载配置 - 不推荐。

© www.soinside.com 2019 - 2024. All rights reserved.