c# AES128 加解密算法

复制代码
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Diagnostics;
using System.IO;
using System.Security.Cryptography;

namespace AESEncoder
{
    class Program
    {
        static void Main(string[] args)
        {
            var encoder = new AESEncoder("@111>111@222>222@333>333");
            var a = encoder.EncryptString("abc");
            var b = encoder.DecryptString(a); 
        }

        /// <summary>
        /// DESEncrypt加密解密算法。
        /// </summary>
        public class AESEncoder
        {

            public AESEncoder(string key)
            {
                this.Key = key;
            }

            /// <summary>
            /// 对称加密解密的密钥
            /// </summary>
            public string Key { get; private set; }

            /// <summary>
            /// DES加密
            /// </summary>
            /// <param name="encryptString"></param>
            /// <returns></returns>
            public string EncryptString(string data)
            {
                byte[] keyArray = UTF8Encoding.UTF8.GetBytes(this.Key);
                byte[] toEncryptArray = UTF8Encoding.UTF8.GetBytes(data);
                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);
            }

            /// <summary>
            /// DES解密
            /// </summary>
            /// <param name="decryptString"></param>
            /// <returns></returns>
            public string DecryptString(string data)
            {
                byte[] keyArray = UTF8Encoding.UTF8.GetBytes(this.Key);
                byte[] toEncryptArray = Convert.FromBase64String(data);
                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 UTF8Encoding.UTF8.GetString(resultArray);
            }

            public bool EncryptFile(string filepath)
            {
                try
                {
                    var bytes = File.ReadAllBytes(filepath);
                    File.WriteAllBytes(filepath, Encoding.UTF8.GetBytes(this.EncryptString(Convert.ToBase64String(bytes))));
                    return true;
                }
                catch (Exception ex)
                {
                    Debug.Print(ex.ToString());
                    return false;
                }
            }

            public bool DecryptFile(string filepath)
            {
                try
                {
                    var bytes = File.ReadAllBytes(filepath);
                    File.WriteAllBytes(filepath, Convert.FromBase64String(this.DecryptString(Encoding.UTF8.GetString(bytes))));
                    return true;
                }
                catch (Exception ex)
                {
                    Debug.Print(ex.ToString());
                    return false;
                }
            }
        }
    }
}
复制代码

 

复制代码
/// <summary>
        /// AES256加密解密算法。
        /// </summary>
        public class AESEncoder
        {

            public AESEncoder(string key)
            {
                this.Key = key;
            }

            /// <summary>
            /// 对称加密解密的密钥
            /// </summary>
            public string Key { get; private set; }

            /// <summary>
            /// DES加密
            /// </summary>
            /// <param name="encryptString"></param>
            /// <returns></returns>
            public byte[] EncryptBytes(byte[] data)
            {
                byte[] keyArray = UTF8Encoding.UTF8.GetBytes(this.Key);
                RijndaelManaged rDel = new RijndaelManaged();
                rDel.Key = keyArray;
                rDel.Mode = CipherMode.ECB;
                rDel.Padding = PaddingMode.PKCS7;
                ICryptoTransform cTransform = rDel.CreateEncryptor();
                byte[] resultArray = cTransform.TransformFinalBlock(data, 0, data.Length);
                return resultArray;
            }

            /// <summary>
            /// DES解密
            /// </summary>
            /// <param name="decryptString"></param>
            /// <returns></returns>
            public byte[] DecryptBytes(byte[] data)
            {
                byte[] keyArray = UTF8Encoding.UTF8.GetBytes(this.Key);
                RijndaelManaged rDel = new RijndaelManaged();
                rDel.Key = keyArray;
                rDel.Mode = CipherMode.ECB;
                rDel.Padding = PaddingMode.PKCS7;
                ICryptoTransform cTransform = rDel.CreateDecryptor();
                byte[] resultArray = cTransform.TransformFinalBlock(data, 0, data.Length);
                return resultArray;
            }
        }
复制代码

 

posted on   空明流光  阅读(1625)  评论(0编辑  收藏  举报

编辑推荐:
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!
历史上的今天:
2015-06-24 本地网站部署注意细节

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5
点击右上角即可分享
微信分享提示