JAVA实现DES加密

JAVA实现DES加密

DES加密介绍

DES是一种对称加密算法,所谓对称加密算法即:加密和解密使用相同密钥的算法。DES加密算法出自IBM的研究,后来被美国政府正式采用,之后开始广泛流传,但是近些年使用越来越少,因为DES使用56位密钥,以现代计算能力,24小时内即可被破解。虽然如此,在某些简单应用中,我们还是可以使用DES加密算法,本文简单讲解DES的JAVA实现。

JAVA实现

加密

代码有详细解释,不多废话。

注意:DES加密和解密过程中,密钥长度都必须是8的倍数

[java] view plaincopy

  1. public byte[] desCrypto(byte[] datasource, String password) {
  2. try{
  3. SecureRandom random = new SecureRandom();
  4. DESKeySpec desKey = new DESKeySpec(password.getBytes());
  5. //创建一个密匙工厂,然后用它把DESKeySpec转换成
  6. SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES");
  7. SecretKey securekey = keyFactory.generateSecret(desKey);
  8. //Cipher对象实际完成加密操作
  9. Cipher cipher = Cipher.getInstance("DES");
  10. //用密匙初始化Cipher对象
  11. cipher.init(Cipher.ENCRYPT_MODE, securekey, random);
  12. //现在,获取数据并加密
  13. //正式执行加密操作
  14. return cipher.doFinal(datasource);
  15. }catch(Throwable e){
  16. e.printStackTrace();
  17. }
  18. return null;
  19. }

解密

代码有详细注释,不多废话

[java] view plaincopy

  1. private byte[] decrypt(byte[] src, String password) throws Exception {
  2. // DES算法要求有一个可信任的随机数源
  3. SecureRandom random = new SecureRandom();
  4. // 创建一个DESKeySpec对象
  5. DESKeySpec desKey = new DESKeySpec(password.getBytes());
  6. // 创建一个密匙工厂
  7. SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES");
  8. // 将DESKeySpec对象转换成SecretKey对象
  9. SecretKey securekey = keyFactory.generateSecret(desKey);
  10. // Cipher对象实际完成解密操作
  11. Cipher cipher = Cipher.getInstance("DES");
  12. // 用密匙初始化Cipher对象
  13. cipher.init(Cipher.DECRYPT_MODE, securekey, random);
  14. // 真正开始解密操作
  15. return cipher.doFinal(src);
  16. }

测试场景

例如,我们可以利用如上函数对字符串进行加密解密,也可以对文件进行加密解密,如:

[java] view plaincopy

  1. //待加密内容
  2. String str = "测试内容";
  3. //密码,长度要是8的倍数
  4. String password = "12345678";
  5. byte[] result = DESCrypto.desCrypto(str.getBytes(),password);
  6. System.out.println("加密后内容为:"+new String(result));
  7. //直接将如上内容解密
  8. try {
  9. byte[] decryResult = des.decrypt(result, password);
  10. System.out.println("加密后内容为:"+new String(decryResult));
  11. } catch (Exception e1) {
  12. e1.printStackTrace();
  13. }
时间: 2024-07-29 12:37:14

JAVA实现DES加密的相关文章

兼容PHP和Java的des加密解密代码分享

