繁体   English   中英

如何从WCF访问其他项目的web.config中的连接字符串

[英]how access connectionstring in a web.config in other project from a WCF

我在从WCF“ Web服务”访问web.config中的连接字符串时遇到一些困难

场景:Visual Studio 2010中的一个解决方案,其中包含2个Web项目,placement和wcfPlacement。 带有连接功能的web.config位于放置项目中。

在此处输入图片说明

如图所示,wcfPlacement没有web.config,但是在构建时,它会生成一个。

从放置项目中,我可以使用ConfigurationManager.ConnectionStrings [“ XX”]。ConnectionString;访问连接字符串。 - 好。

但是,如果我在该服务内部,则在尝试访问该服务时会给我一个错误,这迫使我在要数据库访问的每个类中声明了一个连接字符串,这不好。

如何从wcf中访问放置项目内web.config中的连接字符串?

我试过了:

SqlConnection conn = new SqlConnection(ConfigurationManager.ConnectionStrings["webV"].ConnectionString);

但它给我一个错误:System.NullReferenceException:对象引用未设置为对象的实例。 在wcfPlacement.Prospect.doLogin(字符串登录,字符串senha)

在一个类中尝试了这个:

System.Configuration.Configuration rootWebConfig =
            System.Web.Configuration.WebConfigurationManager.OpenWebConfiguration("/placement");
            System.Configuration.ConnectionStringSettings connString;
            if (rootWebConfig.ConnectionStrings.ConnectionStrings.Count > 0)
            {
                connString =
                    rootWebConfig.ConnectionStrings.ConnectionStrings["NorthwindConnectionString"];
                if (connString != null)
                    Console.WriteLine("Northwind connection string = \"{0}\"",
                        connString.ConnectionString);
                else
                    Console.WriteLine("No Northwind connection string");
            }

但我得到这个错误。 错误1类型或名称空间名称'配置'在名称空间'System.Web'中不存在(您是否缺少程序集引用?)

您必须添加对System.Configuration命名空间的引用。

https://msdn.microsoft.com/zh-CN/library/system.configuration(v=vs.110).aspx

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM