• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >C#教程 > C# 3DES加密详解

C# 3DES加密详解

作者: 字体:[增加 减小] 来源:互联网 时间:2017-05-28

通过本文主要向大家介绍了c#3des加密,c#3des,3des加密,java 3des加密解密,java 3des加密等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

最近一个项目中,因为服务端是用的java开发的,客户端是用的C#,由于通信部分采用到了3DES加密,所以做个记录,以备以后需要的时候直接用。

  这是对方(java)的加密算法,和网上流传的代码也差不多(主密钥直接写死了,方便测试)

package org.zwork.market.mina.msg;
import java.security.spec.KeySpec;
import javax.crypto.Cipher;
import javax.crypto.SecretKey;
import javax.crypto.SecretKeyFactory;
import javax.crypto.spec.DESKeySpec;
import javax.crypto.spec.DESedeKeySpec;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.zwork.market.MktContants;
public class ThreeEncryptDecrypt {
  private static final Logger LOGGER = LoggerFactory.getLogger(ThreeEncryptDecrypt.class);
  // 定义 加密算法,可用 DES,DESede,Blowfish
  public static final String Algorithm = "DESede";
  public static String DES = "DES/ECB/NoPadding";
  public static String TriDes = "DESede/ECB/NoPadding";
  // des加密
  public static byte[] des_crypt(byte key[], byte data[]) {
    try {
      KeySpec ks = new DESKeySpec(key);
      SecretKeyFactory kf = SecretKeyFactory.getInstance("DES");
      SecretKey ky = kf.generateSecret(ks);
      Cipher c = Cipher.getInstance(DES);
      c.init(Cipher.ENCRYPT_MODE, ky);
      return c.doFinal(data);
    } catch (Exception e) {
      LOGGER.error("des_crypt error:", e);
      return null;
    }
  }
  // des解密
  public static byte[] des_decrypt(byte key[], byte data[]) {
    try {
      KeySpec ks = new DESKeySpec(key);
      SecretKeyFactory kf = SecretKeyFactory.getInstance("DES");
      SecretKey ky = kf.generateSecret(ks);
      Cipher c = Cipher.getInstance(DES);
      c.init(Cipher.DECRYPT_MODE, ky);
      return c.doFinal(data);
    } catch (Exception e) {
      LOGGER.error("des_decrypt error:", e);
      return null;
    }
  }
  // 3DES加密
  public static byte[] trides_crypt(byte key[], byte data[]) {
    try {
      byte[] k = new byte[24];
      int len = data.length;
      if (data.length % 8 != 0) {
        len = data.length - data.length % 8 + 8;
      }
      byte[] needData = null;
      if (len != 0)
        needData = new byte[len];
      for (int i = 0; i < len; i++) {
        needData[i] = 0x00;
      }
      System.arraycopy(data, 0, needData, 0, data.length);
      if (key.length == 16) {
        System.arraycopy(key, 0, k, 0, key.length);
        System.arraycopy(key, 0, k, 16, 8);
      } else {
        System.arraycopy(key, 0, k, 0, 24);
      }
      KeySpec ks = new DESedeKeySpec(k);
      SecretKeyFactory kf = SecretKeyFactory.getInstance("DESede");
      SecretKey ky = kf.generateSecret(ks);
      Cipher c = Cipher.getInstance(TriDes);
      c.init(Cipher.ENCRYPT_MODE, ky);
      return c.doFinal(needData);
    } catch (Exception e) {
      LOGGER.error("trides_crypt error:", e);
      return null;
    }
  }
  // 3DES解密
  public static byte[] trides_decrypt(byte key[], byte data[]) {
    try {
      byte[] k = new byte[24];
      int len = data.length;
      if (data.length % 8 != 0) {
        len = data.length - data.length % 8 + 8;
      }
      byte[] needData = null;
      if (len != 0)
        needData = new byte[len];
      for (int i = 0; i < len; i++) {
        needData[i] = 0x00;
      }
      System.arraycopy(data, 0, needData, 0, data.length);
      if (key.length == 16) {
        System.arraycopy(key, 0, k, 0, key.length);
        System.arraycopy(key, 0, k, 16, 8);
      } else {
        System.arraycopy(key, 0, k, 0, 24);
      }
      KeySpec ks = new DESedeKeySpec(k);
      SecretKeyFactory kf = SecretKeyFactory.getInstance("DESede");
      SecretKey ky = kf.generateSecret(ks);
      Cipher c = Cipher.getInstance(TriDes);
      c.init(Cipher.DECRYPT_MODE, ky);
      return c.doFinal(needData);
    } catch (Exception e) {
      LOGGER.error("trides_decrypt error:", e);
      return null;
    }
  }
  public static String getPass(String source) {
    byte[] data= hexToBytes(source);
    byte[] key ="111111111111111111111111111a1.1.".getBytes();
    String result = byte2hex(trides_decrypt(key, data)).toUpperCase();
    return result.substring(2, 8);
  }
  public static String byte2hex(byte[] data) {
    StringBuffer sb = new StringBuffer();
    for (int i = 0; i < data.length; i++) {
      String temp = Integer.toHexString(((int) data[i]) & 0xFF);
      for (int t = temp.length(); t < 2; t++) {
        sb.append("0");
      }
      sb.append(temp);
    }
    return sb.toString();
  }
  public static byte[] hexToBytes(String str) {
    if (str == null) {
      return null;
    } else if (str.length() < 2) {
      return null;
    } else {
      int len = str.length() / 2;
      byte[] buffer = new byte[len];
      for (int i = 0; i < len; i++) {
        buffer[i] = (byte) Integer.parseInt(str.substring(i * 2, i * 2 + 2), 16);
      }
      return buffer;
    }
  }
}

