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. Apache Spark Mesos

    Mesos是一个资源管理框架,提供类似于YARN的功能. 用户可以在其中插件式地运行Spark. MapReduce. Tez等计算框架的任务. Mesos会对资源和任务进行隔离,并实现高效的资源任务 ...

  2. Spark SQL概念学习系列之SQL on Spark的简介(三)

    AMPLab 将大数据分析负载分为三大类型:批量数据处理.交互式查询.实时流处理.而其中很重要的一环便是交互式查询. 大数据分析栈中需要满足用户 ad-hoc.reporting. iterative ...

  3. Java设计模式系列之动态代理模式(转载)

    代理设计模式 定义:为其他对象提供一种代理以控制对这个对象的访问. 动态代理使用 java动态代理机制以巧妙的方式实现了代理模式的设计理念. 代理模式示例代码 public interface Sub ...

  4. NSLog说明

    %@ 对象 %d,%i 整型 (%i的老写法) %hd 短整型 %ld , %lld 长整型 %u 无符整型 %f 浮点型和double型 %0.2f 精度浮点数,只保留两位小数 %x,%X 二进制整 ...

  5. MongoDB的update有关问题(JAVA)——如何一次更新所有的相同记录

    MongoDB的update问题(JAVA)——怎么一次更新所有的相同记录用如下这个函数:public WriteResult update(DBObject q,  DBObject o,  boo ...

  6. POJ1328Radar Installation(贪心)

    对于每一个点,可以找到他在x轴上的可行区域,这样的话就变为了对区间的贪心. #include<iostream> #include<stdio.h> #include<s ...

  7. C#学习笔记(九):LINQ和表达式树

    LINQ LINQ:语言集成查询(Language Integrated Query)是一组用于c#和Visual Basic语言的扩展.它允许编写C#或者Visual Basic代码以查询数据库相同 ...

  8. Ioc容器Autofac系列(2)-- asp.net mvc中整合autofac

    经过上篇蜻蜓点水的介绍后,本篇通过实例快速上手autofac,展示当asp.net mvc引入了autofac之后会带来什么. 创建Asp.net MVC并引入Autofac 首先,创建一个MVC站点 ...

  9. nexus建立maven仓库私服及Snapshots、release的版本管理

    环境搭建   1.linux安装maven   wget http://mirrors.cnnic.cn/apache/maven/maven-3/3.0.5/binaries/apache-mave ...

  10. VC中监测程序运行时间(二)-毫秒级

    /* * 微秒级计时器,用来统计程序运行时间 * http://blog.csdn.net/hoya5121/article/details/3778487#comments * //整理 [10/1 ...