c#多种加解密实例(md5加密解密)
using System;
using System.Collections.Generic;
using System.Globalization;
using System.IO;
using System.Security.Cryptography;
using System.Text;
///
/// 加解密
///
public static class CryptHelper
{
#region RSA加密
///
/// 用指定公钥加密文本
///
///公钥
///文本
///
public static string RsaEncrypt(string publicKey, string input)
{
const string sFormat =
"
var provider = new RSACryptoServiceProvider();
var arrPubKey = Hex2Bytes(publicKey);
var pkB64 = Convert.ToBase64String(arrPubKey);
var xmlStr = string.Format(sFormat, pkB64);
var bytesInput = Encoding.UTF8.GetBytes(input);
provider.FromXmlString(xmlStr);
var encryptArray = provider.Encrypt(bytesInput, false);
var hexStr = BitConverter.ToString(encryptArray).Replace("-", "");
return hexStr.ToLower();
}
#endregion
#region 公用函数
///
/// 将字节转换成16进制数字
///
///字节数组
///
public static string Bytes2Hex(byte[] bytes)
{
var buffer = new StringBuilder();
foreach (var t in bytes)
{
buffer.AppendFormat("{0:x2}", t);
}
return buffer.ToString();
}
///
/// 将16进制数组转换成字节
///
///16进制数组
///
///
public static byte[] Hex2Bytes(string input)
{
if (string.IsNullOrEmpty(input)) return null;
var offset = input.Length%2;
if (offset == 1) input = "0" + input;
int i;
var list = new List
for (i = 0; i < input.Length; i += 2)
{
var temp = input.Substring(i, 2);
byte bv;
var success = byte.TryParse(temp, NumberStyles.HexNumber, null, out bv);
if (!success) throw new ArgumentOutOfRangeException();
list.Add(bv);
}
return list.ToArray();
}
#endregion
#region SHA1加密
///
/// SHA1加密 使用缺省密钥给字符串加密
///
///
///
public static string Sha1Encrypt(string sourceString)
{
var data = Encoding.Default.GetBytes(sourceString);
HashAlgorithm sha = new SHA1CryptoServiceProvider();
var bytes = sha.ComputeHash(data);
return BitConverter.ToString(bytes).Replace("-", "");
}
#endregion
#region DES加解密
///
/// DES加密
///
///
///
///
public static string DesEncrypt(string pubKey, string input)
{
var des = new DESCryptoServiceProvider();
var bytes = Encoding.UTF8.GetBytes(input);
des.Key = Encoding.ASCII.GetBytes(pubKey);
des.IV = Encoding.ASCII.GetBytes(pubKey);
using (var ms = new MemoryStream())
{
using (var cryptoStream = new CryptoStream(ms, des.CreateEncryptor(), CryptoStreamMode.Write))
{
cryptoStream.Write(bytes, 0, bytes.Length);
cryptoStream.FlushFinalBlock();
}
var data = ms.ToArray();
return BitConverter.ToString(data).Replace("-", "");
}
}
///
/// DES解密
///
///
///
///
public static string DesDecrypt(string pubKey, string input)
{
var des = new DESCryptoServiceProvider();
var bytes = Hex2Bytes(input);
des.Key = Encoding.ASCII.GetBytes(pubKey);
des.IV = Encoding.ASCII.GetBytes(pubKey);
using (var ms = new MemoryStream())
{
using (var cryptoStream = new CryptoStream(ms, des.CreateDecryptor(), CryptoStreamMode.Write))
{
cryptoStream.Write(bytes, 0, bytes.Length);
cryptoStream.FlushFinalBlock();
}
var data = ms.ToArray();
return Encoding.UTF8.GetString(data);
}
}
#endregion
#region MD5加密
///
/// MD5加密
///
///输入
///
public static string Md5Encrypt(string input)
{
MD5 md5 = new MD5CryptoServiceProvider();
var data = Encoding.UTF8.GetBytes(input);
var encs = md5.ComputeHash(data);
return BitConverter.ToString(encs).Replace("-", "");
}
#endregion
}
同类资源
- 易语言实现Base64、MD5、SHA、AES、RAS等加解密js库文件
易语言实现Base64、MD5、SHA、AES、RAS等加解密js库文件例子源代码,各种加密解密的实现。...
- c#调用dll,dll加载epk
易语言c#调用dll,dll加载epk例子源代码,通过c#调用dll,易语言写dll调用epk。...
- C#版的模块中所有的api和相关的结构体的声明
C#版的模块中所有的api和相关的结构体的声明例子源代码,直接用易语言封装成dll调用。...
- 微信小程序,数据加解密
微信小程序,数据加解密例子源代码,取我要猫咪小程序源码。...
- BASE64编码Escape编码加解密
BASE64编码Escape编码加解密例子源代码,没有用到外界模块纯代码实现BASE64编码加解密。...
- c#版写的重命名工具
c#版写的重命名工具绿色版,之前记得有个跟这个界面类似的重命名,后来一直找不到了,下载转存太麻烦了就自己弄...
- C#开源利用OpenCV找图经典例子
C#开源利用OpenCV找图经典例子绿色版,没有使用最新本版是因为该本版.NET4.0就能跑。...
- 把其它应用嵌入到C#窗口源代码
把其它应用嵌入到C#窗口源代码本文件感兴趣的可以参考一下,把一个现有的窗体应用程序界面嵌入到自己开发的...
- C#H264格式视频解码
C#H264格式视频解码本文件感兴趣的可以参考一下,使用FFMPEG解码为H264视频文件。...
- C# WinCE播放器WinCE_PlayMusic
C#WinCE播放器本文件感兴趣的可以参考一下,可播放*.wav,*.mp3等语音文件。...
- C#自动远程时间同步助手
C#自动远程时间同步助手本文件感兴趣的可以参考一下,时间服务器的ntp服务开启状态。...
- C#文件加密解密完整项目
C#文件加密解密完整项目本文件感兴趣的可以参考一下,实现C#加密各种文件和解密加密后的文件。...