使用配置文件(.settings、.config)存储应用程序配置

image 引言

我不知大家早先是如何保存应用程序配置,以备下次打开时使用的,反正我开始学.Net的时候就去研究序列化,以二进制或XML格式的序列化来保存应用程序配置。这样每次都要建立单独的配置类,并书写读写配置代码,相当麻烦。

期间也看了看.config文件的读写方式,感觉还是很麻烦,不如自己序列化来的踏实。

后来才猛然发现微软早提供好了settings,用以定义.config文件内容,并生成相应的强类型类,使用起来极其方便~,感觉就像在火星居住了半辈子突然发现还有地球这好地方*_*~

鉴于网上settings方面的资料不多、不详,我就以此文来介绍一下基本的用法,让小鸟们少走我那条破路,老鸟请直接从上空滑翔而过即可。

 

基本使用方法

首先建立一个WinForm项目,设计这样一个窗体:

image

通过“添加新项”功能添加一个MyApp.settings:

 image

 

 

 

在打开的数据表格中做如下设置:

image

这样就设置好了a、b、c三个不同类型的配置变量,现在就可以在程序中使用它们了:

 

private void Form1_Load(object sender, EventArgs e)

{

    numericUpDown1.Value = MyApp.Default.a;

    textBox1.Text = MyApp.Default.b;

    checkBox1.Checked = MyApp.Default.c;

}

 

private void Form1_FormClosing(object sender, FormClosingEventArgs e)

{

    MyApp.Default.a = numericUpDown1.Value;

    MyApp.Default.b = textBox1.Text;

    MyApp.Default.c = checkBox1.Checked;

    MyApp.Default.Save();

}

 

通过上面的代码就可以在窗体开闭时分别加载、保存配置了。

运行抓图:

image

 

复杂数据类型支持情况

settings支持存储一些较为复杂的数据,比如Color、Size等类型,可以自行选择:

image

但并不是所有类型都可以支持,比如FileInfo类型就没有,泛型也没有,自定义类型更是不受支持的,如果需要存储这些特殊类型,就得用其他配置方案了。

 

读写复杂数据类型

我们以ArrayList类型为例,通过它在原程序的基础上实现记录每次关闭程序时间的功能。

首先添加一个配置变量d,其类型为System.Collections.ArrayList:

image

在窗体中增加一个ListBoxt,然后修改后台代码为:

image

高亮部分为新增的代码。

多次运行以测试:

image

 可以看到每次的程序关闭时间都被记录并显示。

 

“用户”和“应用程序”

你可能注意到数据表格中“范围”这里全是“用户”:

image

如果改成另外一个选项,即“应用程序”会怎样呢?

image

报错了,我们的配置变量变成只读的了,所以这里可以简单地把它们理解为:

用户=可读写

应用程序=只读

“应用程序”选项应当是用于设定一些程序运行所必须的重要变量,比如导航网址、数学运算参数等,这些配置项如果让用户篡改就会出问题了,所以要只读。

 

数据被存在哪里?

你可能会发现编译后在Debug目录中有个“SettingTest.exe.config”,但无论如何操作程序,这个配置文件里始终都是描述的默认配置。

其实数据是被存在了“C:\Users\SkyD\AppData\Local\”目录中(我这是Windows7,XP或以下版本可能不是这里)

我在“C:\Users\SkyD\AppData\Local\SettingTest\SettingTest.vshost.exe_Url_ffofch2tvz5bil2xbhdayqbnqwppy2ce\1.0.0.0”这个目录中找到了配置文件(user.config),这是其描述的配置信息:

image

 

结语

虽然settings无法实现对一些复杂类型及自定义类型的支持,但是在多数情况下,用它来存储程序配置已是绰绰有余了,在够用的前提下,不要重复造轮子啦。


下载示例项目:http://www.uushare.com/user/icesee/file/2017630

下载本文的XPS版本:http://www.uushare.com/user/icesee/file/2017629

转载请遵循此协议:署名 - 非商业用途 - 保持一致

