1 changed files with 175 additions and 0 deletions
@ -0,0 +1,175 @@
|
||||
using System; |
||||
using System.Collections.Generic; |
||||
using System.Linq; |
||||
using System.Text; |
||||
using System.Threading.Tasks; |
||||
|
||||
namespace Elight.Utility.Encrypt |
||||
{ |
||||
public sealed class DataEncryption |
||||
{ |
||||
private static byte[] KEY = new byte[8] { 40, 16, 37, 37, 32, 62, 83, 60 }; |
||||
|
||||
private static byte ByteXor(byte b, byte key) |
||||
{ |
||||
b = (byte)(b ^ key); |
||||
return b; |
||||
} |
||||
|
||||
private static byte[] ByteXor(byte[] data, byte[] key) |
||||
{ |
||||
var keyLen = key.Length; |
||||
var dataLen = data.Length; |
||||
if (dataLen == 0) |
||||
{ |
||||
return data; |
||||
} |
||||
for (var i = 0; i < dataLen; i++) |
||||
{ |
||||
data[i] = ByteXor(data[i], key[i % keyLen]); |
||||
} |
||||
return data; |
||||
} |
||||
|
||||
/// <summary> |
||||
/// 加密,key必须是2的n次方 |
||||
/// </summary> |
||||
public static byte[] Encryption(byte[] data, byte[] key) |
||||
{ |
||||
return ByteXor(data, key); |
||||
} |
||||
|
||||
/// <summary> |
||||
/// 加密, 使用内置密钥 |
||||
/// </summary> |
||||
public static byte[] Encryption(byte[] data) |
||||
{ |
||||
return ByteXor(data, KEY); |
||||
} |
||||
|
||||
/// <summary> |
||||
/// 加密文件 |
||||
/// </summary> |
||||
/// <param name="srcFile">明文文件</param> |
||||
/// <param name="descFile">密文文件</param> |
||||
/// <param name="key">密钥</param> |
||||
public static void Encryption(string srcFile, string descFile, byte[] key) |
||||
{ |
||||
var fs = File.OpenRead(srcFile); |
||||
var newfs = File.Create(descFile, 1024 * 512); |
||||
var count = 0; |
||||
var keyLen = key.Length; |
||||
|
||||
var buffer = new byte[1024 * 512]; |
||||
using (fs) |
||||
{ |
||||
using (newfs) |
||||
{ |
||||
if (fs.Length == 0) |
||||
{ |
||||
return; |
||||
} |
||||
while (fs.Position < fs.Length) |
||||
{ |
||||
count = fs.Read(buffer, 0, 1024 * 512); |
||||
for (var i = 0; i < count; i++) |
||||
{ |
||||
buffer[i] = ByteXor(buffer[i], key[i % keyLen]); |
||||
} |
||||
newfs.Write(buffer, 0, count); |
||||
} |
||||
} |
||||
} |
||||
} |
||||
|
||||
/// <summary> |
||||
/// 加密文件, 使用内置密钥 |
||||
/// </summary> |
||||
/// <param name="srcFile">明文文件</param> |
||||
/// <param name="descFile">密文文件</param> |
||||
public static void Encryption(string srcFile, string descFile) |
||||
{ |
||||
Encryption(srcFile, descFile, KEY); |
||||
} |
||||
|
||||
/// <summary> |
||||
/// 解密 |
||||
/// </summary> |
||||
public static byte[] Decryption(byte[] data, byte[] key) |
||||
{ |
||||
return ByteXor(data, key); |
||||
} |
||||
|
||||
/// <summary> |
||||
/// 解密, 使用内置密钥 |
||||
/// </summary> |
||||
public static byte[] Decryption(byte[] data) |
||||
{ |
||||
return ByteXor(data, KEY); |
||||
} |
||||
|
||||
/// <summary> |
||||
/// 解密文件 |
||||
/// </summary> |
||||
/// <param name="srcFile">密文文件</param> |
||||
/// <param name="descFile">解密后的文件</param> |
||||
/// <param name="key">密钥</param> |
||||
public static void Decryption(string srcFile, string descFile, byte[] key) |
||||
{ |
||||
Encryption(srcFile, descFile, key); |
||||
} |
||||
|
||||
/// <summary> |
||||
/// 解密文件, 使用内置密钥 |
||||
/// </summary> |
||||
/// <param name="srcFile">密文文件</param> |
||||
/// <param name="descFile">解密后的文件</param> |
||||
public static void Decryption(string srcFile, string descFile) |
||||
{ |
||||
Decryption(srcFile, descFile, KEY); |
||||
} |
||||
|
||||
/// <summary> |
||||
/// 根据文件路径判断是否加密文件 |
||||
/// </summary> |
||||
/// <param name="srcFile">文件路径</param> |
||||
/// <returns></returns> |
||||
public static bool JudgeIsEncryFile(string srcFile) |
||||
{ |
||||
return srcFile.LastIndexOf(".encry") > 0; |
||||
} |
||||
|
||||
public static string Decryptiones(string srcFile) |
||||
{ |
||||
var fs = File.OpenRead(srcFile); |
||||
//var newfs = File.Create(descFile, 1024 * 512); |
||||
var newfs = new MemoryStream(); |
||||
var count = 0; |
||||
var keyLen = KEY.Length; |
||||
|
||||
var buffer = new byte[1024 * 512]; |
||||
using (fs) |
||||
{ |
||||
using (newfs) |
||||
{ |
||||
if (fs.Length == 0) |
||||
{ |
||||
return null; |
||||
} |
||||
while (fs.Position < fs.Length) |
||||
{ |
||||
count = fs.Read(buffer, 0, 1024 * 512); |
||||
for (var i = 0; i < count; i++) |
||||
{ |
||||
buffer[i] = ByteXor(buffer[i], KEY[i % keyLen]); |
||||
} |
||||
newfs.Write(buffer, 0, count); |
||||
} |
||||
} |
||||
} |
||||
|
||||
var base64 = Convert.ToBase64String(newfs.ToArray()); |
||||
return base64; |
||||
} |
||||
} |
||||
} |
Loading…
Reference in new issue