WebForm读取指定的config文件的内容

需求:

什么时候会用到动态改变Web.config内的值?
在Web.config定义了一个全局设置值A,因为程序运行中满足了某个条件,要将A的值改变

Web.config中定义:

  <appSettings>
    <add key="IsChangeDb" value="false"/>
  </appSettings>

 

获取Web.config中指定配置:

//获取web.config中 定义在appSetting中定义的配置
var item = ConfigurationManager.AppSettings["IsChangeDb"];

//根据我自己的需要转换成bool值
bool isChangeDb = string.IsNullOrEmpty(ConfigurationManager.AppSettings["IsChangeDb"]) ? false : bool.Parse(ConfigurationManager.AppSettings["IsChangeDb"]);

 

代码中更改Web.config中指定配置:


Configuration config=System.Web.Configuration.WebConfigurationManager.OpenWebConfiguration("~");
config.AppSettings.Settings.Remove("IsChangeDb");
config.AppSettings.Settings.Add("IsChangeDb", "true");
config.Save();

 

参考资料:

http://stackoverflow.com/questions/719928/how-do-you-modify-the-web-config-appsettings-at-runtime

 

 

出处:https://blog.csdn.net/qq_32452623/article/details/53580093

============================================================================

asp.net2.0新添加了对web.config直接操作的功能。开发的时候有可能用到在web.config里设置配置文件,其实是可以通过程序来设置这些配置节的。

asp.net2.0需要添加引用:

using System.Web.Configuration;

web.config里的配置节:

Code
  <appSettings>
    
<add key="FilePath" value="g:\Test\WebConfigManager\Upload\" />
    
<add key="p" value="g:\" />
  
</appSettings>

(1)读

string  filepath  =  ConfigurationManager.AppSettings[ " FilePath " ];
 
(2)添加
        Configuration config  =  WebConfigurationManager.OpenWebConfiguration( " /WebConfigManager " );
        AppSettingsSection app 
=  config.AppSettings;
        app.Settings.Add(
" p " " p:\\ " );
        config.Save(ConfigurationSaveMode.Modified);
 
(3)修改
          Configuration config  =  WebConfigurationManager.OpenWebConfiguration( " /WebConfigManager " );
            AppSettingsSection app 
=  config.AppSettings;
            app.Settings[
" p " ].Value  =   @" g:\ " ;
            config.Save(ConfigurationSaveMode.Modified);
 
(4)删除
Configuration config  =  WebConfigurationManager.OpenWebConfiguration( " /WebConfigManager " );
        AppSettingsSection app 
=  config.AppSettings;
        app.Settings.Remove(
" p " );
        config.Save(ConfigurationSaveMode.Modified);
 
 
 
注意:
(1)asp.net用户需要有读取、修改、写入的权限。
(2) WebConfigManager是web.config所在的文件夹名。

 

出处:https://www.cnblogs.com/xxtkong/archive/2011/10/14/2211793.html

==============================================================================

通过从网上的了解,和学习,我们看到ConfigurationManager.OpenMappedExeConfiguration这个方法可以用于打开指定的配置文件,那么看看我们用它来做一些事情吧,下面看代码:

using System;
using System.Collections.Generic;
using System.Configuration;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Web.Configuration;



namespace PVG.Lib.Configs
{
    public class WebConfigHelper
    {
        /// <summary>
        /// 是否加密连接字符串
        /// </summary>
        public bool IsEncryptionConnection { get; set; }

        private Configuration config = null;
        public Configuration Configuration
        {
            get { return config; }
            set { config = value; }
        }



        public WebConfigHelper()
        {
            config = WebConfigurationManager.OpenWebConfiguration("~");
        }


        /// <summary>
        /// 读取ConnectionStrings
        /// </summary>
        /// <param name="ConnName"></param>
        /// <returns></returns>
        public string GetConnectionStrings(string ConnName)
        {
            string res = "";
            if (config != null && config.ConnectionStrings.ConnectionStrings[ConnName] != null)
                res = config.ConnectionStrings.ConnectionStrings[ConnName].ConnectionString;
            return res;
        }

        public string SetConnectionStrings(string ConnName, string ConnValue)
        {
            return SetConnectionStrings(ConnName, ConnValue, "");
        }

        public string SetConnectionStrings(string ConnName, string ConnValue, string providerName)
        {
            if (config != null)
            {
                if (config.ConnectionStrings.ConnectionStrings[ConnName] != null)
                    config.ConnectionStrings.ConnectionStrings[ConnName].ConnectionString = ConnValue;
                else
                    config.ConnectionStrings.ConnectionStrings.Add(new ConnectionStringSettings(ConnName, ConnValue, providerName));
                config.Save(ConfigurationSaveMode.Modified);
            }
            if (IsEncryptionConnection)
                encryptionConn();//加密配置项
            return GetConnectionStrings(ConnName);

        }


        public string GetAppSettings(string keyName)
        {
            string res = "";
            if (config != null && config.AppSettings.Settings[keyName] != null)
                res = config.AppSettings.Settings[keyName].Value;
            return res;
        }


        public string SetAppSettings(string keyName, string keyValue)
        {
            if (config != null)
            {
                if (config.AppSettings.Settings[keyName] != null)
                    config.AppSettings.Settings[keyName].Value = keyValue;
                else
                    config.AppSettings.Settings.Add(keyName, keyValue);
                config.Save(ConfigurationSaveMode.Modified);
            }
            return GetAppSettings(keyName);

        }


        private void encryptionConn()
        {

            ConfigurationSection connectionSection = config.GetSection("connectionStrings");
            if (connectionSection != null)
            {
                connectionSection.SectionInformation.ProtectSection("RSAProtectedConfigurationProvider");
                config.Save();
            }
        }

    }
}
View Code

 

WebForm可以通过使用ASP.NET的GridView控件实现对CSV文件读取和分类显示。以下是一些基本步骤: 1. 在WebForm上添加GridView控件。可以通过Visual Studio的工具箱将GridView控件拖动到WebForm上。 2. 创建一个数据源,用于从CSV文件读取数据。可以使用OleDbDataReader或CsvDataReader等类来读取CSV文件。以下是CsvDataReader的一个示例: ```csharp using (var reader = new CsvDataReader(csvFilePath)) { var dt = new DataTable(); dt.Load(reader); GridView1.DataSource = dt; GridView1.DataBind(); } ``` 3. 对数据进行分类。可以使用GridView控件的排序和筛选功能来对数据进行分类。也可以通过编写自定义代码来实现分类。以下是一个基本的示例,它使用LINQ查询对数据进行分类: ```csharp using (var reader = new CsvDataReader(csvFilePath)) { var dt = new DataTable(); dt.Load(reader); var groupedData = from row in dt.AsEnumerable() group row by row.Field<string>("Category") into grp select new { Category = grp.Key, Count = grp.Count() }; GridView1.DataSource = groupedData; GridView1.DataBind(); } ``` 这个示例将CSV文件的数据按照“Category”列进行分类,并计算每个分类的数据行数。然后,它将分类数据绑定到GridView控件上,以显示每个分类的行数。 4. 运行WebForm应用程序并查看结果。在浏览器打开WebForm应用程序,GridView控件将显示CSV文件的数据,并根据分类方式进行排序。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值