import cn.eaglelink.module.base.other.MessageEncrypt;
import java.io.FileOutputStream;
import java.io.InputStream;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
import java.security.Key;
import java.security.SecureRandom;
import javax.crypto.Cipher;
import javax.crypto.KeyGenerator;
import org.apache.log4j.Logger;
/**
* DES加密算法来加密消息xml字符串
* @author song.li
*
*/
public class DESEncryptMessage implements MessageEncrypt {
private static Logger logger = Logger.getLogger(DESEncryptMessage.class);
// private Key key;
/**
* 根据参数生成KEY
* @param strKey
*/
public void saveDesKey(String strKey) {
logger.debug("进入创建DES密钥方法...");
Key key;
try{
KeyGenerator _generator = KeyGenerator.getInstance("DES");
_generator.init(new SecureRandom(strKey.getBytes()));
//生成密钥
key = _generator.generateKey();
_generator=null;
//将密钥保存到文件中
FileOutputStream fos = new FileOutputStream("d:/DesKey.xml");
ObjectOutputStream oos = new ObjectOutputStream(fos);
oos.writeObject(key);
oos.close();
}catch(Exception e){
logger.error("创建DES密钥失败!");
}
}
/**
*获得DES加密的密钥。在交易处理的过程中应该定时更换密钥。
* @return kp
*/
public static Key getKey() {
logger.debug("进入取得DES密钥方法...");
Key kp = null;
try {
String fileName = "DesKey.xml";
InputStream is = DESEncryptMessage.class.getClassLoader().getResourceAsStream(fileName);
ObjectInputStream oos = new ObjectInputStream(is);
kp = (Key) oos.readObject();
oos.close();
}catch(Exception e){
logger.error("取得DES密钥失败!");
}
return kp;
}
/**
* 加密String明文输入,String密文输出
* @param messageXml
* @return
*/
@Override
public String encryptMessage(String messageXml) {
logger.debug("进入DES加密的主方法...");
//具体实现DES加密算法来实现消息xml的加密
byte[] byteMi = null;
byte[] byteMing = null;
String strMi = "";
try {
return byte2hex(getEncCode (messageXml.getBytes() ) );
// byteMing = strMing.getBytes("UTF8");
// byteMi = this.getEncCode(byteMing);
// strMi = new String( byteMi,"UTF8");
}catch(Exception e){
logger.error("使用DES算法将xml字符串加密失败!");
}finally{
byteMing = null;
byteMi = null;
}
return strMi;
}
/**
* 加密以byte[]明文输入,byte[]密文输出
* @param byteS
* @return
*/
private byte[] getEncCode(byte[] byteS) {
logger.debug("进入DES加密以byte[]明文输入,byte[]密文输出方法...");
byte[] byteFina = null;
Cipher cipher;
try {
cipher = Cipher.getInstance("DES");
cipher.init(Cipher.ENCRYPT_MODE, getKey());
byteFina = cipher.doFinal(byteS);
}catch(Exception e) {
logger.error("DES加密以byte[]明文输入,byte[]密文输出失败!");
}finally {
cipher = null;
}
return byteFina;
}
/**
* 二行制转字符串
* @param b
* @return
*/
public static String byte2hex(byte[] b) { //一个字节的数,
logger.debug("进入二行制转字符串方法...");
// 转成16进制字符串
String hs = "";
String stmp = "";
for (int n = 0; n < b.length; n++) {
//整数转成十六进制表示
stmp = (java.lang.Integer.toHexString(b[n] & 0XFF));
if (stmp.length() == 1){
hs = hs + "0" + stmp;
}else{
hs = hs + stmp;
}
}
return hs.toUpperCase(); //转成大写
}
/**
* 解密 以String密文输入,String明文输出
* @param strMi
* @return
*/
public String getDesString(String strMi) {
byte[] byteMing = null;
byte[] byteMi = null;
String strMing = "";
try {
return new String(getDesCode(hex2byte(strMi.getBytes()) ));
// byteMing = this.getDesCode(byteMi);
// strMing = new String(byteMing,"UTF8");
}catch(Exception e) {
e.printStackTrace();
}finally {
byteMing = null;
byteMi = null;
}
return strMing;
}
/**
* 解密以byte[]密文输入,以byte[]明文输出
* @param byteD
* @return
*/
private byte[] getDesCode(byte[] byteD) {
Cipher cipher;
byte[] byteFina=null;
try{
cipher = Cipher.getInstance("DES");
cipher.init(Cipher.DECRYPT_MODE, getKey());
byteFina = cipher.doFinal(byteD);
}catch(Exception e){
e.printStackTrace();
}finally{
cipher=null;
}
return byteFina;
}
public static byte[] hex2byte(byte[] b) {
if((b.length%2)!=0)
throw new IllegalArgumentException("长度不是偶数");
byte[] b2 = new byte[b.length/2];
for (int n = 0; n < b.length; n+=2) {
String item = new String(b,n,2);
// 两位一组,表示一个字节,把这样表示的16进制字符串,还原成一个进制字节
b2[n/2] = (byte)Integer.parseInt(item,16);
}
return b2;
}
public static void main(String[] args) {
DESEncryptMessage des=new DESEncryptMessage();//实例化一个对像
des.saveDesKey("aadd");//生成密匙
String result=des.encryptMessage("helloworld");
System.out.println("生成的密文为--result="+result);
String result2=des.getDesString(result);
System.out.println("解密后的原文为--result="+result2);
}
}
分享到:
相关推荐
在给定的“des加密例程”中,可能包含了一个调用动态链接库(DLL)实现DES加密解密的示例代码。DLL是Windows操作系统中的一种共享库,可以被多个程序同时调用,节省内存资源并便于代码复用。这个示例可能涉及以下...
标题中的“3DES加密解密工具”指的是一个用于执行三重数据加密标准(3DES,Triple DES)的软件工具,这种工具通常用于保护敏感数据的安全,确保信息在传输过程中的机密性。3DES是DES(Data Encryption Standard,...
6. **执行D3DES**:首先用第一个密钥执行DES加密,然后用第二个密钥执行DES解密,最后再用第一个密钥进行一次DES加密。这个过程就是D3DES的核心。 7. **密文后处理**:加密完成后,对密文进行逆初始置换,得到最终...
5. **编程实践**:在训练中,你需要实现一个TCP聊天程序,其中通信内容通过DES加密和解密。这将涉及到对TCP协议的理解,使用socket编程接口,以及在代码中集成DES加密算法的实现。 总结来说,基于DES加密的TCP聊天...
在SQL Server中进行DES加密是保护敏感数据的一种常见方法,特别是在C#应用程序中与数据库交互时。DES(Data Encryption Standard)是一种对称加密算法,它使用相同的密钥进行加密和解密,提供了一种相对快速的数据...
这需要创建一个.NET类库项目,实现DES加密解密功能,然后在VBA中通过CreateObject或早绑定的方式调用这些函数。 以下是VB.NET中实现DES加密解密的简单示例代码: ```vbnet Imports System.IO Imports System....
DES加密解密算法的C语言实现 DES(Data Encryption Standard)是一种对称密钥 BLOCK 加密算法,使用 56 位密钥对 64 位数据块进行加密。下面是 DES 加密解密算法的 C 语言实现的知识点总结。 字节与二进制转换 在...
在Delphi编程环境中,实现DES加密和解密是一项常见的任务,特别是在处理敏感信息时。 标题"DES加密_delphi_加解密_des_"所涉及的核心知识点是: 1. **DES算法**:DES是一种64位块密码,使用56位的密钥进行加密。它...
总结来说,这个“Qt写的DES加密算法展示程序”是一个学习和实践密码学的好例子,它结合了经典的DES加密算法和现代的Qt开发框架。对于希望了解这两方面的开发者,这是一个很好的起点,可以从中探索数据安全和GUI编程...
总结来说,DES加密算法是一种重要的对称加密技术,虽然因为其相对较短的密钥长度(56位)而逐渐被更安全的算法如AES所取代,但它在密码学教育和理解加密原理方面仍具有重要价值。C语言实现的DES算法源码可以帮助我们...
3DES(Triple Data Encryption Algorithm,三重数据加密算法)是一种强化版的DES(Data Encryption Standard)加密算法,它通过三次应用DES加密过程来提高安全性。在JavaScript中实现3DES加密通常是为了在网络通信中...
单次DES加密使用同一个密钥对数据进行一次加密;而双倍DES(也称为2DES或2-key TDEA)则是先用一个密钥加密,然后用另一个密钥再次加密,以提高安全性。不过,双倍DES并不完全等同于两倍的安全性,因为它存在中间...
对数据进行单DES或者3DES加密或者解密,如果密码长度为8字节则为DES加密或者解密
Java写的DES的一个类”表明了这个压缩包包含两个部分:一个是使用Delphi编程语言编写的用于执行DES(Data Encryption Standard)加密和解密的小程序,另一个是用Java实现的DES加密类。DES是一种广泛使用的对称加密...
### DES加密算法实验知识点 #### 一、实验背景与目的 **DES(Data Encryption Standard)加密算法**是一种经典的对称加密技术,在信息安全领域占据着重要地位。本实验旨在通过实践操作,加深对DES算法工作原理的...
实验要求在Linux或Windows操作系统上开发一个基于DES加密的TCP聊天程序,具体要求包括: 1. 实现DES算法的加密和解密功能,对字符串进行加密和解密操作,了解其基本流程。 2. 使用TCP协议建立可靠的双向通信,简化...
这个DEMO是一个很好的学习资源,可以帮助开发者理解和实践DES加密解密技术,同时也可以作为不同语言间加密解密兼容性的参考示例。在实际项目中,由于DES的安全性相对较低,现在更多使用更安全的AES(Advanced ...
DES加密在信息技术领域中是一种广泛使用的对称加密算法,全称为Data Encryption Standard,中文译为数据加密标准。VB,即Visual Basic,是微软公司开发的一种编程语言,它提供了丰富的控件和直观的用户界面设计工具...
在VB6.0(Visual Basic 6.0)环境中实现DES加密解密是编程中常见的一种需求,主要用于保护敏感数据的安全。下面将详细阐述DES加密解密原理及其在VB6.0中的实现方法。 1. **DES加密原理**: - **初始置换**:将明文...
C_DesEncryptFile.cpp和C_DesEncryptFile.h文件很可能包含了一个用于实现文件加密的接口,它可能先生成一个随机的DES密钥,使用RSA加密这个密钥,然后用DES加密文件内容,最后将加密后的文件和RSA加密的密钥保存下来...