DES加密介绍

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

JAVA实现

加密

     代码有详细解释,不多废话。
     注意:DES加密和解密过程中,密钥长度都必须是8的倍数
  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. }

解密

    代码有详细注释,不多废话
  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. }

测试场景

      例如,我们可以利用如上函数对字符串进行加密解密,也可以对文件进行加密解密,如:
  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();

JAVA实现DES加密的更多相关文章

  1. 一个java的DES加密解密类转换成C#

    一个java的des加密解密代码如下: //package com.visionsky.util; import java.security.*; //import java.util.regex.P ...

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

    这篇文章主要介绍了兼容PHP和Java的des加密解密代码分享,适合如服务器是JAVA语言编写,客户端是PHP编写,并需要des加密解密的情况,需要的朋友可以参考下 作为一个iOS工程师来解决安卓的问 ...

  3. JAVA实现DES加密实现详解

    package util; import java.security.SecureRandom; import javax.crypto.spec.DESKeySpec; import javax.c ...

  4. C#用DES加密JAVA用DES解密,JAVA用DES加密C#用DES解密的实现

    这里贴出来的是可通用的C#与jav的DES加密类,希望对大家管用直接复制即可用 C#DES加密解密类 ///<summary><![CDATA[加密解密帮助类]]></s ...

  5. java 实现 DES加密 解密算法

    DES算法的入口参数有三个:Key.Data.Mode.其中Key为8个字节共64位,是DES算法的工作密钥:Data也为8个字节64位,是要被加密或被解密的数据:Mode为DES的工作方式,有两种: ...

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

    很多时候要对秘要进行持久化加密,此时的加密采用md5.采用对称加密的时候就采用DES方法了 import java.io.IOException; import java.security.Messa ...

  7. Android和java平台 DES加密解密互通程序及其不能互通的原因

    网上的demo一搜一大堆,但是,基本上都是一知半解(包括我).为什么呢?我在尝试分别在两个平台加密的时候,竟然发现Android DES 加密和java DES加密的程序不能互通.就是加密的结果不一样 ...

  8. IOS、java支持DES加密

    转载请注明博客地址:http://blog.csdn.net/mengxiangyue/article/details/40015727 近期在考虑数据加密方面的需求,所以对数据加密简单的看了一下,当 ...

  9. JAVA的DES加密解密在windows上测试一切正常,在linux上异常

    windows上加解密正常,linux上加密正常,解密时发生 如下异常,异常信息如下: [ERROR] 2018-10-15 09:30:35,998 method:com.iscas.ippc.co ...

随机推荐

  1. HDU-4747 Mex 线段树

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4747 题意:求一个数列中,所有mex(L,R)的和. 注意到mex是单调不降的,那么首先预处理出mex ...

  2. Gym 100507D Zhenya moves from the dormitory (模拟)

    Zhenya moves from the dormitory 题目链接: http://acm.hust.edu.cn/vjudge/contest/126546#problem/D Descrip ...

  3. CodeForces 173C Spiral Maximum (想法、模拟)

    Spiral Maximum Time Limit:3000MS     Memory Limit:262144KB     64bit IO Format:%I64d & %I64u Sub ...

  4. Linux 获取文件时间信息 判断文件是否存在

    获取文件时间戳   (1)查看全部信息: stat e4.txt 范例: [root@localhost ~]# stat e4.txt File: “e4.txt” Size: 0 Blocks: ...

  5. JavaIO(03)字节流--OutputStream and InputStream

    IO概述:   IO流用来处理设备之间的数据传输 java对数据的操作是通过流的方式 java用于操作流的对象都在IO包中 流按操作数据分为两种:字节流与字符流(编码表) 流按流向分为:输入流,输出流 ...

  6. SaltStack 最新版WebUI部署

    saltstack web uiweb平台界面 saltapi项目主页:http://salt-api.readthedocs.org/en/latest/ halite 项目主页:https://g ...

  7. 关于TCP主动关闭连接中的wait_timeout

    首先我们先来回顾一下tcp关闭连接的过程: 假设A和B连接状态为EST,A需要主动关闭: A发送FIN给B,并将状态更改为FIN_WAIT1, B接收到FIN将状态更改为CLOSE_WAIT,并回复A ...

  8. setbuf和freopen

    看memcached代码的时候学习了一个api,setbuf,可以设置文件流的缓冲区.        #include <stdio.h> void setbuf(FILE *stream ...

  9. Oracle RMAN 清除归档日志

    在开发环境及UAT环境经常碰到需要清除归档日志的情形,对于这个问题方法有很多.可以直接使用rm方式清除归档日志,也可以使用find命令来查找符合条件的记录来清除归档日志,或者直接写个shell脚本来搞 ...

  10. 怎么修改路由器地址的默认IP

    参考文章:http://jingyan.baidu.com/article/4b52d7026e14effc5c774b30.html  一.怎么修改路由器地址的默认IP 目前绝大多数品牌有线或无线路 ...