C#窗体应用程序:添加配置文件连接数据库并保证数据库连接的安全

C#应用程序想要访问数据库要通过ADO.NET数据访问技术。所以有必要写一个类来对数据库中的信息进行增删改查——SQLHelper类。
在这里插入图片描述
但存在一个问题,连接字符串在编译后无法修改,即SQLHelper类所在的类库被编译为 .dll文件无法对此文件进行修改。
如果此程序安装到了其他主机上时,连接字符串是不一样的,这就导致了在其他主机上无法连接数据库。

解决方法: 添加一个配置文件
1、在项目的根目录下(UI层)中添加配置文件App.config 文件(标准的XMl格式文件)
在这里插入图片描述
在这里插入图片描述

编写配置文件:添加连接字符串
在这里插入图片描述
即:


2、在UI层添加引用:程序集➡System.Configuration
在这里插入图片描述
在这里插入图片描述

3、在SQLHelper类中添加 using System.Configuration; 这样就可以调用配置文件中的连接字符串了;
ConfigurationManager.ConnectionString[“连接字符串名”]
在这里插入图片描述

这样就完成了配置文件的添加与应用。可以在项目文件夹下找到此配置文件
在这里插入图片描述
可打开查看编辑
在这里插入图片描述
但是这样就使得连接数据库字符串的信息暴露了,有的人使用的连接字符串包含连接数据库的账号密码,导致了数据库连接的不安全。
所以还要再添加一个加密解密类,对其config文件中的关键信息进行加密,在读取config文件时进行解密。此类可在网上找,也可自行编写。
我就编写了一个简单加密解密类:
public class En_Decryption
{
private const int key = 5;
private string encrypted_code;
private string decrypted_code;

    //获得加密字符串
    public string GetEncrypted_Code(string code)
    {
        encrypted_code = "";
        
        for(int i=0;i<code.Length;i++)
        {
            encrypted_code += (char)(code[i] + i + key);
        }

        return encrypted_code;
    }

    //获得解密字符串
    public string GetDecrypted_Code(string code)
    {
        decrypted_code = "";

        for(int i=0;i<code.Length;i++)
        {
            decrypted_code += (char)(code[i] - i - key);
        }

        return decrypted_code;
    }


}

}

将加密的字符串放到配置文件中
在这里插入图片描述

在SQLHelper类中的连接字符串用配置文件中的解了密的连接字符串进行赋值
在这里插入图片描述

  • 1
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
C# 读取保存App.config配置文件的完整源码参考(转) http://smartsoft.5d6d.com/thread-6550-1-1.html C# 读取保存App.config配置文件的完整源码参考 最近出差在北京做一个小项目,项目里需要读取配置文件的小功能,觉得挺有参考意义的就把代码发上来给大家参考一下。我们选择了直接用微软的读取配置文件的方法。 这个是程序的运行设计效果,就是把这些参数可以进行灵活设置,灵活保存设置状态。 程序编译后自动会产生相应的配置文件,是跟项目的名称一样的配置文件。 读取配置文件及保存配置的具体代码参考如下,希望能给你节省一些时间,直接复制粘贴这个代码就可以用了: //------------------------------------------------------------ // All Rights Reserved , Copyright (C) 2010 , CDPF , Ltd. //------------------------------------------------------------ using System; using System.Configuration; using System.Windows.Forms; using Utilities; namespace DirectSeeding { /// /// FrmConfig /// 读取配置文件 /// /// 修改纪录 /// /// 2011.01.14 版本: 1.0 JiRiGaLa 完善程序的注释等、从新整理代码。 /// /// 版本:1.0 /// /// /// JiRiGaLa /// 2011.01.14 /// /// public partial class FrmConfig : Form { public FrmConfig() { InitializeComponent(); } /// /// 读取配置文件 /// private void GetConfig() { this.txtWriteFileName.Text = ConfigurationManager.AppSettings["WriteFileName"]; this.txtWritePath.Text = ConfigurationManager.AppSettings["WritePath"].Replace("|", Environment.NewLine); this.txtPostMessageURL.Text = ConfigurationManager.AppSettings["PostMessageURL"]; this.txtLeasedLineURL.Text = ConfigurationManager.AppSettings["LeasedLineURL"]; } private void FrmDirectSeeding_Load(object sender, EventArgs e) { this.GetConfig(); } /// /// 保存配置文件 /// private void SaveConfig() { // 写入参数设置 Configuration configuration = ConfigurationManager.OpenExeConfiguration(ConfigurationUserLevel.None); configuration.AppSettings.Settings["WriteFileName"].Value = this.txtWriteFileName.Text; configuration.AppSettings.Settings["Wri
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值