利用程序动态管理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天前
|
安全 JavaScript Java
AppSpider Pro 7.5.015 for Windows - Web 应用程序安全测试
AppSpider Pro 7.5.015 for Windows - Web 应用程序安全测试
20 12
AppSpider Pro 7.5.015 for Windows - Web 应用程序安全测试
|
17天前
|
开发工具 git 索引
怎么取消对project.private.config.json这个文件的git记录
通过以上步骤,您可以成功取消对 `project.private.config.json`文件的Git记录。这样,文件将不会被包含在未来的提交中,同时仍保留在您的工作区中。
58 28
|
3月前
|
监控 前端开发 JavaScript
使用 MERN 堆栈构建可扩展 Web 应用程序的最佳实践
使用 MERN 堆栈构建可扩展 Web 应用程序的最佳实践
59 6
|
3月前
|
开发框架 搜索推荐 数据可视化
Django框架适合开发哪种类型的Web应用程序?
Django 框架凭借其强大的功能、稳定性和可扩展性,几乎可以适应各种类型的 Web 应用程序开发需求。无论是简单的网站还是复杂的企业级系统,Django 都能提供可靠的支持,帮助开发者快速构建高质量的应用。同时,其活跃的社区和丰富的资源也为开发者在项目实施过程中提供了有力的保障。
159 62
|
3月前
|
JavaScript 前端开发 开发工具
web项目规范配置(husky、eslint、lint-staged、commit)
通过上述配置,可以确保在Web项目开发过程中自动进行代码质量检查和规范化提交。Husky、ESLint、lint-staged和Commitlint共同作用,使得每次提交代码之前都会自动检查代码风格和语法问题,防止不符合规范的代码进入代码库。这不仅提高了代码质量,还保证了团队协作中的一致性。希望这些配置指南能帮助你建立高效的开发流程。
111 5
|
3月前
|
数据可视化 数据库 开发者
使用Dash构建交互式Web应用程序
【10月更文挑战第16天】本文介绍了使用Python的Dash框架构建交互式Web应用程序的方法。Dash结合了Flask、React和Plotly等技术,让开发者能够快速创建功能丰富的数据可视化应用。文章从安装Dash开始,逐步介绍了创建简单应用程序、添加交互元素、部署应用程序以及集成更多功能的步骤,并提供了代码示例。通过本文,读者可以掌握使用Dash构建交互式Web应用程序的基本技巧和高级功能。
126 3
|
4月前
|
JavaScript 前端开发 应用服务中间件
vue前端开发中,通过vue.config.js配置和nginx配置,实现多个入口文件的实现方法
vue前端开发中,通过vue.config.js配置和nginx配置,实现多个入口文件的实现方法
271 0
|
4月前
|
Java API 数据库
构建RESTful API已经成为现代Web开发的标准做法之一。Spring Boot框架因其简洁的配置、快速的启动特性及丰富的功能集而备受开发者青睐。
【10月更文挑战第11天】本文介绍如何使用Spring Boot构建在线图书管理系统的RESTful API。通过创建Spring Boot项目,定义`Book`实体类、`BookRepository`接口和`BookService`服务类,最后实现`BookController`控制器来处理HTTP请求,展示了从基础环境搭建到API测试的完整过程。
79 4
|
4月前
|
JavaScript 前端开发
如何使用Vue.js构建响应式Web应用程序
【10月更文挑战第9天】如何使用Vue.js构建响应式Web应用程序
|
4月前
|
前端开发 JavaScript 测试技术
构建响应式Web应用程序:React实战指南
【10月更文挑战第9天】构建响应式Web应用程序:React实战指南

热门文章

最新文章