Web.config的读取

对于Web.config的读取大家都很属性了。平时我们用得比较多的就是appSettings节点下配置。如:

我们对应的代码是:

= ConfigurationManager.AppSettings[“OAuth_QQ_ClientId”];
= ConfigurationManager.AppSettings[“OAuth_QQ_CallbackUrl”];
= ConfigurationManager.AppSettings[“OAuth_QQ_ClientScrert”];
= ConfigurationManager.AppSettings[“OAuth_Sina_ClientId”];
= ConfigurationManager.AppSettings[“OAuth_Sina_ClientScrert”];
= ConfigurationManager.AppSettings[“OAuth_Sina_CallbackUrl”];
........

是的,很简单、很方便、很清晰。可以总感觉缺少那么一点“面向对象”的感觉。少还无所谓,如果几十个上百个呢?我们是不是可以考虑分类定义,如下:

 <!--自定义配置-->
<customCon>
<!--邮件配置-->
<mail mailPwd="" mailHost="" mailFrom="" />
<!--QQ登陆-->
<oAuthQQ OAuth_QQ_ClientId="" OAuth_QQ_ClientScrert="" OAuth_QQ_CallbackUrl="haojima.net/hi_login.html" />
<!--新浪登录-->
<oAuthSina OAuth_Sina_ClientId="" OAuth_Sina_ClientScrert="" OAuth_Sina_CallbackUrl="haojima.net/hi_login.html" />
</customCon>

可是,你会发现 customCon 编辑器不认,因为这是我自己定义的一个,那如何是好?如下:(申明自定义标签)

如此,是不是感觉分类更清楚了?可是问题又来了,那我们怎么读取自定义标签里面的值呢?

首先:(注意:需要继承ConfigurationSection)

/// <summary>
/// 自定义配置
/// </summary>
public class CustomCon : ConfigurationSection
{
/// <summary>
/// 邮箱设置
/// </summary>
[ConfigurationProperty("mail", IsRequired = true)]
public MailElement Mail
{
get { return (MailElement)this["mail"]; }
} /// <summary>
/// qq登录
/// </summary>
[ConfigurationProperty("oAuthQQ", IsRequired = true)]
public OAuthQQElement OAuthQQ
{
get { return (OAuthQQElement)this["oAuthQQ"]; }
} /// <summary>
/// 新浪登录
/// </summary>
[ConfigurationProperty("oAuthSina", IsRequired = true)]
public OAuthSinaElement OAuthSina
{
get { return (OAuthSinaElement)this["oAuthSina"]; }
}

然后MailElement、OAuthQQElement、OAuthSinaElement 分别具体定义:

 #region MailElement(邮箱)
public class MailElement : ConfigurationElement
{
/// <summary>
/// 发件人密码
/// </summary>
[ConfigurationProperty("mailPwd", IsRequired = true)]
public string Pwd
{
get { return this["mailPwd"].ToString(); }
set { this["mailPwd"] = value; }
} /// <summary>
/// SMTP邮件服务器
/// </summary>
[ConfigurationProperty("mailHost", IsRequired = true)]
public string Host
{
get { return this["mailHost"].ToString(); }
set { this["mailHost"] = value; }
} /// <summary>
///发件人邮箱
/// </summary>
[ConfigurationProperty("mailFrom", IsRequired = true)]
public string From
{
get { return this["mailFrom"].ToString(); }
set { this["mailFrom"] = value; }
}
}
#endregion #region OAuthQQElement(QQ)
public class OAuthQQElement : ConfigurationElement
{ [ConfigurationProperty("OAuth_QQ_ClientId", IsRequired = true)]
public string ClientId
{
get { return this["OAuth_QQ_ClientId"].ToString(); }
set { this["OAuth_QQ_ClientId"] = value; }
} [ConfigurationProperty("OAuth_QQ_ClientScrert", IsRequired = true)]
public string ClientScrert
{
get { return this["OAuth_QQ_ClientScrert"].ToString(); }
set { this["OAuth_QQ_ClientScrert"] = value; }
} [ConfigurationProperty("OAuth_QQ_CallbackUrl", IsRequired = true)]
public string CallbackUrl
{
get { return this["OAuth_QQ_CallbackUrl"].ToString(); }
set { this["OAuth_QQ_CallbackUrl"] = value; }
}
}
#endregion #region OAuthSinaElement(新浪)
public class OAuthSinaElement : ConfigurationElement
{ [ConfigurationProperty("OAuth_Sina_ClientId", IsRequired = true)]
public string ClientId
{
get { return this["OAuth_Sina_ClientId"].ToString(); }
set { this["OAuth_Sina_ClientId"] = value; }
} [ConfigurationProperty("OAuth_Sina_ClientScrert", IsRequired = true)]
public string ClientScrert
{
get { return this["OAuth_Sina_ClientScrert"].ToString(); }
set { this["OAuth_Sina_ClientScrert"] = value; }
} [ConfigurationProperty("OAuth_Sina_CallbackUrl", IsRequired = true)]
public string CallbackUrl
{
get { return this["OAuth_Sina_CallbackUrl"].ToString(); }
set { this["OAuth_Sina_CallbackUrl"] = value; }
}
}
#endregion

到现在为止,我们在代码层面已经建立和config一一对应的关联了。下面我们来取值:

