|

楼主 |
发表于 2022-4-5 21:36:35
|
显示全部楼层
- using System;
- using System.Security.Cryptography;
- using System.Text;
- using Microsoft.Office.Interop.Word;
- namespace AES
- {
- class Program
- {
- public static string AesEncryptor_Base64(string EncryptStr, string Key)
- {
- try
- {
- //byte[] keyArray = Encoding.UTF8.GetBytes(Key);
- byte[] keyArray = Convert.FromBase64String(Key);
- byte[] toEncryptArray = Encoding.UTF8.GetBytes(EncryptStr);
- RijndaelManaged rDel = new RijndaelManaged();
- rDel.Key = keyArray;
- rDel.Mode = CipherMode.ECB;
- rDel.Padding = PaddingMode.PKCS7;
- ICryptoTransform cTransform = rDel.CreateEncryptor();
- byte[] resultArray = cTransform.TransformFinalBlock(toEncryptArray, 0, toEncryptArray.Length);
- return Convert.ToBase64String(resultArray, 0, resultArray.Length);
- }
- catch (Exception ex)
- {
- return null;
- }
- }
- public static string AesDecryptor_Base64(string DecryptStr, string Key)
- {
- try
- {
- //byte[] keyArray = Encoding.UTF8.GetBytes(Key);
- byte[] keyArray = Convert.FromBase64String(Key);
- byte[] toEncryptArray = Convert.FromBase64String(DecryptStr);
- RijndaelManaged rDel = new RijndaelManaged();
- rDel.Key = keyArray;
- rDel.Mode = CipherMode.ECB;
- rDel.Padding = PaddingMode.PKCS7;
- ICryptoTransform cTransform = rDel.CreateDecryptor();
- byte[] resultArray = cTransform.TransformFinalBlock(toEncryptArray, 0, toEncryptArray.Length);
- return Encoding.UTF8.GetString(resultArray);// UTF8Encoding.UTF8.GetString(resultArray);
- }
- catch (Exception ex)
- {
- return null;
- }
- }
- public static string AesEncryptor_Hex(string str, string key)
- {
- if (string.IsNullOrEmpty(str)) return null;
- Byte[] toEncryptArray = Encoding.UTF8.GetBytes(str);
- System.Security.Cryptography.RijndaelManaged rm = new System.Security.Cryptography.RijndaelManaged
- {
- Key = StrToHexByte(key),
- Mode = System.Security.Cryptography.CipherMode.ECB,
- Padding = System.Security.Cryptography.PaddingMode.PKCS7
- };
- System.Security.Cryptography.ICryptoTransform cTransform = rm.CreateEncryptor();
- Byte[] resultArray = cTransform.TransformFinalBlock(toEncryptArray, 0, toEncryptArray.Length);
- return ToHexString(resultArray);
- }
- public static string AesDecryptor_Hex(string str, string key)
- {
- if (string.IsNullOrEmpty(str)) return null;
- Byte[] toEncryptArray = StrToHexByte(str);
- System.Security.Cryptography.RijndaelManaged rm = new System.Security.Cryptography.RijndaelManaged
- {
- Key = StrToHexByte(key),
- Mode = System.Security.Cryptography.CipherMode.ECB,
- Padding = System.Security.Cryptography.PaddingMode.PKCS7
- };
- System.Security.Cryptography.ICryptoTransform cTransform = rm.CreateDecryptor();
- Byte[] resultArray = cTransform.TransformFinalBlock(toEncryptArray, 0, toEncryptArray.Length);
- return Encoding.UTF8.GetString(resultArray);
- }
- public static string ToHexString(byte[] bytes) // 0xae00cf => "AE00CF "
- {
- string hexString = string.Empty;
- if (bytes != null)
- {
- StringBuilder strB = new StringBuilder();
- for (int i = 0; i < bytes.Length; i++)
- {
- strB.Append(bytes[i].ToString("X2"));
- }
- hexString = strB.ToString();
- }
- return hexString;
- }
- public static byte[] StrToHexByte(string hexString)
- {
- hexString = hexString.Replace(" ", "");
- if ((hexString.Length % 2) != 0)
- hexString += " ";
- byte[] returnBytes = new byte[hexString.Length / 2];
- for (int i = 0; i < returnBytes.Length; i++)
- returnBytes[i] = Convert.ToByte(hexString.Substring(i * 2, 2), 16);
- return returnBytes;
- }
- static void Main(string[] args)
- {
- Microsoft.Office.Interop.Word.Application A = new Microsoft.Office.Interop.Word.Application();//打开word程序
- Document docx = null;
- object unknow = Type.Missing;
- A.Visible = true;
- object paramSourceDocPath = @"C:\Users\26221\Desktop\xx.docx";
- docx = A.Documents.Open(ref paramSourceDocPath,
- ref unknow, ref unknow, ref unknow, ref unknow, ref unknow,
- ref unknow, ref unknow, ref unknow, ref unknow, ref unknow,
- ref unknow, ref unknow, ref unknow, ref unknow, ref unknow);
- string str = docx.Content.Text.Trim();
- string str1 = AesEncryptor_Base64(str, "7654564321654321abc7534567446654");
- Console.WriteLine("Base64密文:" + str1);
- string str2 = AesDecryptor_Base64(str1, "7654564321654321abc7534567446654");
- Console.WriteLine("Base64解密密文:" + str2);
- string str3 = AesEncryptor_Hex(str, "364836143850abc46746243098546756");
- Console.WriteLine("Hex加密后密文:" + str3);
- string str4 = AesDecryptor_Hex(str3, "364836143850abc46746243098546756");
- Console.WriteLine("Hex解密密文:" + str4);
- }
- }
- }
复制代码
|
本帖子中包含更多资源
您需要 登录 才可以下载或查看,没有帐号?立即注册
x
|