• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

使用3DES加密算法对数据进行加密C#类

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

1

2

3

 

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.IO;
using System.Security.Cryptography;

namespace Rare.Card.Libary.Security
{
    /// <summary>
    /// 构造一个对称算法,使用3Des加密
    ///如果当前的 Key 属性为 NULL,可调用 GenerateKey 方法以创建新的随机 Key。 
    ///如果当前的 IV 属性为 NULL,可调用 GenerateIV 方法以创建新的随机 IV
    /// </summary>
    public class CryptoTripleDes
    {
        //加密矢量
        private static byte[] IV = { 0xB0, 0xA2, 0xB8, 0xA3, 0xDA, 0xCC, 0xDA, 0xCC };
        /// <summary>
        /// 使用指定的128字节的密钥对8字节数组进行3Des加密
        /// </summary>
        /// <param name="keys">密钥,16字节,128位</param>
        /// <param name="values">要加密的数组</param>
        /// <returns>已加密的数组</returns>
        public static byte[] CreateEncryptByte(byte[] keys, byte[] values)
        {
            TripleDESCryptoServiceProvider tdsc = new TripleDESCryptoServiceProvider();
            //指定密匙长度,默认为192位
            tdsc.KeySize = 128;
            //使用指定的key和IV(加密向量)
            tdsc.Key = keys;
            tdsc.IV = IV;
            //加密模式,偏移
            tdsc.Mode = CipherMode.ECB;
            tdsc.Padding = PaddingMode.None;
            //进行加密转换运算
            ICryptoTransform ct = tdsc.CreateEncryptor();
            //8很关键,加密结果是8字节数组
            byte[] results = ct.TransformFinalBlock(values, 0, 8);

            return results;
        }
        /// <summary>
        /// 使用指定的128字节的密钥对字符串(8位)进行3Des加密
        /// </summary>
        /// <param name="strKey"></param>
        /// <param name="strValue"></param>
        /// <returns></returns>
        public static byte[] CreateEncryptString(string strKey, string strValue)
        {
            TripleDESCryptoServiceProvider tdsc = new TripleDESCryptoServiceProvider();
            byte[] results = new byte[strValue.Length];
            tdsc.KeySize = 128;
            if (!string.IsNullOrEmpty(strKey))
            {
                tdsc.Key = Encoding.UTF8.GetBytes(strKey);
            }
            tdsc.IV = IV;
            using (ICryptoTransform ct = tdsc.CreateDecryptor())
            {
                byte[] byt = Encoding.UTF8.GetBytes(strValue);
                results = ct.TransformFinalBlock(byt, 0, 8);
            }
            return results;
        }
        /// <summary>
        /// 对加密字符串进行解密
        /// </summary>
        /// <param name="keys">密匙</param>
        /// <param name="values">已加密字符串</param>
        /// <returns>解密结果</returns>
        public static byte[] CreateDescryptByte(byte[] keys, byte[] values)
        {
            TripleDESCryptoServiceProvider tdsc = new TripleDESCryptoServiceProvider();

            //指定密匙长度,默认为192位
            tdsc.KeySize = 128;
            //使用指定的key和IV(加密向量)
            tdsc.Key = keys;
            tdsc.IV = IV;
            //加密模式,偏移
            tdsc.Mode = CipherMode.ECB;
            tdsc.Padding = PaddingMode.None;
            //进行加密转换运算
            ICryptoTransform ct = tdsc.CreateDecryptor();
            //8很关键,加密结果是8字节数组
            byte[] results = ct.TransformFinalBlock(values, 0, 8);

            return results;
        }
    }
}

 

4测试数据:

16字节密钥:0x31,0x32,0x33,0x34,0x35,0x36,0x37,0x38,0x39,0x3a,0x3b,0x3c,0x3d,0x3e,0x3f,0x30
对:0x11,0x22,0x33,0x44,0x55,0x66,0x77,0x88 八字节明文作3DES加密
得出如下8字节密文:0x3c,0x46,0xea,0x28,0x2f,0xdb,0x64,0x00

 

 


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap