博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
c#进行MD5加密方式和解密算法
阅读量:6683 次
发布时间:2019-06-25

本文共 2558 字,大约阅读时间需要 8 分钟。

原文:

 

 

 

--------------- 因为加密个解密都需要用到key所有在加密的后需要把key和加密码都存到数据库中

 

/// <summary>

/// 唯一加密方式
/// </summary>
/// <param name="texts"></param>
/// <returns></returns>
public static string WeiJiaMiGuid(string texts)
{
string Keys = GenerateKey();
return MD5Encrypt(texts, Keys) + "=" + Keys;      //这里我把要加密的字符串和生成的key给拼接起来,这样我在调用 WeiJiaMiGuid方法是只需要传文本框text值就可以了;
}

 

------------------------取出加密时存在数据库的加密码和key  

/// <summary>
/// 唯一解密方式
/// </summary>
/// <param name="texts"></param>
/// <returns></returns>
public static string WeiYiJieMiGuid(string texts)
{
string[] pwa = texts.Split(new char[] { '=' });   //分割一下    然后调解密
return GXC.Commonality.CommGUID.MD5Decrypt(pwa[0], pwa[1]);

}

 

/// <summary>

/// 创建Key
/// </summary>
/// <returns></returns>
public static string GenerateKey()
{
DESCryptoServiceProvider desCrypto = (DESCryptoServiceProvider)DESCryptoServiceProvider.Create();
return ASCIIEncoding.ASCII.GetString(desCrypto.Key);
}

 

 

/// <summary>

/// MD5加密
/// </summary>
/// <param name="pToEncrypt"></param>
/// <param name="sKey"></param>
/// <returns></returns>
public static string MD5Encrypt(string pToEncrypt, string sKey)
{
DESCryptoServiceProvider des = new DESCryptoServiceProvider();
byte[] inputByteArray = Encoding.Default.GetBytes(pToEncrypt);
des.Key = ASCIIEncoding.ASCII.GetBytes(sKey);
des.IV = ASCIIEncoding.ASCII.GetBytes(sKey);
MemoryStream ms = new MemoryStream();
CryptoStream cs = new CryptoStream(ms, des.CreateEncryptor(), CryptoStreamMode.Write);
cs.Write(inputByteArray, 0, inputByteArray.Length);
cs.FlushFinalBlock();
StringBuilder ret = new StringBuilder();
foreach (byte b in ms.ToArray())
{
ret.AppendFormat("{0:X2}", b);
}
ret.ToString();
return ret.ToString();
}

/// <summary>

/// MD5解密
/// </summary>
/// <param name="pToDecrypt"></param>
/// <param name="sKey"></param>
/// <returns></returns>
public static string MD5Decrypt(string pToDecrypt, string sKey)
{
DESCryptoServiceProvider des = new DESCryptoServiceProvider();

byte[] inputByteArray = new byte[pToDecrypt.Length / 2];

for (int x = 0; x < pToDecrypt.Length / 2; x++)
{
int i = (Convert.ToInt32(pToDecrypt.Substring(x * 2, 2), 16));
inputByteArray[x] = (byte)i;
}

des.Key = ASCIIEncoding.ASCII.GetBytes(sKey);

des.IV = ASCIIEncoding.ASCII.GetBytes(sKey);
MemoryStream ms = new MemoryStream();
CryptoStream cs = new CryptoStream(ms, des.CreateDecryptor(), CryptoStreamMode.Write);
cs.Write(inputByteArray, 0, inputByteArray.Length);
cs.FlushFinalBlock();

StringBuilder ret = new StringBuilder();

return System.Text.Encoding.Default.GetString(ms.ToArray());

}

 

复制就可以用  无需改动 16位加密方式

转载地址:http://slxao.baihongyu.com/

你可能感兴趣的文章
我的友情链接
查看>>
酒有两不喝,财有两不发,忙有三不帮,亲有三不走!
查看>>
IPFS 服务的Python访问
查看>>
DllMain详解
查看>>
Class bytes found but defineClass()failed for error when deploying EAR
查看>>
IIS7.0安装的FTP建账号
查看>>
spring --理解
查看>>
前台中文数据后台achieveRequest().getParameter获取乱码问题
查看>>
sed工具扩展学习
查看>>
db4o 参考资料
查看>>
mysql生产环境___主从同步修复案例
查看>>
对Controller的单元测试
查看>>
人工智能无法挑战人心
查看>>
移动web 1px边框解决方案
查看>>
centos7.4 Rsync配置和触发备份
查看>>
Oracle12c 安装
查看>>
DX11之D3DXMatrixIdentity 函数
查看>>
四项重要标准 让金融机构评选合适的DDoS防护提供商
查看>>
iOS开发的插件和工具
查看>>
设置UIButton,UITextFild边框圆角(上半边或下半边)
查看>>