 CustomCon custom = (CustomCon)ConfigurationManager.GetSection("customCon");
var url = custom.OAuthQQ.CallbackUrl;//获取值
var id = custom.OAuthQQ.ClientId;//获取值
//、、、、、

如此是不是甚爽,比原先的 appSettings 更有“对象”的感觉了吧。且,当你配置过多的时候分类也更加清晰!

Web.config的写入

对于Web.config的写入需求一般很少,多数都只是读取。那为什么我这里要说写入呢?因为好多人问我“这个博客系统的数据库在哪里?”,每次都解释的'不亦乐乎',"这个是coder first根据代码生成数据库",后来次数多了实在受不了了。考虑着,是否可以做个引导页面,初次使用的时候提示设置数据库和邮箱什么的(这样的话对于没有编程基础的人搭建自己的博客系统也降低了门槛)。

第一次启动程序的时候检查数据库连接,没有就进入引导页面,设置。(这个过程都不用去编辑Web.config文件了)

好了,看了上面的效果图我们继续来看是怎么把数据写入到Web.config文件的吧。

其实很简单,稍微改下上面代码:

改成通过 WebConfigurationManager.OpenWebConfiguration 来读取代码就可以编辑了。不过不要忘了 config.Save(); 才会真正更新到Web.config里面去。

到这里还只能修改我们自定义的节点数据。我们最最主要的是想更新数据库连接,请看下面对数据库连接的操作:

/// <summary>
/// 修改数据库连接
/// </summary>
/// <param name="key"></param>
/// <param name="connectionString"></param>
/// <param name="providerName"></param>
public static void SetConnectionString(string key, string connectionString, string providerName = "System.Data.SqlClient")
{
ConnectionStringsSection connectionSetting = (ConnectionStringsSection)config.GetSection("connectionStrings");
if (connectionSetting.ConnectionStrings[key] == null)//如果不存在此节点,则添加
{
ConnectionStringSettings connectionStringSettings = new ConnectionStringSettings(key, connectionString, providerName);
connectionSetting.ConnectionStrings.Add(connectionStringSettings);
}
else//如果存在此节点,则修改
{
connectionSetting.ConnectionStrings[key].ConnectionString = connectionString;
connectionSetting.ConnectionStrings[key].ProviderName = providerName;
}
config.Save();
}

其实,细看和我们上面的代码大同小异。(只是把我们自定义的类改成了 ConnectionStringsSection .net默认的连接对象)

一步步搭建自己的博客

好了,以上都是胡说八道。

主要是说下思路,大家自由发挥。感谢您的阅读,希望对您有一点点作用!

文章首链:http://www.cnblogs.com/zhaopei/p/5677053.html

一步步开发自己的博客 .NET版(11、Web.config文件的读取和修改)的更多相关文章

  1. 一步步开发自己的博客 .NET版(1、基本显示)

    前言 我们每个猿都有一个搭建自己独立博客的梦,我也不例外.以前想 现在想 以后也想.之所以一直迟迟没有着手,是因为难以跨出第一步.每次心里想着,等我以后技术好了再说,然后就没有然后了.以前用过word ...

  2. 一步步开发自己的博客 .NET版(3、注册登录功能)

    前言 这次开发的博客主要功能或特点:    第一:可以兼容各终端,特别是手机端.    第二:到时会用到大量html5,炫啊.    第三:导入博客园的精华文章,并做分类.(不要封我)    第四:做 ...

  3. 一步步开发自己的博客 .NET版(4、文章发布功能)百度编辑器

    前言 这次开发的博客主要功能或特点: 第一:可以兼容各终端,特别是手机端. 第二:到时会用到大量html5,炫啊. 第三:导入博客园的精华文章,并做分类.(不要封我) 第四:做个插件,任何网站上的技术 ...

