`
songshu8312
  • 浏览: 18924 次
  • 性别: Icon_minigender_1
  • 来自: 北京
最近访客 更多访客>>
社区版块
存档分类
最新评论

DES加密(一)

阅读更多

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加密解密_Des加密解密_DES加密_

    在给定的“des加密例程”中,可能包含了一个调用动态链接库(DLL)实现DES加密解密的示例代码。DLL是Windows操作系统中的一种共享库,可以被多个程序同时调用,节省内存资源并便于代码复用。这个示例可能涉及以下...

    3DES加密解密工具

    标题中的“3DES加密解密工具”指的是一个用于执行三重数据加密标准(3DES,Triple DES)的软件工具,这种工具通常用于保护敏感数据的安全,确保信息在传输过程中的机密性。3DES是DES(Data Encryption Standard,...

    STM32上实现D3DES加密

    6. **执行D3DES**:首先用第一个密钥执行DES加密,然后用第二个密钥执行DES解密,最后再用第一个密钥进行一次DES加密。这个过程就是D3DES的核心。 7. **密文后处理**:加密完成后,对密文进行逆初始置换,得到最终...

    实验一 基于DES加密的TCP聊天程序1

    5. **编程实践**:在训练中,你需要实现一个TCP聊天程序,其中通信内容通过DES加密和解密。这将涉及到对TCP协议的理解,使用socket编程接口,以及在代码中集成DES加密算法的实现。 总结来说,基于DES加密的TCP聊天...

    sql server 中进行des加密

    在SQL Server中进行DES加密是保护敏感数据的一种常见方法,特别是在C#应用程序中与数据库交互时。DES(Data Encryption Standard)是一种对称加密算法,它使用相同的密钥进行加密和解密,提供了一种相对快速的数据...

    VB实现DES加密解密算法,vb加密和解密,VBA

    这需要创建一个.NET类库项目,实现DES加密解密功能,然后在VBA中通过CreateObject或早绑定的方式调用这些函数。 以下是VB.NET中实现DES加密解密的简单示例代码: ```vbnet Imports System.IO Imports System....

    C语言实现DES加密解密算法

    DES加密解密算法的C语言实现 DES(Data Encryption Standard)是一种对称密钥 BLOCK 加密算法,使用 56 位密钥对 64 位数据块进行加密。下面是 DES 加密解密算法的 C 语言实现的知识点总结。 字节与二进制转换 在...

    DES加密_delphi_加解密_des_

    在Delphi编程环境中,实现DES加密和解密是一项常见的任务,特别是在处理敏感信息时。 标题"DES加密_delphi_加解密_des_"所涉及的核心知识点是: 1. **DES算法**:DES是一种64位块密码,使用56位的密钥进行加密。它...

    Qt写的DES加密算法展示程序

    总结来说,这个“Qt写的DES加密算法展示程序”是一个学习和实践密码学的好例子,它结合了经典的DES加密算法和现代的Qt开发框架。对于希望了解这两方面的开发者,这是一个很好的起点,可以从中探索数据安全和GUI编程...

    DES加密算法(c语言实现)

    总结来说,DES加密算法是一种重要的对称加密技术,虽然因为其相对较短的密钥长度(56位)而逐渐被更安全的算法如AES所取代,但它在密码学教育和理解加密原理方面仍具有重要价值。C语言实现的DES算法源码可以帮助我们...

    3DES加密js前端示例

    3DES(Triple Data Encryption Algorithm,三重数据加密算法)是一种强化版的DES(Data Encryption Standard)加密算法,它通过三次应用DES加密过程来提高安全性。在JavaScript中实现3DES加密通常是为了在网络通信中...

    C++ 代码实现DES加密解密源代码类

    单次DES加密使用同一个密钥对数据进行一次加密;而双倍DES(也称为2DES或2-key TDEA)则是先用一个密钥加密,然后用另一个密钥再次加密,以提高安全性。不过,双倍DES并不完全等同于两倍的安全性,因为它存在中间...

    DES/3DES加密解密工具

    对数据进行单DES或者3DES加密或者解密,如果密码长度为8字节则为DES加密或者解密

    用delphi写的一个des的加密解密小程序,java写的des的一个类

    Java写的DES的一个类”表明了这个压缩包包含两个部分:一个是使用Delphi编程语言编写的用于执行DES(Data Encryption Standard)加密和解密的小程序,另一个是用Java实现的DES加密类。DES是一种广泛使用的对称加密...

    DES加密算法实验

    ### DES加密算法实验知识点 #### 一、实验背景与目的 **DES(Data Encryption Standard)加密算法**是一种经典的对称加密技术,在信息安全领域占据着重要地位。本实验旨在通过实践操作,加深对DES算法工作原理的...

    基于des加密的tcp聊天1

    实验要求在Linux或Windows操作系统上开发一个基于DES加密的TCP聊天程序,具体要求包括: 1. 实现DES算法的加密和解密功能,对字符串进行加密和解密操作,了解其基本流程。 2. 使用TCP协议建立可靠的双向通信,简化...

    DES加密DEMO(C#与JAVA)

    这个DEMO是一个很好的学习资源,可以帮助开发者理解和实践DES加密解密技术,同时也可以作为不同语言间加密解密兼容性的参考示例。在实际项目中,由于DES的安全性相对较低,现在更多使用更安全的AES(Advanced ...

    DES加密 VB源码 (一)

    DES加密在信息技术领域中是一种广泛使用的对称加密算法,全称为Data Encryption Standard,中文译为数据加密标准。VB,即Visual Basic,是微软公司开发的一种编程语言,它提供了丰富的控件和直观的用户界面设计工具...

    DES加密解密VB6.0源代码

    在VB6.0(Visual Basic 6.0)环境中实现DES加密解密是编程中常见的一种需求,主要用于保护敏感数据的安全。下面将详细阐述DES加密解密原理及其在VB6.0中的实现方法。 1. **DES加密原理**: - **初始置换**:将明文...

    DES 加密,RSA 加密,DES 文件加密

    C_DesEncryptFile.cpp和C_DesEncryptFile.h文件很可能包含了一个用于实现文件加密的接口,它可能先生成一个随机的DES密钥,使用RSA加密这个密钥,然后用DES加密文件内容,最后将加密后的文件和RSA加密的密钥保存下来...

Global site tag (gtag.js) - Google Analytics