App.config中的数据库连接字符串,是在Settings.settings同步过来的。后者在设计时支持数据集DataSet的设计,但运行时不能更改,可以更改App.config的连接字符串,但无法加密、解密。造成的结果是数据库连接字符串,要么固定不变,要么以明文显示,极不安全。
Settings.settings中的设置和App.config中的设置会相互更新,彼此同步。前者用于设计支持,后者用于运行时。可以手工阻止两者同步,使两者设置不一样,如果没有发布App.config,则全部采用Settings.settings的设置;否则在运行时App.config会覆盖Settings.settings的设置。
上述文字证明我的测试,但为了将来能有使用Config中的其他设置,于是采用下面的办法:在设计时就选择不输入密码,而由我在应用程序中完成相关设置,于是应用程序同名的Config文件中保存了如下信息
<?xml version="1.0" encoding="utf-8" ?>
<configuration>
<configSections>
</configSections>
<connectionStrings>
<add name="YaoHuoDingDanDaYin.Properties.Settings.XSSystemConnectionString"
connectionString="Data Source=10.108.0.1;Initial Catalog=XSSystem;Persist Security Info=True;User ID=ERPYAOHUODINGDANPRINTUSER"
providerName="System.Data.SqlClient" />
</connectionStrings>
</configuration>
Form_Load事件中
this.View_ERP_STOCKYaoHuoDingDan_DAYINTableAdapter.Connection.ConnectionString = "Data Source=10.108.0.1;Initial Catalog=XSSystem;Persist Security Info=True;User ID=ERPYAOHUODINGDANPRINTUSER;Password=********";
this.View_ERP_STOCKYaoHuoDingDan_DAYINTableAdapter.FillByAllDingDanData(this.XSSystem_YaoHuoDingDanDaYin_DataSet.View_ERP_STOCKYaoHuoDingDan_DAYIN);
this.reportViewerDingDanDaYin.RefreshReport();
有了这样的方法,自己加密密码可以很容易地实现了.