项目的加密解密(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把到期日期加密。
需要使用时,再把这个到期时间解密出来。
这个方法算是比较简单的一个方法。好处是需要设置到期时间时,直接把加密后的数据给客户,让他直接注册就可以了。
不过,这个方法有一个很通常的问题。就是如果更改系统时间,这个方法就不起作用了。
分类:
C#
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现