  4. 一步步开发自己的博客 .NET版(5、Lucenne.Net 和 必应站内搜索)

    前言 这次开发的博客主要功能或特点:    第一:可以兼容各终端,特别是手机端.    第二:到时会用到大量html5,炫啊.    第三:导入博客园的精华文章,并做分类.(不要封我)    第四:做 ...

  5. 一步步开发自己的博客 .NET版 剧终篇(6、响应式布局 和 自定义样式)

    前言 这次开发的博客主要功能或特点:    第一:可以兼容各终端,特别是手机端.    第二:到时会用到大量html5,炫啊.    第三:导入博客园的精华文章,并做分类.(不要封我)    第四:做 ...

  6. 一步步开发自己的博客 .NET版(10、前端对话框和消息框的实现)

    关于前端对话框.消息框的优秀插件多不胜数.造轮子是为了更好的使用轮子,并不是说自己造的轮子肯定好.所以,这个博客系统基本上都是自己实现的,包括日志记录.响应式布局.评论功能等等一些本可以使用插件的.好 ...

  7. 一步步开发自己的博客 .NET版(9、从model first替换成code first 问题记录)

    为什么要改用code first 用过code first的基本上都不会再想用回model first或是db first(谁用谁知道).不要问我为什么不一开始就直接使用code first,因为那个 ...

  8. ASP.NET 一步步开发自己的博客 .NET版(11、Web.config文件的读取和修改)

    原文:http://www.cnblogs.com/zhaopei/p/5677053.html

  9. 一步步搭建自己的博客 .NET版(2、评论功能)

    前言 这次开发的博客主要功能或特点:    第一:可以兼容各终端,特别是手机端.    第二:到时会用到大量html5,炫啊.    第三:导入博客园的精华文章,并做分类.(不要封我)    第四:做 ...

随机推荐

  1. 异步编程 In .NET

    概述 在之前写的一篇关于async和await的前世今生的文章之后,大家似乎在async和await提高网站处理能力方面还有一些疑问,博客园本身也做了不少的尝试.今天我们再来回答一下这个问题,同时我们 ...

  2. JAVA语言中的修饰符

    JAVA语言中的修饰符 -----------------------------------------------01--------------------------------------- ...

  3. ABP文档 - 本地化

    文档目录 本节内容: 简介 应用语言 本地化源 XML文件 注册XML本地化源 JSOn文件 注册JSON本地化源 资源文件 自定义源 获取一个本地文本 在服务端 在MVc控制器里 在MVC视图里 在 ...

  4. 07.LoT.UI 前后台通用框架分解系列之——轻巧的文本编辑器

    LoT.UI汇总:http://www.cnblogs.com/dunitian/p/4822808.html#lotui 上次说的是强大的百度编辑器 http://www.cnblogs.com/d ...

  5. 《Django By Example》第一章 中文 翻译 (个人学习,渣翻)

    书籍出处:https://www.packtpub.com/web-development/django-example 原作者:Antonio Melé (译者注:本人目前在杭州某家互联网公司工作, ...

  6. ASP.NET MVC5+EF6+EasyUI 后台管理系统(70)-微信公众平台开发-成为开发者

    系列目录 前言: 一.阅读这段系列之前,你必须花半天时间大致阅读微信公众平台的API文档,我尽量以简短快速的语言与大家分享一个过程 二.借助微信公众平台SDK Senparc.Weixin for C ...

  7. 【原创分享·微信支付】C# MVC 微信支付教程系列之现金红包

            微信支付教程系列之现金红包           最近最弄这个微信支付的功能,然后扫码.公众号支付,这些都做了,闲着无聊,就看了看微信支付的其他功能,发现还有一个叫“现金红包”的玩意,想 ...

  8. SDWebImage源码解读 之 SDWebImageCompat

    第三篇 前言 本篇主要解读SDWebImage的配置文件.正如compat的定义,该配置文件主要是兼容Apple的其他设备.也许我们真实的开发平台只有一个,但考虑各个平台的兼容性,对于框架有着很重要的 ...

  9. 设计模式之行为类模式大PK

                                        行为类模式大PK 行为类模式包括责任链模式.命令模式.解释器模式.迭代器模式.中介者模式.备忘录模式.观察者模式.状态模式.策略 ...

  10. vue.js初探

    前言 入手2016最火前端框架之一vue.js.大概从网上找了些资料看了下vue.js,从网上的资料来看只能惊叹其发展速度太快,让我意外的是其作者是华人的前提下作品这么受欢迎. 网上的博客和教程各种组 ...