zoukankan      html  css  js  c++  java
  • 加密算法

    public class Cryptography
        {
            private static readonly Byte[] IV =
            {
                131, 124, 213, 11, 241, 214, 201, 103,
                138, 225, 188, 216, 116, 247, 152, 145
            };
    
            private Byte[] aesKey =
            {
                121, 249, 165, 183, 172, 16, 18, 24,
                111, 129, 121, 13, 152, 114, 238, 114
            };
    
            private Boolean isDefaultKey;
    
            public String Key
            {
                get { return Convert.ToBase64String(this.aesKey); }
                set
                {
                    this.aesKey = Convert.FromBase64String(value);
                    this.isDefaultKey = false;
                }
            }
    
            public bool IsDefaultKey
            {
                get { return this.isDefaultKey; }
            }
    
            public Byte[] Encrypt(Byte[] plainData)
            {
                using (var aesProvider = new AesCryptoServiceProvider())
                {
                    using (var stream = new MemoryStream())
                    {
                        using (var cryptoStream = new CryptoStream(
                            stream,
                            aesProvider.CreateEncryptor(this.aesKey, IV),
                            CryptoStreamMode.Write))
                        {
                            cryptoStream.Write(plainData, 0, plainData.Length);
                        }
                        var encryptMessageBytes = stream.ToArray();
                        var bts = new Byte[IV.Length + encryptMessageBytes.Length];
                        Array.Copy(IV, 0, bts, 0, IV.Length);
                        Array.Copy(encryptMessageBytes, 0, bts, IV.Length, encryptMessageBytes.Length);
                        return bts;
                    }
                }
            }
    
            public Byte[] Decrypt(Byte[] encryptionData)
            {
                using (var aesProvider = new AesCryptoServiceProvider())
                {
                    using (var stream = new MemoryStream())
                    {
                        var iv = new Byte[16];
                        Array.Copy(encryptionData, 0, iv, 0, iv.Length);
                        using (var cryptoStream = new CryptoStream(
                            stream,
                            aesProvider.CreateDecryptor(this.aesKey, iv),
                            CryptoStreamMode.Write))
                        {
                            cryptoStream.Write(encryptionData, IV.Length, encryptionData.Length - IV.Length);
                        }
                        return stream.ToArray();
                    }
                }
            }
    
            public String EncryptString(String plainString)
            {
                var buffer = Encoding.UTF8.GetBytes(plainString);
                var encryptMessageBytes = this.Encrypt(buffer);
                return Convert.ToBase64String(encryptMessageBytes);
            }
    
            public String DecryptString(String encryptedString)
            {
                var buffer = Convert.FromBase64String(encryptedString);
                var decryptMessageBytes = this.Decrypt(buffer);
                return Encoding.UTF8.GetString(decryptMessageBytes);
            }
        }
    

      

  • 相关阅读:
    Vim作者创造新编程语言Zimbu
    Google Maps API编程资源大全
    好网收集的地址
    三种模拟自动登录和提交POST信息的实现方法
    解析VMware三种网络连接方式
    PostgreSQL 创建帐号,数据库,权限
    LINUX目录详解
    Linux流媒体服务器安装配置
    用RAMDISK来提高PostgreSQL访问速度
    PostgreSQL 集群复制方案之使用pgq和londiste工具包
  • 原文地址:https://www.cnblogs.com/qindy/p/6664401.html
Copyright © 2011-2022 走看看