106 lines
3.8 KiB
C#
106 lines
3.8 KiB
C#
|
using System;
|
|||
|
using System.Collections.Generic;
|
|||
|
using System.IO;
|
|||
|
using System.Linq;
|
|||
|
using System.Security.Cryptography;
|
|||
|
using System.Text;
|
|||
|
using System.Threading.Tasks;
|
|||
|
|
|||
|
namespace FAuth.Extensions.Decryptor
|
|||
|
{
|
|||
|
/// <summary>
|
|||
|
/// 加密帮助类
|
|||
|
/// </summary>
|
|||
|
public class EncryptyWorker
|
|||
|
{
|
|||
|
/// <summary>
|
|||
|
/// 补位填充方式
|
|||
|
/// </summary>
|
|||
|
public PaddingMode Padding { get; set; }
|
|||
|
/// <summary>
|
|||
|
/// 加密算法模式
|
|||
|
/// </summary>
|
|||
|
public CipherMode Cipher { get; set; }
|
|||
|
/// <summary>
|
|||
|
/// 初始化向量
|
|||
|
/// </summary>
|
|||
|
public byte[] IV { get; set; }
|
|||
|
/// <summary>
|
|||
|
/// 加密字符串获取Base64密文
|
|||
|
/// </summary>
|
|||
|
/// <param name="key">加密key</param>
|
|||
|
/// <param name="str">要加密的字符串</param>
|
|||
|
public string Encrypty(string key,string str) {
|
|||
|
if(key.Length < 8) {
|
|||
|
throw new Exception("加密用的key长度为8位");
|
|||
|
}
|
|||
|
byte[] bKey = Encoding.UTF8.GetBytes(key.Substring(0,8));
|
|||
|
byte[] bStr = Encoding.UTF8.GetBytes(str);
|
|||
|
var desc = createProvider();
|
|||
|
using(var mStream = new MemoryStream()) {
|
|||
|
using(var cStream = new CryptoStream(mStream,desc.CreateEncryptor(bKey,IV),CryptoStreamMode.Write)) {
|
|||
|
cStream.Write(bStr,0,bStr.Length);
|
|||
|
cStream.FlushFinalBlock();
|
|||
|
return Convert.ToBase64String(mStream.ToArray());
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
/// <summary>
|
|||
|
/// 从Base64密文解密,获取字符串
|
|||
|
/// </summary>
|
|||
|
/// <param name="key">加密键</param>
|
|||
|
/// <param name="str">密文</param>
|
|||
|
public string DesCrypty(string key,string str) {
|
|||
|
if(key.Length < 8) {
|
|||
|
throw new Exception("加密用的key长度为8位");
|
|||
|
}
|
|||
|
var bStr = Convert.FromBase64String(str);
|
|||
|
byte[] bKey = Encoding.UTF8.GetBytes(key.Substring(0,8));
|
|||
|
var desc = createProvider();
|
|||
|
using(var mStream = new MemoryStream()) {
|
|||
|
using(var cStream = new CryptoStream(mStream,desc.CreateDecryptor(bKey,IV),CryptoStreamMode.Write)) {
|
|||
|
cStream.Write(bStr,0,bStr.Length);
|
|||
|
cStream.FlushFinalBlock();
|
|||
|
return Encoding.UTF8.GetString(mStream.ToArray());
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
private DESCryptoServiceProvider createProvider() {
|
|||
|
var desc = new DESCryptoServiceProvider();
|
|||
|
desc.Padding = this.Padding;
|
|||
|
desc.Mode = this.Cipher;
|
|||
|
return desc;
|
|||
|
}
|
|||
|
|
|||
|
private static EncryptyWorker Deshelper { get; set; }
|
|||
|
|
|||
|
private EncryptyWorker() { }
|
|||
|
|
|||
|
/// <summary>
|
|||
|
/// 重用模式获取默认加密帮助器
|
|||
|
/// </summary>
|
|||
|
public static EncryptyWorker GetHelper() {
|
|||
|
if(Deshelper == null) {
|
|||
|
byte[] IV = { 0x01,0x02,0x03,0x04,0x05,0x06,0x07,0x08 };
|
|||
|
Deshelper = GetHelper(PaddingMode.PKCS7,CipherMode.CBC,IV);
|
|||
|
|
|||
|
}
|
|||
|
return Deshelper;
|
|||
|
}
|
|||
|
/// <summary>
|
|||
|
/// 生成新的加密帮助器
|
|||
|
/// </summary>
|
|||
|
/// <param name="padding">补位方式</param>
|
|||
|
/// <param name="cipher">加密算法模式</param>
|
|||
|
/// <param name="IV">初始化向量</param>
|
|||
|
public static EncryptyWorker GetHelper(PaddingMode padding,CipherMode cipher,byte[] IV) {
|
|||
|
return new EncryptyWorker {
|
|||
|
Cipher = cipher,
|
|||
|
IV = IV,
|
|||
|
Padding = padding,
|
|||
|
};
|
|||
|
}
|
|||
|
}
|
|||
|
}
|