并保留此链接:http://skyd.cnblogs.com/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Portainer的配置文件settings.json的内容如下: { "app": { "analytics": false, "hide_labels": false, "logo": "", "logo_dark": "", "logo_mini": "", "page_size": 10, "snapshot_interval": 0, "ssl": false, "ssl_cert": "", "ssl_key": "", "template_upload": true, "theme": "", "title": "", "update_notification": true }, "auth": { "ldap": { "enabled": false, "debug": false, "config_file": "", "url": "", "starttls": false, "tls_ca_cert": "", "tls_client_cert": "", "tls_client_key": "", "tls_client_insecure_skip_verify": false, "search_dn": "", "search_password": "", "search_filter": "", "group_search_dn": "", "group_search_filter": "", "group_search_attribute": "", "group_membership_attribute": "", "group_dn_attribute": "", "group_filter_enabled": false, "group_filter": "", "auto_create_users": true, "auto_create_admin": true, "user_attribute_mappings": {}, "group_attribute_mappings": {}, "debug_bind": false, "debug_search": false }, "oauth": { "enabled": false, "debug": false, "config_file": "", "client_id": "", "client_secret": "", "scopes": "", "auth_url": "", "token_url": "", "api_url": "", "callback_url": "", "auto_create_users": true, "auto_create_admin": true, "user_attribute_mappings": {} }, "azuread": { "enabled": false, "debug": false, "config_file": "", "client_id": "", "client_secret": "", "tenant_id": "", "scopes": "", "auth_url": "", "token_url": "", "api_url": "", "callback_url": "", "auto_create_users": true, "auto_create_admin": true, "user_attribute_mappings": {} }, "jwt": { "enabled": false, "debug": false, "secret": "thisisasecret", "algorithm": "HS256", "expiration": 86400, "header_name": "Authorization", "header_prefix": "Bearer" } }, "data": { "data_location": "", "sync_interval": 60, "templates_url": "https://templates.portainer.io", "templates_check_for_update": true, "registry_credentials": [], "extensions": [], "extensions_check_for_update": true, "azure_credentials": [], "tls_ca_certificates": [], "tls_client_certs": [], "tls_client_keys": [] }, "endpoints": { "azure": [], "docker": [], "edge": [] }, "integrations": { "agent": { "enabled": true, "endpoint": "", "public_url": "", "tls": false, "tls_ca_cert": "", "tls_client_cert": "", "tls_client_key": "" }, "azuremonitor": { "enabled": false, "debug": false, "config_file": "", "subscription_id": "", "client_id": "", "client_secret": "", "tenant_id": "", "log_analytics_workspace_id": "", "log_analytics_workspace_key": "", "metrics": { "enabled": true, "interval": 60, "retention": 30, "metrics": [ { "type": "cpu", "aggregation": "Average", "dimension": "ContainerName" }, { "type": "memory", "aggregation": "Average", "dimension": "ContainerName" }, { "type": "network", "aggregation": "Total", "dimension": "ContainerName" } ] }, "logs": { "enabled": true, "interval": 60, "retention": 30, "log_template": "{\"time\": \"{{.Timestamp}}\", \"level\": \"{{.Level}}\", \"message\": \"{{.Message}}\", \"container\": \"{{.ContainerName}}\", \"image\": \"{{.ImageName}}\", \"instance\": \"{{.InstanceID}}\"}" } }, "cicd": { "enabled": false, "debug": false, "config_file": "", "gitlab": { "base_url": "", "token": "", "auto_deploy_on_push": true, "auto_deploy_on_merge_request": false, "auto_deploy_on_tag": false, "auto_deploy_on_release": false, "auto_remove_stacks": false }, "github": { "base_url": "", "token": "", "auto_deploy_on_push": true, "auto_deploy_on_pull_request": false, "auto_deploy_on_tag": false, "auto_deploy_on_release": false, "auto_remove_stacks": false }, "bitbucket": { "base_url": "", "username": "", "app_password": "", "auto_deploy_on_push": true, "auto_deploy_on_pull_request": false, "auto_deploy_on_tag": false, "auto_deploy_on_release": false, "auto_remove_stacks": false } } }, "labels": [], "registries": [], "settings_version": 2, "snapshot": { "schedule": "", "keep": 5 }, "telemetry": { "enabled": true } } 这是一个JSON格式的文件,包含了Portainer的各种配置项,例如应用程序的设置、认证方式、数据存储位置、终端节点、集成等等。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值