ASP.NET WebConfig读写辅助类

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/a497785609/article/details/82684657
using System.Configuration;
using System.Web;
using System.Web.Configuration;

namespace RC.Website.FileManage.Controllers
{
    /// <summary>
    ///     ASP.NET 配置文件写辅助类
    /// </summary>
    public class ConfigurationHelper
    {
        /// <summary>
        ///     读取链接字符串
        /// </summary>
        /// <param name="key"></param>
        /// <returns></returns>
        public string GetConnectionString(string key = "")
        {
            var setting = ConfigurationManager.ConnectionStrings;
            if (key.Length == 0 && setting.Count > 0) return setting[0].ConnectionString;
            return setting[key] == null ? string.Empty : setting[key].ConnectionString;
        }

        /// <summary>
        ///     设置数据库连接字符串节点,如果不存在此节点,则会添加此节点及对应的值;存在则修改
        /// </summary>
        /// <param name="key"></param>
        /// <param name="connectionString"></param>
        public void SetConnectionString(string key, string connectionString)
        {
            var config = WebConfigurationManager.OpenWebConfiguration(HttpContext.Current.Request.ApplicationPath);
            var connectionSetting = (ConnectionStringsSection) config.GetSection("connectionStrings");
            if (connectionSetting.ConnectionStrings[key] == null)
            {
                var connectionStringSettings = new ConnectionStringSettings(key, connectionString);
                connectionSetting.ConnectionStrings.Add(connectionStringSettings);
            }
            else
            {
                connectionSetting.ConnectionStrings[key].ConnectionString = connectionString;
            }

            config.Save();
        }

        #region AppSetting读写

        /// <summary>
        ///     设置应用程序配置节点,如果已经存在此节点,则会修改该节点的值;否则添加此节点
        /// </summary>
        /// <param name="key">节点名称</param>
        /// <param name="value">节点值</param>
        public void SetAppSetting(string key, string value)
        {
            var config = WebConfigurationManager.OpenWebConfiguration(HttpContext.Current.Request.ApplicationPath);
            var appSetting = (AppSettingsSection) config.GetSection("appSettings");
            if (appSetting.Settings[key] == null)
                appSetting.Settings.Add(key, value);
            else
                appSetting.Settings[key].Value = value;

            config.Save();
        }

        /// <summary>
        ///     读取节点值
        /// </summary>
        /// <param name="key"></param>
        /// <returns></returns>
        public string GetAppSetting(string key)
        {
            return ConfigurationManager.AppSettings[key] ?? string.Empty;
        }

        #endregion
    }
}

调用方式:

ConfigurationHelper helper = new ConfigurationHelper();
helper.SetAppSetting("siteName", name);
helper.SetAppSetting("userName", loginName);
helper.SetAppSetting("password", password);
helper.SetAppSetting("installDate", DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"));
helper.SetConnectionString("sqlserver", connectionString);

猜你喜欢

转载自blog.csdn.net/a497785609/article/details/82684657