其他分享
首页 > 其他分享> > 项目的加密解密(1)

项目的加密解密(1)

作者:互联网

    public static class DESUtil
    {
        /// <summary>
        /// DES加密
        /// </summary>
        /// <param name="data">加密数据</param>
        /// <param name="key">8位字符的密钥字符串</param>
        /// <param name="iv">8位字符的初始化向量字符串</param>
        /// <returns></returns>
        public static string DESEncrypt(string data, string key, string iv="12345678")
        {
            //把字符串放到byte数组中
            DESCryptoServiceProvider des = new DESCryptoServiceProvider();
            byte[] inputByteArray = Encoding.Default.GetBytes(data);
            des.Key = Encoding.ASCII.GetBytes(key.Substring(0, 8)); //建立加密对象的密钥和偏移量
            des.IV = Encoding.ASCII.GetBytes(iv.Substring(0, 8)); //原文使用ASCIIEncoding.ASCII方法的GetBytes方法
            MemoryStream ms = new MemoryStream(); //使得输入密码必须输入英文文本
            try
            {
                CryptoStream cs = new CryptoStream(ms, des.CreateEncryptor(), CryptoStreamMode.Write);
                cs.Write(inputByteArray, 0, inputByteArray.Length);
                cs.FlushFinalBlock();
            }
            catch (Exception e) { Console.WriteLine(e.ToString()); }
            return Convert.ToBase64String(ms.ToArray());

        }

        /// <summary>
        /// DES解密
        /// </summary>
        /// <param name="data">解密数据</param>
        /// <param name="key">8位字符的密钥字符串(需要和加密时相同)</param>
        /// <param name="iv">8位字符的初始化向量字符串(需要和加密时相同)</param>
        /// <returns></returns>
        public static string DESDecrypt(string pToDecrypt, string sKey, string sIV = "12345678")
        {
            //byte[] byKey = System.Text.ASCIIEncoding.ASCII.GetBytes(key);
            //byte[] byIV = System.Text.ASCIIEncoding.ASCII.GetBytes(iv);

            //byte[] byEnc;
            //try
            //{
            //    byEnc = Convert.FromBase64String(data);
            //}
            //catch
            //{
            //    return null;
            //}

            //DESCryptoServiceProvider cryptoProvider = new DESCryptoServiceProvider();
            //MemoryStream ms = new MemoryStream(byEnc);
            //CryptoStream cst = new CryptoStream(ms, cryptoProvider.CreateDecryptor(byKey, byIV), CryptoStreamMode.Read);
            //StreamReader sr = new StreamReader(cst);
            //return sr.ReadToEnd();


            DESCryptoServiceProvider des = new DESCryptoServiceProvider();

            byte[] inputByteArray = Convert.FromBase64String(pToDecrypt);
            des.Key = Encoding.ASCII.GetBytes(sKey.Substring(0, 8)); //建立加密对象的密钥和偏移量
            des.IV = Encoding.ASCII.GetBytes(sIV.Substring(0, 8));
            string decrypt = "";

            using (MemoryStream ms = new MemoryStream())
            {
                using (CryptoStream cs = new CryptoStream(ms, des.CreateDecryptor(), CryptoStreamMode.Write))
                {
                    //cStream.Write(byteArray, 0, byteArray.Length);
                    //cStream.FlushFinalBlock();
                    cs.Write(inputByteArray, 0, inputByteArray.Length);
                    cs.FlushFinalBlock();
                    decrypt = Encoding.UTF8.GetString(ms.ToArray());


                }
            }





            //MemoryStream ms = new MemoryStream();
            //CryptoStream cs = new CryptoStream(ms, des.CreateDecryptor(), CryptoStreamMode.Write);

            //cs.Write(inputByteArray, 0, inputByteArray.Length);
            //cs.FlushFinalBlock();
            //cs.Close();
            //return System.Text.Encoding.Default.GetString(ms.ToArray());

            return decrypt;


        }


    }

做项目时,经常会遇到一个尾款的问题。

所以软件的到期验证十分必要,到期验证和加密解密十分相关。

这个是我个人的到期验证的一个思路做法。

首先获取一个唯一码。可以是机器码(CPU码,硬盘码等等),也可以是uuid。然后使用个人密码用函数DESEncrypt把到期日期加密。

需要使用时,再把这个到期时间解密出来。

这个方法算是比较简单的一个方法。好处是需要设置到期时间时,直接把加密后的数据给客户,让他直接注册就可以了。

 

不过,这个方法有一个很通常的问题。就是如果更改系统时间,这个方法就不起作用了。

标签:加密,string,项目,des,解密,ms,cs,new
来源: https://www.cnblogs.com/kuangzhuaikuxuandiaozhatian/p/16516187.html