|
本帖最后由 李浩栋 于 2022-4-5 18:53 编辑
- using System;
- using System.Security.Cryptography;
- using System.Text;
- using Word = Microsoft.Office.Interop.Word;
- namespace caogaoben
- {
- class Program
- {
- static void Main(string[] args)
- {
- Word.Application app = new Microsoft.Office.Interop.Word.Application();
- Word.Document doc = null;
- object unknow = Type.Missing;
- app.Visible = true;
- string str = @"C:\Users\李浩栋\Desktop\密码学.docx";
- object file = str;
- doc = app.Documents.Open(ref file,
- 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 temp = doc.Paragraphs[1].Range.Text.Trim();
- string key = "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa";
- string str1 = Program.AesEncryptor_Base64(temp, key);
- Console.WriteLine("加密后进行base64编码得:" + str1);
- string str2 = Program.AesDecryptor_Base64(str1, key);
- Console.WriteLine("base64解码后进行解密得:" + str2);
- string str3 = Program.AesEncryptor_Hex(temp, key);
- Console.WriteLine("加密后进行Hex编码得:" + str3);
- string str4 = Program.AesDecryptor_Hex(str3, key);
- Console.WriteLine("Hex解码后进行解密得:" + str4);
- }
- /// <summary>
- /// AES 算法加密(ECB模式) 将明文加密,加密后进行base64编码,返回密文
- /// </summary>
- /// <param name="EncryptStr">明文</param>
- /// <param name="Key">密钥</param>
- /// <returns>加密后base64编码的密文</returns>
- 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;
- }
- }
- /// <summary>
- /// AES 算法解密(ECB模式) 将密文base64解码进行解密,返回明文
- /// </summary>
- /// <param name="DecryptStr">密文</param>
- /// <param name="Key">密钥</param>
- /// <returns>明文</returns>
- 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;
- }
- }
- /// <summary>
- ///AES 算法加密(ECB模式) 将明文加密,加密后进行Hex编码,返回密文
- /// </summary>
- /// <param name="str">明文</param>
- /// <param name="key">密钥</param>
- /// <returns>加密后Hex编码的密文</returns>
- 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);
- }
- /// <summary>
- ///AES 算法解密(ECB模式) 将密文Hex解码后进行解密,返回明文
- /// </summary>
- /// <param name="str">密文</param>
- /// <param name="key">密钥</param>
- /// <returns>明文</returns>
- 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);
- }
- /// <summary>
- /// byte数组Hex编码
- /// </summary>
- /// <param name="bytes">需要进行编码的byte[]</param>
- /// <returns></returns>
- 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;
- }
- /// <summary>
- /// 字符串进行Hex解码(Hex.decodeHex())
- /// </summary>
- /// <param name="hexString">需要进行解码的字符串</param>
- /// <returns></returns>
- 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;
- }
- }
- }
复制代码
|
本帖子中包含更多资源
您需要 登录 才可以下载或查看,没有帐号?立即注册
x
|