加密解密
来源:互联网 发布:随机点名软件 编辑:程序博客网 时间:2024/05/16 16:16
取得机器CPU的ID的前八位作为密钥:
using System.Security .Cryptography;
using System.Management;
public static string GetProcessID()
{
try
{
string str1 = string.Empty;
ManagementClass mcCpu = new ManagementClass("win32_Processor");
ManagementObjectCollection mocCpu = mcCpu.GetInstances();
foreach (ManagementObject m in mocCpu)
{
str1 = m["ProcessorId"].ToString().Trim().Substring(0, 8);
}
return str1;
}
catch (Exception ex)
{
return "zhenxing"; //如果失败取默认的密钥
}
}
----------------------------------
加密算法
public static string Encode(string data)
{
byte[] aKey = System.Text.ASCIIEncoding.ASCII.GetBytes(GetProcessID());
byte[] aIV = System.Text.ASCIIEncoding.ASCII.GetBytes(GetProcessID());
DESCryptoServiceProvider cp = new DESCryptoServiceProvider();
MemoryStream ms = new MemoryStream();
CryptoStream cs = new CryptoStream(ms, cp.CreateEncryptor(aKey, aIV), CryptoStreamMode.Write);
StreamWriter sw = new StreamWriter(cs);
sw.Write(data);
sw.Flush();
cs.FlushFinalBlock();
sw.Flush();
return Convert.ToBase64String(ms.GetBuffer(), 0, (int)ms.Length);
}
------------------------------------------------------
解密
public static string Decode(string data)
{
byte[] aKey = System.Text.ASCIIEncoding.ASCII.GetBytes(GetProcessID());
byte[] aIV = System.Text.ASCIIEncoding.ASCII.GetBytes(GetProcessID());
byte[] Enc;
try
{
Enc = Convert.FromBase64String(data);
}
catch(Exception ex)
{
return null;
}
try
{
DESCryptoServiceProvider cp = new DESCryptoServiceProvider();
MemoryStream ms = new MemoryStream(Enc);
CryptoStream cs = new CryptoStream(ms, cp.CreateDecryptor(aKey, aIV), CryptoStreamMode.Read);
StreamReader sr = new StreamReader(cs);
return sr.ReadToEnd();
}
catch(Exception ex)
{
throw ex;
}
}
- 加密解密
- 加密解密
- 加密解密
- 加密解密
- 加密解密
- 加密解密
- 加密、解密
- 加密解密
- 加密解密
- 加密解密
- 加密解密
- 加密解密
- 加密解密
- 加密解密
- 加密解密
- 加密解密
- 加密解密
- 加密解密
- 为什么要使用设计模式
- Realtime Rendering 3rd笔记 8
- ext 另类导出excel 只导出显示的列
- C#生成Word文档
- 我开博啦,欢迎光临
- 加密解密
- 数据导出到Excel的方法C#
- SqlTransaction
- C# 插件构架实战
- apk调用so库的问题
- 菜鸟!请求高手们帮助!
- 关于m_pMainWnd = &dlg错误……
- oracle 的wmsys.wm_concat函数用法
- ORACLE数据库中创建、删除--同义词、视图、索引、序列