基本信息
源码名称:C# 伪随机数加密 实例
源码大小:0.04M
文件格式:.zip
开发语言:C#
更新时间:2013-01-29
   友情提示:(无需注册或充值,赞助后即可获取资源下载链接)

     嘿,亲!知识可是无价之宝呢,但咱这精心整理的资料也耗费了不少心血呀。小小地破费一下,绝对物超所值哦!如有下载和支付问题,请联系我们QQ(微信同号):813200300

本次赞助数额为: 2 元 
   源码介绍

伪随机数加密


    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }

        private void button1_Click(object sender, EventArgs e)
        {
            if (textBox3.Text != "")
            {
                if (DecryptPwd(textBox3.Text) == textBox2.Text)
                    MessageBox.Show("用户登录成功!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
                else
                    MessageBox.Show("用户密码错误!", "错误", MessageBoxButtons.OK, MessageBoxIcon.Error);
            }
        }

        private void button2_Click(object sender, EventArgs e)
        {
            textBox1.Text = textBox2.Text = textBox3.Text = string.Empty;
            textBox2.Focus();
        }

        private void textBox2_TextChanged(object sender, EventArgs e)
        {
            textBox3.Text = EncryptPwd(textBox2.Text);
        }

        //定义加密用户密码所用的伪随机数
        private string randStr = "ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789abcdefghijklmnopqrstuvwxyz";

        #region 使用伪随机数加密用户登录密码
        /// <summary>
        /// 使用伪随机数加密用户登录密码
        /// </summary>
        /// <param name="str">用户登录密码</param>
        /// <returns>加密后的用户登录密码</returns>
        private string EncryptPwd(string str)
        {
            byte[] btData = Encoding.Default.GetBytes(str);
            int j, k, m;
            int len = randStr.Length;
            StringBuilder sb = new StringBuilder();
            Random rand = new Random();
            for (int i = 0; i < btData.Length; i  )
            {
                j = (byte)rand.Next(6);
                btData[i] = (byte)((int)btData[i] ^ j);
                k = (int)btData[i] % len;
                m = (int)btData[i] / len;
                m = m * 8   j;
                sb.Append(randStr.Substring(k, 1)   randStr.Substring(m, 1));
            }
            return sb.ToString();
        }
        #endregion

        #region 解密用户登录密码
        /// <summary>
        /// 解密用户登录密码
        /// </summary>
        /// <param name="str">经过加密的用户登录密码</param>
        /// <returns>解密后的用户登录密码</returns>
        private string DecryptPwd(string str)
        {
            try
            {
                int j, k, m, n = 0;
                int len = randStr.Length;
                byte[] btData = new byte[str.Length / 2];
                for (int i = 0; i < str.Length; i  = 2)
                {
                    k = randStr.IndexOf(str[i]);
                    m = randStr.IndexOf(str[i   1]);
                    j = m / 8;
                    m = m - j * 8;
                    btData[n] = (byte)(j * len   k);
                    btData[n] = (byte)((int)btData[n] ^ m);
                    n  ;
                }
                return Encoding.Default.GetString(btData);
            }
            catch { return ""; }
        }
        #endregion
    }