</div>

  因为客户端只负责数据加密,所以我这里只写了加密的部分。由于java和C#语言很相似,所以我就仿这他们给的java代码改成C#的,当然也在网上参考了一些代码,不过中间还是出现了些问题,比如C#不支持弱密钥(把密钥弄复杂点),因为没注意大小写造成加密结果不一致等等。编程这东西一个点都能让整个系统崩溃,所以小细节很重要!!!

public class DESHelper
{
  /// <summary>
  /// 将密码转成直接数组
  /// </summary>
  /// <param name="str"></param>
  /// <returns></returns>
  public static byte[] HexToBytes(String str)
  {
    if (str == null)
    {
      return null;
    }
    else if (str.Length < 2)
    {
      return null;
    }
    else
    {
      int len = str.Length / 2;
      byte[] buffer = new byte[len];
      for (int i = 0; i < len; i++)
      {
        var temp = str.Substring(i * 2, 2);
        buffer[i] = (byte)Convert.ToInt32(temp, 16);
      }
      return buffer;
    }
  }
  /// <summary>
  /// 3DES加密
  /// </summary>
  /// <param name="key"></param>
  /// <param name="data"></param>
  /// <returns></returns>
  public static byte[] GetDes3EncryptedText(byte[] key, byte[] data)
  {
    byte[] k = new byte[24];
    int len = data.Length;
    if (data.Length % 8 != 0)
    {
      len = data.Length - data.Length % 8 + 8;
    }
    byte[] needData = null;
    if (len != 0)
      needData = new byte[len];
    for (int i = 0; i < len; i++)
    {
      needData[i] = 0x00;
    }
    Buffer.BlockCopy(data, 0, needData, 0, data.Length);
    if (key.Length == 16)
    {
      Buffer.BlockCopy(key, 0, k, 0, key.Length);
      Buffer.BlockCopy(key, 0, k, 16, 8);
    }
    else
    {
      Buffer.BlockCopy(key, 0, k, 0, 24);
    }
    var des3 = new TripleDESCryptoServiceProvider();
    des3.Key = k;
    des3.Mode = CipherMode.ECB;
    des3.Padding = PaddingMode.Zeros;
    using (MemoryStream ms = new MemoryStream())
    using (CryptoStream cs = new CryptoStream(ms, des3.CreateEncryptor(), CryptoStreamMode.Write))
    {
      cs.Write(data, 0, data.Length);
      cs.FlushFinalBlock();
      return ms.ToArray();
    }
  }
  /// <summary>
  /// 将加密结果转成字符串
  /// </summary>
  /// <param name="data"></param>
  /// <returns></returns>
  public static String GetByte2Hex(byte[] data)
  {
    StringBuilder sb = new StringBuilder();
    for (int i = 0; i < data.Length; i++)
    {
      String temp = string.Format("{0:X}", ((int)data[i]) & 0xFF);
      for (int t = temp.Length; t < 2; t++)
      {
        sb.Append("0");
      }
      sb.Append(temp);
    }
    return sb.ToString();
  }
}

</div>

以上所述就是本文的全部内容了,希望大家能够喜欢。

</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • C# 3DES加密详解
  • C#的3DES加密解密算法实例代码

相关文章

  • 2017-05-28C#位移的介绍与例子
  • 2017-05-28C#页面之间跳转功能的小结
  • 2017-05-28C#调用dos窗口获取相关信息的方法
  • 2017-05-28web打印 window.print()介绍
  • 2017-05-28C#将图片和字节流互相转换并显示到页面上
  • 2017-05-28详解MongoDB for C#基础入门
  • 2017-05-28c#中 String和string的区别介绍
  • 2017-05-28C# 中将数值型数据转换为字节数组的方法
  • 2017-05-28C#实现大数字运算的实例代码
  • 2017-05-28C#与Java的MD5简单验证(实例代码)

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • C#进程监控方法实例分析
    • c#泛型学习详解 创建线性链表
    • C#不同类型的成员变量(字段)的默认值介绍
    • C# salt+hash 加密
    • 谈一谈autofac组件的实例范围
    • C#中序列化实现深拷贝,实现DataGridView初始化刷新的方法
    • C#使用webbrowser的常见用法实例
    • C#编写Windows服务实例代码
    • C#操作config文件的具体方法
    • 在.net应用程序中运行其它EXE文件的方法

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有