利用程序动态管理Web.config文件的配置

简介:

Web.config文件假设有如下需要管理的配置信息:  

<appSettings>
   <add key="Sitetitle" value="站点名称" />
   <add key="SiteUrl" value="主页网址" />
   <add key="SiteLogo" value="站点Logo" />
   <add key="SiteBanner" value="站点Banner" />
   <add key="SiteEmail" value="联系Email" />
</appSettings>

实现的c#核心代码:

一、将Web.config中的相关信息读入TextBox


private void Page_Load(object sender, System.EventArgs e)
 {
  if(!Page.IsPostBack)
  {
   //将Web.config中的相关值填入TextBox
   this.txttitle.Text=System.Configuration.ConfigurationSettings.AppSettings["Sitetitle"];
   this.txtUrl.Text=System.Configuration.ConfigurationSettings.AppSettings["SiteUrl"];
   this.txtLogo.Text=System.Configuration.ConfigurationSettings.AppSettings["SiteLogo"];
   this.txtBanner.Text=System.Configuration.ConfigurationSettings.AppSettings["SiteBanner"];
   this.txtEmail.Text=System.Configuration.ConfigurationSettings.AppSettings["SiteEmail"];
  }

 }
二、将修改后的内容写入Web.config


 private void btnSave_Click(object sender, System.EventArgs e)
 {
  string filename=Server.MapPath("web.config");
  string KeyName;//键名称

  XmlDocument  xmldoc= new XmlDocument();
  try
  {
   xmldoc.Load(filename);
  }
  catch
  {
   Response.Write("<script>alert('读文件时错误,请检查 Web.config 文件是否存在!')</script>");
   return;
  }
  
  XmlNodeList DocdNodeNameArr=xmldoc.DocumentElement.ChildNodes;//文档节点名称数组
  foreach(XmlElement DocXmlElement in DocdNodeNameArr)
  {
   if(DocXmlElement.Name.ToLower()=="appsettings")//找到名称为 appsettings 的节点
   {
    XmlNodeList KeyNameArr=DocXmlElement.ChildNodes;//子节点名称数组
    if ( KeyNameArr.Count >0 ) 
    {
     foreach(XmlElement xmlElement in KeyNameArr)
     {
      KeyName=xmlElement.Attributes["key"].InnerXml;//键值
      switch(KeyName)
      {
       case "Sitetitle":
        xmlElement.Attributes["value"].value=this.txttitle.Text;
        break;
       case "SiteUrl":
        xmlElement.Attributes["value"].value=this.txtUrl.Text;
        break;
       case "SiteLogo":
        xmlElement.Attributes["value"].value=this.txtLogo.Text;
        break;
       case "SiteBanner":
        xmlElement.Attributes["value"].value=this.txtBanner.Text;
        break;
       case "SiteEmail":
        xmlElement.Attributes["value"].value=this.txtEmail.Text;
        break;

      }
     }
    }
   }
  }
  try
  {
   xmldoc.Save(filename);
   Response.Write("<script>alert('OK,信息已保存!')</script>");
  }
  catch
  {
   Response.Write("<script>alert('写文件时错误,请检查 Web.config 文件是否存在!')</script>");
   return;
  }

 }



本文转自高海东博客园博客,原文链接:http://www.cnblogs.com/ghd258/archive/2005/10/19/257688.html,如需转载请自行联系原作者
相关文章
|
2月前
|
Java API 数据库
构建RESTful API已经成为现代Web开发的标准做法之一。Spring Boot框架因其简洁的配置、快速的启动特性及丰富的功能集而备受开发者青睐。
【10月更文挑战第11天】本文介绍如何使用Spring Boot构建在线图书管理系统的RESTful API。通过创建Spring Boot项目,定义`Book`实体类、`BookRepository`接口和`BookService`服务类,最后实现`BookController`控制器来处理HTTP请求,展示了从基础环境搭建到API测试的完整过程。
48 4
|
2月前
|
安全 测试技术 数据库
维护的Web应用程序
【10月更文挑战第4天】维护的Web应用程序
48 4
|
23天前
|
JavaScript 前端开发 开发工具
web项目规范配置(husky、eslint、lint-staged、commit)
通过上述配置,可以确保在Web项目开发过程中自动进行代码质量检查和规范化提交。Husky、ESLint、lint-staged和Commitlint共同作用,使得每次提交代码之前都会自动检查代码风格和语法问题,防止不符合规范的代码进入代码库。这不仅提高了代码质量,还保证了团队协作中的一致性。希望这些配置指南能帮助你建立高效的开发流程。
34 5
|
29天前
|
数据可视化 数据库 开发者
使用Dash构建交互式Web应用程序
【10月更文挑战第16天】本文介绍了使用Python的Dash框架构建交互式Web应用程序的方法。Dash结合了Flask、React和Plotly等技术,让开发者能够快速创建功能丰富的数据可视化应用。文章从安装Dash开始,逐步介绍了创建简单应用程序、添加交互元素、部署应用程序以及集成更多功能的步骤,并提供了代码示例。通过本文,读者可以掌握使用Dash构建交互式Web应用程序的基本技巧和高级功能。
43 3
|
2月前
|
JavaScript 前端开发
如何使用Vue.js构建响应式Web应用程序
【10月更文挑战第9天】如何使用Vue.js构建响应式Web应用程序
|
2月前
|
前端开发 JavaScript 测试技术
构建响应式Web应用程序:React实战指南
【10月更文挑战第9天】构建响应式Web应用程序:React实战指南
|
2月前
|
存储 JavaScript 前端开发
如何使用React和Redux构建现代化Web应用程序
【10月更文挑战第4天】如何使用React和Redux构建现代化Web应用程序
|
2月前
|
设计模式 测试技术 持续交付
开发复杂Web应用程序
【10月更文挑战第3天】开发复杂Web应用程序
39 2
|
2月前
|
JavaScript 前端开发 应用服务中间件
vue前端开发中,通过vue.config.js配置和nginx配置,实现多个入口文件的实现方法
vue前端开发中,通过vue.config.js配置和nginx配置,实现多个入口文件的实现方法
160 0
|
2月前
|
监控 Java Maven
springboot学习二:springboot 初创建 web 项目、修改banner、热部署插件、切换运行环境、springboot参数配置,打包项目并测试成功
这篇文章介绍了如何快速创建Spring Boot项目,包括项目的初始化、结构、打包部署、修改启动Banner、热部署、环境切换和参数配置等基础操作。
148 0