最近一个项目中,因为服务端是用的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[]; int len = data.length;
if (data.length % != ) {
len = data.length - data.length % + ;
}
byte[] needData = null;
if (len != )
needData = new byte[len]; for (int i = ; i < len; i++) {
needData[i] = 0x00;
} System.arraycopy(data, , needData, , data.length); if (key.length == ) {
System.arraycopy(key, , k, , key.length);
System.arraycopy(key, , k, , );
} else {
System.arraycopy(key, , k, , );
} 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[]; int len = data.length;
if (data.length % != ) {
len = data.length - data.length % + ;
}
byte[] needData = null;
if (len != )
needData = new byte[len]; for (int i = ; i < len; i++) {
needData[i] = 0x00;
} System.arraycopy(data, , needData, , data.length); if (key.length == ) {
System.arraycopy(key, , k, , key.length);
System.arraycopy(key, , k, , );
} else {
System.arraycopy(key, , k, , );
}
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(, );
} public static String byte2hex(byte[] data) {
StringBuffer sb = new StringBuffer();
for (int i = ; i < data.length; i++) {
String temp = Integer.toHexString(((int) data[i]) & 0xFF);
for (int t = temp.length(); t < ; t++) {
sb.append("");
}
sb.append(temp);
}
return sb.toString();
} public static byte[] hexToBytes(String str) {
if (str == null) {
return null;
} else if (str.length() < ) {
return null;
} else {
int len = str.length() / ;
byte[] buffer = new byte[len];
for (int i = ; i < len; i++) {
buffer[i] = (byte) Integer.parseInt(str.substring(i * , i * + ), );
}
return buffer;
}
}
}

  因为客户端只负责数据加密,所以我这里只写了加密的部分。由于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 < )
{
return null;
}
else
{
int len = str.Length / ;
byte[] buffer = new byte[len];
for (int i = ; i < len; i++)
{
var temp = str.Substring(i * , );
buffer[i] = (byte)Convert.ToInt32(temp, );
}
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[];
int len = data.Length;
if (data.Length % != )
{
len = data.Length - data.Length % + ;
}
byte[] needData = null;
if (len != )
needData = new byte[len]; for (int i = ; i < len; i++)
{
needData[i] = 0x00;
} Buffer.BlockCopy(data, , needData, , data.Length); if (key.Length == )
{
Buffer.BlockCopy(key, , k, , key.Length);
Buffer.BlockCopy(key, , k, , );
}
else
{
Buffer.BlockCopy(key, , k, , );
} 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, , 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 = ; i < data.Length; i++)
{
String temp = string.Format("{0:X}", ((int)data[i]) & 0xFF);
for (int t = temp.Length; t < ; t++)
{
sb.Append("");
}
sb.Append(temp);
}
return sb.ToString();
}
}

C# 3DES加密的更多相关文章

  1. Des与3Des加密解密

    /// <summary> /// Des和3Des算法 /// </summary> public class Des { /// <summary> /// D ...

  2. iOS 3DES加密解密(一行代码搞定)

    3DES(或称为Triple DES)是三重数据加密算法(TDEA,Triple Data Encryption Algorithm)块密码的通称.它相当于是对每个数据块应用三次DES加密算法.由于计 ...

  3. 简进祥==iOS 3DES加密解密

    3DES(或称为Triple DES)是三重数据加密算法(TDEA,Triple Data Encryption Algorithm)块密码的通称.它相当于是对每个数据块应用三次DES加密算法.由于计 ...

  4. JAVA和C# 3DES加密解密

    最近 一个项目.net 要调用JAVA的WEB SERVICE,数据采用3DES加密,涉及到两种语言3DES一致性的问题, 下面分享一下, 这里的KEY采用Base64编码,便用分发,因为Java的B ...

  5. C# Java 3DES加密解密 扩展及修正\0 问题

    注: C#已亲测及做扩展, Java 部分未做验证 /// <summary> /// 3DES加密解密 /// ------------------------------------- ...

  6. JAVA安卓和C# 3DES加密解密的兼容性问题(2013年8月修改版)

    近 一个项目.net 要调用JAVA的WEB SERVICE,数据采用3DES加密,涉及到两种语言3DES一致性的问题, 下面分享一下, 这里的KEY采用Base64编码,便用分发,因为Java的By ...

  7. 使用openssl库实现des,3des加密

    原文地址: 使用openssl库实现des,3des加密 主要是调整了一下格式,以及一些变量的类型,以解决在VC2008下无法编译通过的问题. #include <stdio.h> #in ...

  8. Java中3DES加密解密与其他语言(如C/C++)通信

    国内私募机构九鼎控股打造APP,来就送 20元现金领取地址:http://jdb.jiudingcapital.com/phone.html内部邀请码:C8E245J (不写邀请码,没有现金送)国内私 ...

  9. 【推荐】JAVA基础◆浅谈3DES加密解密

    国内私募机构九鼎控股打造APP,来就送 20元现金领取地址:http://jdb.jiudingcapital.com/phone.html内部邀请码:C8E245J (不写邀请码,没有现金送)国内私 ...

