C# DES对称加密(需自行配置秘钥)

C# 2277次浏览 本站
//--------------------------------------------------------------------------------
// 文件描述:数据加密辅助类
// 文件作者:全体开发人员
// 创建日期:2016-06-27
//--------------------------------------------------------------------------------

using System;
using System.IO;
using System.Security.Cryptography;
using System.Text;

namespace RC.Framework.Helper
{
    /// <summary>
    ///     加密类
    /// </summary>
    public class DESCrypt
    {
        /// <summary>
        ///     密钥(只支持8个字节的密钥)
        /// </summary>
        private const string SKey = "whir.net";//自行配置

        /// <summary>
        ///     DEC 加密过程 密钥(只支持8个字节的密钥)
        /// </summary>
        /// <param name="input">被加密的字符串</param>
        /// <returns>加密后的字符串</returns>
        public static string Encrypt(string input)
        {
            //访问数据加密标准(DES)算法的加密服务提供程序 (CSP) 版本的包装对象
            var des = new DESCryptoServiceProvider
            {
                Key = Encoding.ASCII.GetBytes(SKey),
                IV = Encoding.ASCII.GetBytes(SKey)
            };

            var inputByteArray = Encoding.Default.GetBytes(input); //把字符串放到byte数组中

            var ms = new MemoryStream(); //创建其支持存储区为内存的流 
            //定义将数据流链接到加密转换的流
            var cs = new CryptoStream(ms, des.CreateEncryptor(), CryptoStreamMode.Write);
            cs.Write(inputByteArray, 0, inputByteArray.Length);
            cs.FlushFinalBlock();
            //上面已经完成了把加密后的结果放到内存中去

            var ret = new StringBuilder();
            foreach (var b in ms.ToArray()) ret.AppendFormat("{0:X2}", b);
            return ret.ToString();
        }

        /// <summary>
        ///     DEC 解密过程 密钥(只支持8个字节的密钥,同前面的加密密钥相同)
        /// </summary>
        /// <param name="input">被解密的字符串</param>
        /// <returns>返回被解密的字符串</returns>
        public static string Decrypt(string input)
        {
            var des = new DESCryptoServiceProvider();

            var inputByteArray = new byte[input.Length / 2];
            for (var x = 0; x < input.Length / 2; x++)
            {
                var i = Convert.ToInt32(input.Substring(x * 2, 2), 16);
                inputByteArray[x] = (byte) i;
            }

            des.Key = Encoding.ASCII.GetBytes(SKey); //建立加密对象的密钥和偏移量,此值重要,不能修改
            des.IV = Encoding.ASCII.GetBytes(SKey);
            var ms = new MemoryStream();
            var cs = new CryptoStream(ms, des.CreateDecryptor(), CryptoStreamMode.Write);

            cs.Write(inputByteArray, 0, inputByteArray.Length);
            cs.FlushFinalBlock();
            return Encoding.Default.GetString(ms.ToArray());
        }
    }
}
            

发表评论

电子邮件地址不会被公开。 必填项已用*标注