Four Ways to Read Configuration Setting in C#(COPY)
Introduction
This article will demonstrate us how we can get/read the configuration setting from Web.Config or App.Config in C#. There are different purposes to set the values inside the configuration file and read their values based on defined keys, we define those values inside the configuration section which might be need to make it more secure, it could be some secret keys or the value which should get frequently.
Using the code
Today I will show you, four different ways to get the values from configuration section. For this demonstration, I am going to create a simple Console Application and provide the name as “ConfigurationExample”. Just create one Console Application as following.
Just follow: New Project > Visual C# > Console Application
We need to add System.Configuration assembly reference to access configuration setting using ConfigurationManager. To add reference, just right click to References and Click to Add References.
Now we can see that System.Configuration reference added successfully with our project.
So, let’s move to different ways to add the values inside the config file and approach we follow to get it.
Approach One
Let’s take one example, where we need to add some application level settings and access them based on their keys. We can add these setting either inside Web.Config or App.Config. But we need to add <appSettings> section inside the configuration section.
Just follow the following example, where inside the appSettings section; we have defined few keys and their values.
App.config
<?xml version="1.0" encoding="utf-8" ?>
<configuration>
<startup>
<supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.5" />
</startup>
<appSettings>
<add key="Title" value="Configuration Example"/>
<add key="Language" value="CSharp"/>
</appSettings>
</configuration>
To access these values, there is one static class as named “ConfigurationManager” which has one getter property as named AppSettings. We can just pass the key inside the AppSettings and get the desired value from AppSettings section as following.
public static void GetConfigurationValue()
{
var title = ConfigurationManager.AppSettings["title"];
var language = ConfigurationManager.AppSettings["language"]; Console.WriteLine(string.Format("'{0}' project is created in '{1}' language ", title, language));
}
When we implement the above code, we get following out.
Approach Two
Let’s move to next example, just think about if we need to add settings inside section for separation. So, in this situation, we can create custom section inside the configuration section in App.Config/Web.Config as following. Section can make your data more readable and understandable based on your section name.
In following example, we have just created one custom section as named “ApplicationSettings” and added all key/value pairs separately.
<?xml version="1.0" encoding="utf-8" ?>
<configuration>
<configSections>
<section name="ApplicationSettings" type="System.Configuration.NameValueSectionHandler"/>
</configSections> <ApplicationSettings>
<add key="ApplicationName" value="Configuration Example Project"/>
<add key="Language" value="CSharp"/>
<add key="SecretKey" value="xxxxxxx"/>
</ApplicationSettings>
<startup>
<supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.5" />
</startup>
</configuration>
To access custom section settings, first we need to find out the section using GetSection method which is defined inside the ConfigurationManager class and cast the return value as NameValueCollection. It will return all the keys available inside this custom section and based on keys we can get values easily as following.
public static void GetConfigurationUsingSection()
{
var applicationSettings = ConfigurationManager.GetSection("ApplicationSettings")
as NameValueCollection; if (applicationSettings.Count == )
{
Console.WriteLine("Application Settings are not defined");
}
else
{
foreach (var key in applicationSettings.AllKeys)
{
Console.WriteLine(key + " = " + applicationSettings[key]);
}
} }
When we implement the above code, we get following out.
Approach Three
Now move to some tough stuff, here we are going to create section inside the group, so that if required we can add multiple sections in same group. It is basically grouping the same type of section in a group.
In following example, we have created one group as named “BlogGroup” and inside that we have defined one section as named “PostSetting” and its type as a NameValueSectionHandler. “PostSetting” section is containing all the key/value pair separately as following.
<?xml version="1.0" encoding="utf-8"?>
<configuration>
<configSections>
<sectionGroup name="BlogGroup">
<section name="PostSetting" type="System.Configuration.NameValueSectionHandler"/>
</sectionGroup>
<section name="ProductSettings" type="ConfigurationExample.ProductSettings, ConfigurationExample"/>
</configSections> <BlogGroup>
<PostSetting>
<add key="PostName" value="Getting Started With Config Section in .Net"/>
<add key="Category" value="C#"></add>
<add key="Author" value="Mukesh Kumar"></add>
<add key="PostedDate" value="28 Feb 2017"></add>
</PostSetting>
</BlogGroup> <ProductSettings>
<DellSettings ProductNumber="" ProductName="Dell Inspiron" Color="Black" Warranty="2 Years" ></DellSettings>
</ProductSettings> <startup>
<supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.5.2"/>
</startup>
</configuration>
To read these types of configuration setting, we need to access section based on section group and then we can get all the keys and their values as following code is doing.
public static void GetConfigurationUsingSectionGroup()
{
var PostSetting = ConfigurationManager.GetSection("BlogGroup/PostSetting") as NameValueCollection;
if (PostSetting.Count == )
{
Console.WriteLine("Post Settings are not defined");
}
else
{
foreach (var key in PostSetting.AllKeys)
{
Console.WriteLine(key + " = " + PostSetting[key]);
}
}
}
When we implement the above code, we get following out.
Approach Four
At last we are on advance stage of configuration settings. Sometimes it is required to setup your all key/value pair based on custom class behavior so that we can control it behavior form outer world.
See the following class “DellFeatures”, which shows some custom properties of Dell laptop and we need to add it inside the configuration section. Following class contains some default values if value is not available in configuration section.
using System;
using System.Collections.Generic;
using System.Configuration;
using System.Linq;
using System.Text;
using System.Threading.Tasks; namespace ConfigurationExample
{
public class DellFeatures : ConfigurationElement
{
[ConfigurationProperty("ProductNumber", DefaultValue = , IsRequired = true)]
public int ProductNumber
{
get
{
return (int)this["ProductNumber"];
}
} [ConfigurationProperty("ProductName", DefaultValue = "DELL", IsRequired = true)]
public string ProductName
{
get
{
return (string)this["ProductName"];
}
} [ConfigurationProperty("Color", IsRequired = false)]
public string Color
{
get
{
return (string)this["Color"];
}
}
[ConfigurationProperty("Warranty", DefaultValue = "1 Years", IsRequired = false)]
public string Warranty
{
get
{
return (string)this["Warranty"];
}
}
}
}
To return this setting, we are going to create on more class which returns this as a property. Here we can also add multiple classes as properties.
using System;
using System.Collections.Generic;
using System.Configuration;
using System.Linq;
using System.Text;
using System.Threading.Tasks; namespace ConfigurationExample
{
public class ProductSettings : ConfigurationSection
{
[ConfigurationProperty("DellSettings")]
public DellFeatures DellFeatures
{
get
{
return (DellFeatures)this["DellSettings"];
}
}
}
}
To implement it inside the configuration section, we are going to change the type of “ProductSettings” as “ConfigurationExample.ProductSettings” which will return all the property of DellFeaturs class.
<?xml version="1.0" encoding="utf-8"?>
<configuration>
<configSections> <section name="ProductSettings" type="ConfigurationExample.ProductSettings, ConfigurationExample"/>
</configSections> <BlogGroup>
<PostSetting>
<add key="PostName" value="Getting Started With Config Section in .Net"/>
<add key="Category" value="C#"></add>
<add key="Author" value="Mukesh Kumar"></add>
<add key="PostedDate" value="28 Feb 2017"></add>
</PostSetting>
</BlogGroup> <ProductSettings>
<DellSettings ProductNumber="" ProductName="Dell Inspiron" Color="Black" Warranty="2 Years" ></DellSettings>
</ProductSettings> <startup>
<supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.5.2"/>
</startup>
</configuration>
To access this type of configuration, same we need to get custom section first and rest of will be accessible very easily as following code.
public static void GetConfigurationUsingCustomClass()
{
var productSettings = ConfigurationManager.GetSection("ProductSettings") as ConfigurationExample.ProductSettings;
if (productSettings == null)
{
Console.WriteLine("Product Settings are not defined");
}
else
{
var productNumber = productSettings.DellFeatures.ProductNumber;
var productName = productSettings.DellFeatures.ProductName;
var color = productSettings.DellFeatures.Color;
var warranty = productSettings.DellFeatures.Warranty; Console.WriteLine("Product Number = " + productNumber);
Console.WriteLine("Product Name = " + productName);
Console.WriteLine("Product Color = " + color);
Console.WriteLine("Product Warranty = " + warranty);
}
}
When we implement the above code, we get following out.
Four Ways to Read Configuration Setting in C#(COPY)的更多相关文章
- maven setting.xml 配置(有效)
<?xml version="1.0" encoding="UTF-8"?> <settings xmlns="http://mav ...
- System Center Configuration Manager 2016 配置安装篇(Part3)
SCCM 2016 配置管理系列(Part 1- 4) 介绍AD01上配置了Active Directory域服务(ADDS),然后将Configuration Manager服务器(CM16)加入到 ...
- System Center Configuration Manager 2016 配置安装篇(Part1)
SCCM 2016 配置管理系列(Part 1- 4) 介绍AD01上配置了Active Directory域服务(ADDS),然后将Configuration Manager服务器(CM16)加入到 ...
- System Center Configuration Manager 2016 必要条件准备篇(Part1)
步骤4.创建系统管理容器 SCCM 2016 配置管理系列(Part 1- 4) 介绍AD01上配置了Active Directory域服务(ADDS),然后将Configuration Manag ...
- System Center Configuration Manager 2016 域准备篇(Part4)
步骤4.创建系统管理容器 注意:在Active Directory域控制器服务器(AD01)上以本地管理员身份执行以下操作 有关您为何这样做的详细信息,请参阅https://docs.microsof ...
- 微软企业库5.0 学习之路——第八步、使用Configuration Setting模块等多种方式分类管理企业库配置信息
在介绍完企业库几个常用模块后,我今天要对企业库的配置文件进行处理,缘由是我打开web.config想进行一些配置的时候发现web.config已经变的异常的臃肿(大量的企业库配置信息充斥其中),所以决 ...
- Spark 官方文档(4)——Configuration配置
Spark可以通过三种方式配置系统: 通过SparkConf对象, 或者Java系统属性配置Spark的应用参数 通过每个节点上的conf/spark-env.sh脚本为每台机器配置环境变量 通过lo ...
- maven -- 学习笔记(二)之setting.xml配置说明(备忘)
setting.xml配置说明,learn from:http://pengqb.javaeye.com,http://blog.csdn.net/mypop/article/details/6146 ...
- maven之(六)setting.xml的配置文件详解
setting.xml配置文件 maven的配置文件settings.xml存在于两个地方: 1.安装的地方:${M2_HOME}/conf/settings.xml 2.用户的目录:${user.h ...
随机推荐
- Pipe——高性能IO(三)
Pipelines可以替换掉那些丑陋的封装(kludge).变通(workaround)或妥协(compromise)——用一个在框架中设计优雅的专门的解决方案. 敢肯定,下面所覆盖的那些痛点,对于那 ...
- 【RTOS】基于V7开发板的最新版FreeRTOS V10.2.0程序模板,含MDK和IAR,支持串口打印任务执行情况
模板下载: 链接:https://pan.baidu.com/s/1N32Hx7cTbDoRinuzTUB3zw 提取码:6aox 1.MDK使用MDK5.26及其以上版本. 2.IAR使用IAR ...
- vue安装遇到的5个报错小结
前言 这篇博文不会教你怎么安装vue,但会告知安装过程中可能遇到的5个问题 2017年我写过一篇安装vue的博客,详情:https://www.cnblogs.com/tu-0718/p/752109 ...
- 三行Jquery代码实现简单的选项卡
今晚,我们来用实现一个简单的选项卡切换代码,主要代码只有两行. 效果: 思路:通过切换JQuery控制div的显隐和样式的改变 其中那个一个div显示,其余全隐藏 实现: <!DOCTYPE h ...
- Java题库——Chapter11 继承和多态
1)Analyze the following code: public class Test { public static void main(String[ ] args) { B b = ne ...
- ZooKeeper 面试题
高强度训练第二十一天总结 1. ZooKeeper 面试题 ZooKeeper 是一个开放源码的分布式协调服务,它是集群的管理者,监视着集群 中各个节点的状态根据节点提交的反馈进行下一步合理操作.最终 ...
- javascript 模块化开发(一)
什么是模块化 将一组模块(及其依赖项)以正确的顺序拼接到一个文件(或一组文件)中的过程. 传统的模块化做法. 模块是实现特定功能的一组属性和方法的封装. 将模块写成一个对象,所有的模块成员都放到这个对 ...
- 【Swift】WKWebView与JS的交互使用
一.前言 近日,有朋友问我关于WKWebView与JS的交互问题,可我之前一直使用的是UIWebView,也不曾做过WKWebView的交互啊!接下来大家一块学习下WKWebView是怎么实现原生代码 ...
- Linux—软连接与硬连接
软链接的创建,删除,修改 创建软链接:ln -s[目标文件或目录][软链接地址] 解释:软链接地址相当于快捷方式,目标文件或目录才是真正的内容.[软链接地址]指“快捷键”文件名称,该文件是被指令创建的 ...
- shiro授权、注解式开发
在ShiroUserMapper.xml中新增内容 <select id="getRolesByUserId" resultType="java.lang.Stri ...