随机推荐

  1. AMD加载器实现笔记(一)

    之前研究过AMD,也写过一篇关于AMD的文章<以代码爱好者角度来看AMD与CMD>.代码我是有看过的,基本的原理也都明白,但实际动手去实现却是没有的.因为今年计划的dojo教程<静静 ...

  2. 正式工作的前奏——一个Java程序员的实习总结(1)

    不知不觉,到深圳实习已经三个礼拜了.跟在暑假的三个半月实习不一样,这次收获更多,感受更好,算是摆脱了那次实习给我带来的阴影(这个会放到以后才说). 在知乎上,有这么一个问题,你现在最想跟刚工作时的你说 ...

  3. 知方可补不足~Sqlserver发布订阅与sql事务的关系

    回到目录 前几讲说了一下通过sqlserver的发布与订阅来实现数据的同步,再通过EF这个ORM架构最终实现架构系统的读写分离,而在使用发布与订阅来实现数据同步时,需要我们注意几点,那就是当操作被使用 ...

  4. 知方可补不足~SqlServer自动备份数据库及清理备份文件

    回到目录 对于SQLSERVER这个关系型数据库来说,为了保持数据的安全,备份是必须的,当你的一个误操作导致数据丢失,这可能是灾难性的,是不被允许发生的,这时,我们必须要做好定期的备份工作,如我们可以 ...

  5. 爱上MVC~为CheckBoxFor和RadioButtonFor加个扩展方法吧(希望MVC5把这方法收纳——呵呵)

    回到目录 说在前 我都是喜欢把问题复杂化,还有总是喜欢把问题简单化,偷懒化,这也需就是一个程序员的追求吧,呵呵. 我不太喜欢重复的东西,当你看到页面上有一个以上相同的代码时,那可以说,你的代码有重构的 ...

  6. 锋利的JQuery —— DOM操作

    图片猛戳链接

  7. Atitit 多继承实现解决方案 java c#

    Atitit 多继承实现解决方案 java c# Java c#都没有提供多继承的解决方案..默认从语言级别以及没办法多继承了. 只可以崽类库的级别实现拉.. 继承的原理就是,使用一个内部super指 ...

  8. Atitit截屏功能的设计解决方案

    Atitit截屏功能的设计解决方案 自己实现.... 使用快捷键.. 弹出自己的win,,背景是屏幕快照 点击鼠标光标变成十字状态 出现截屏窗口调整截屏窗口位置与大小 释放鼠标,三个btn,,  复制 ...

  9. VMware Workstation cannot connect to the virtual machine 解决方案

    今天 打开虚拟机 忽然遇到这个问题: VMware Workstation cannot connect to the virtual machine. Make sure you have righ ...

  10. 在 xampp 环境下安装 laravel

    网上搜了很多教程,很多都是采用命令行安装的.但是对于web前端来说,根本就不知道在干吗! 于是,打算写一篇文章,来教后面的人如何在 XAMPP 环境下安装 laravel. 初步认识 XAMPP(Ap ...