这篇文章主要介绍了兼容PHP和Java的des加密解密代码分享,适合如服务器是JAVA语言编写,客户端是PHP编写,并需要des加密解密的情况,需要的朋友可以参考下 php <?php class DES { var $key; var $iv; //偏移量 function DES($key, $iv=0) { $this->key = $key; if($iv == 0) { $this->iv = $key; } else { $this->iv = $iv; } } //加

关于Objective-c和Java下DES加密保持一致的方式

转载自:http://www.cnblogs.com/janken/archive/2012/04/05/2432930.html 最近做了一个移动项目,是有服务器和客户端类型的项目,客户端是要登录才行的,登录的密码要用DES加密,服务器是用Java开发的,客户端要同时支持多平台(Android.iOS),在处理iOS的DES加密的时候遇到了一些问题,起初怎么调都调不成和Android端生成的密文相同.最终一个忽然的想法让我找到了问题的所在,现在将代码总结一下,以备自己以后查阅. 首先,Java

IOS、java支持DES加密

最近在考虑数据加密方面的需求,所以对数据加密简单的看了一下,当然不是看的原理,只是看看怎么能够实现.现在我们需要实现的是移动端和后台 (java)数据加解密的配合,开始的时候考虑的使用RSA,因为RSA是非对称加密,更加安全点,但是RSA加密的过程中,ios公钥加密的数据,后台 java是能够解密成功,但是后台java私钥加密的东西,前端ios,就没有解密成功,实验了很多方法,最终也没有成功,所以就放弃了,转向了安全性差 一点的DES加密. 对于DES.RSA的介绍,自己百度去吧,因为我也说不明

JAVA使用DES加密解密

在使用DES加密解密的时候,遇到了一些问题,廖记一下.如有哪位大神亲临留言指点,不胜感激. 先上代码: public DESUtil() { } //密码,长度要是8的倍数 注意此处为简单密码 简单应用 要求不高时可用此密码 /*DES是一种对称加密算法,所谓对称加密算法即:加密和解密使用相同密钥的算法.DES加密算法出自IBM的研究,后来被美国政府正式采用,之后开始广泛流传,但是近些年使用越来越少,因为DES使用56位密钥,以现代计算能力,24小时内即可被破解.*/ private stati

java 实现 DES加密 解密算法

DES算法的入口参数有三个:Key.Data.Mode.其中Key为8个字节共64位,是DES算法的工作密钥:Data也为8个字节64位,是要被加密或被解密的数据:Mode为DES的工作方式,有两种:加密或解密.  DES算法是这样工作的:如Mode为加密,则用Key 去把数据Data进行加密, 生成Data的密码形式(64位)作为DES的输出结果:如 Mode为解密,则用Key去把密码形式的数据Data解密,还原为Data的明码形式(64位)作为DES的输出结果.在通信网络的两端,双方约定一致

java实现DES加密与解密,md5加密

很多时候要对秘要进行持久化加密,此时的加密采用md5.采用对称加密的时候就采用DES方法了 1 import java.io.IOException; 2 import java.security.MessageDigest; 3 import java.security.SecureRandom; 4 5 import javax.crypto.Cipher; 6 import javax.crypto.SecretKey; 7 import javax.crypto.SecretKeyFac

JAVA实现DES加密实现详解

package util; import java.security.SecureRandom;import javax.crypto.spec.DESKeySpec;import javax.crypto.SecretKeyFactory;import javax.crypto.SecretKey;import javax.crypto.Cipher; /** DES加密介绍DES是一种对称加密算法,所谓对称加密算法即:加密和解密使用相同密钥的算法.DES加密算法出自IBM的研究, 后来被美国

(iOS)Base64加密和DES加密、以及JAVA和iOS中DES加密统一性问题

我们在项目中为了安全方面的考虑,通常情况下会选择一种加密方式对需要安全性的文本进行加密,而Base64加密和DES64加密是常用的加密算法.我记得我在前一个项目中使用的就是这两种加密算法的结合:Base64 + DES加密.当然这需要移动端和后台服务器做一个统一. 1.Base64加解密 值得一提的是:apple提供了基础的Base64加解密算法.这样我们就可以直接使用方法去实现Base64加解密.先看一下apple都提供了哪些方法: @interface NSData (NSDataBase6

使用C# DES解密java DES加密的字符串

转自 microAllen 最近需要使用C#的DES解密工具类解密字符串,但是要解密的字符串是使用java进行DES加密的,去网上查了关于C#和java关于DES加密解密的资料,发现可以相互加密解密的时候,java进行DES加密一般都会写成如下:public static byte[] encrypt(String message, String key) throws Exception {     Cipher cipher = Cipher.getInstance("DES/CBC/PKC