[恶心]数据库连接串加密

[恶心]数据库连接串加密

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Data.Common;

namespace System.Data
{
    /// <summary>
    /// MultipleActiveResultSets=True;
    /// </summary>
    [Serializable]
    public sealed class ConnectionStringBuilder : DbConnectionStringBuilder
    {
        #region Properties
        public bool IsEncrypt
        {
            get { return base.ContainsKey("KEY"); }
        }
        public string[] CryptoKeys
        {
            set
            {
                if (value.Length < 2)
                {
                    throw new ArgumentException("value.Length < 2");
                }
                base["KEY"] = string.Join(DbUtility.Separator, value);
            }
            get
            {
                object value;
                if (base.TryGetValue("KEY", out value))
                {
                    string[] args = value.ToString().Split(DbUtility.Separator[0]);
                    if (args.Length >= 2)
                    {
                        return args;
                    }
                }
                return new string[2];
            }
        }
        #endregion

        #region Methods
        public ConnectionStringBuilder()
        {

        }
        public ConnectionStringBuilder(string connectionString)
        {
            base.ConnectionString = connectionString;
        }

        internal string GetDecrypt()
        {
            if (this.IsEncrypt)
            {
                string[] args = this.CryptoKeys;
                using (CryptoManaged coder = new CryptoManaged(args[0], args[1]))
                {
                    return coder.Decrypt(base["ENTITY"].ToString());
                }
            }
            return base.ConnectionString;
        }
        public override string ToString()
        {
            if (this.IsEncrypt)
            {
                string[] args = this.CryptoKeys;
                using (CryptoManaged coder = new CryptoManaged(args[0], args[1]))
                {
                    base.Remove("KEY");
                    string oldString = base.ConnectionString;
                    base.Clear();
                    base["ENTITY"] = coder.Encrypt(oldString);
                    this.CryptoKeys = args;
                    string newString = base.ToString().Replace("\"", string.Empty);
                    base.ConnectionString = oldString;
                    this.CryptoKeys = args;
                    return newString;
                }
            }
            return base.ToString();
        }
        #endregion
    }
}
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;

namespace Rocky.App
{
    public partial class ConnectionStringForm : Form
    {
        private ConnectionStringBuilder builder;

        public ConnectionStringForm()
        {
            InitializeComponent();
        }

        private void ConnectionStringForm_Load(object sender, EventArgs e)
        {
            builder = new ConnectionStringBuilder();
        }

        private void textBox1_Enter(object sender, EventArgs e)
        {
            if (Clipboard.ContainsText())
            {
                textBox1.Text = Clipboard.GetText();
            }
        }

        private void button1_Click(object sender, EventArgs e)
        {
            builder.ConnectionString = textBox1.Text;
            builder.CryptoKeys = new string[] { CryptoManaged.MD5Hex("Rocky.TBox"), CryptoManaged.NewSalt };
            textBox2.Text = builder.ToString();
        }
    }
}
View Code

 

  <connectionStrings>
    <add name="access" connectionString="Provider=Microsoft.Jet.OLEDB.4.0;Data Source=|DataDirectory|#xfjob.mdb" providerName="System.Data.OleDb"/>
  </connectionStrings>
View Code

 

posted on 2013-07-25 19:23 RockyLOMO 阅读(...) 评论(...) 编辑 收藏

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值