In this post, I am going to discuss about web.config. Normally in our daily life, we used to have some data in appSettings section of web.config and read it when required. That is in string
form. But there are lot more than this. We can update the data in web.config programmatically as well.
Now another main point is, we can store some object of custom type in web.config as well, which we normally don’t do. But this can be very useful in several scenarios.
Has anyone tried to update some value or add some value in web.config? We’ll have a brief discussion about this.
First, this is very common to have some constant data at appSettings
section of web.config and read it whenever required. So how to read this (for beginners).
//The data is stored in web.config as
<appSettings>
<add key="WelcomeMessage"
value="Hello All, Welcome to my Website." />
</appSettings>
// To read it
string message = ConfigurationManager.AppSettings["WelcomeMessage"];
Now if we want to update some data of appSettings
programmatically, one can do it like this.
Configuration config =
WebConfigurationManager.OpenWebConfiguration(Request.ApplicationPath);
config.AppSettings.Settings["WelcomeMessage"].Value =
"Hello All, Welcome to my updated site.";
config.Save();
Now what do you do if you want to add some data in appSettings
. You can add some app.config data as below:
Configuration config =
WebConfigurationManager.OpenWebConfiguration(Request.ApplicationPath);
config.AppSettings.Settings.Add("ErrorMessage",
"An error has been occurred during processing this request.");
config.Save();
The above code is adding one new key value pair in web.config file. Now this can be read anywhere in the application.
Now, the question is, can we store some custom data at config?
Yes…
We can store some object. Let’s see how.
I created a sample example. In this example, I saved an object of my custom class NewError
in web.config file and updated it whenever required.
To do this, follow the below steps:
- Create a Class that inherits from
ConfigurationSection
(it is available under namespace System.Configuration
). Every property must have an attribute ConfigurationProperty
, having attribute name and some more parameters. This name is directly mapped to web.config. Let’s see the NewError
class:
public class NewError:ConfigurationSection
{
[ConfigurationProperty ("Id",IsRequired = true)]
public string ErrorId {
get { return (string)this["Id"]; }
set { this["Id"] = value; }
}
[ConfigurationProperty("Message", IsRequired = false)]
public string Message {
get { return (string)this["Message"]; }
set { this["Message"] = value; }
}
[ConfigurationProperty("RedirectURL", IsRequired = false)]
public string RedirectionPage
{
get { return (string)this["RedirectURL"]; }
set { this["RedirectURL"] = value; }
}
[ConfigurationProperty("MailId", IsRequired = false)]
public string EmailId
{
get { return (string)this["MailId"]; }
set { this["MailId"] = value; }
}
[ConfigurationProperty("DateAdded", IsRequired = false)]
public DateTime DateAdded
{
get { return (DateTime)this["DateAdded"]; }
set { this["DateAdded"] = value; }
}
}
As you can see, every property has attribute ConfigurationProperty
with some value. As you can see, the property ErrorId
has attribute:
[ConfigurationProperty ("Id",IsRequired = true)]
it means ErrorId
will be saved as Id
in web.config file and it is required value. There are more elements in this attribute that you can set based on your requirement.
Now if you’ll see the property closely, it is a bit different.
public string ErrorId {
get { return (string)this["Id"]; }
set { this["Id"] = value; }
}
Here the value is saved as the key “id
”, that is mapped with web.config file.
- Now you are required to add/register a section in the section group to tell the web.config that you are going to have this kind of data. This must be in
<configSections/>
and will be as:
<section name="errorList" type="NewError" allowLocation="true"
allowDefinition="Everywhere"/>
- Now one can add that object in your config file directly as:
<errorList Id="1" Message="ErrorMessage"
RedirectURL="www.google.com" MailId="xyz@hotmail.com" >
</errorList>
- And to read it at your page. Read it as follows:
NewError objNewError = (NewError)ConfigurationManager.GetSection("errorList");
And also a new object can be saved programmatically as:
NewError objNewError = new NewError()
{
RedirectionPage="www.rediff.com",
Message = "New Message",
ErrorId="0",
DateAdded= DateTime.Now.Date
};
Configuration config =
WebConfigurationManager.OpenWebConfiguration(Request.ApplicationPath);
config.Sections.Add("errorList", objNewError);
config.Save();
Even one can add a custom group and have some custom elements in this section.
ASP.NET provides very powerful APIs to read/edit the web.config file easily.
Hope you all must have enjoyed this, and I will appreciate your feedback.
Thanks!