desdesedejavaaes

    接下来我们介绍对称加密算法,最常用的莫过于DES数据加密算法。

DES

DES-Data Encryption Standard,即数据加密算法。是IBM公司于1975年研究成功并公开发表的。DES算法的入口参数有三个:Key、Data、Mode。其中Key为8个字节共64位,是DES算法的工作密钥;Data也为8个字节64位,是要被加密或被解密的数据;Mode为DES的工作方式,有两种:加密或解密。

  DES算法把64位的明文输入块变为64位的密文输出块,它所使用的密钥也是64位。







通过java代码实现如下:Coder类见 Java加密技术(一)

Java代码  收藏代码

import java.security.Key; 

import java.security.SecureRandom; 

 

import javax.crypto.Cipher; 

import javax.crypto.KeyGenerator; 

import javax.crypto.SecretKey; 

import javax.crypto.SecretKeyFactory; 

import javax.crypto.spec.DESKeySpec; 

 

 

/**

* DES安全编码组件



* <pre>

* 支持 DES、DESede(TripleDES,就是3DES)、AES、Blowfish、RC2、RC4(ARCFOUR)

* DES                  key size must be equal to 56

* DESede(TripleDES)    key size must be equal to 112 or 168

* AES                  key size must be equal to 128, 192 or 256,but 192 and 256 bits may not be available

* Blowfish             key size must be multiple of 8, and can only range from 32 to 448 (inclusive)

* RC2                  key size must be between 40 and 1024 bits

* RC4(ARCFOUR)         key size must be between 40 and 1024 bits

* 具体内容 需要关注 JDK Document http://.../docs/technotes/guides/security/SunProviders.html

* </pre>



* @author 梁栋

* @version 1.0

* @since 1.0

*/ 

public abstract class DESCoder extends Coder { 

    /**

     * ALGORITHM 算法 <br>

     * 可替换为以下任意一种算法,同时key值的size相应改变。

     * 

     * <pre>

     * DES                  key size must be equal to 56

     * DESede(TripleDES)    key size must be equal to 112 or 168

     * AES                  key size must be equal to 128, 192 or 256,but 192 and 256 bits may not be available

     * Blowfish             key size must be multiple of 8, and can only range from 32 to 448 (inclusive)

     * RC2                  key size must be between 40 and 1024 bits

     * RC4(ARCFOUR)         key size must be between 40 and 1024 bits

     * </pre>

     * 

     * 在Key toKey(byte[] key)方法中使用下述代码

     * <code>SecretKey secretKey = new SecretKeySpec(key, ALGORITHM);</code> 替换

     * <code>

     * DESKeySpec dks = new DESKeySpec(key);

     * SecretKeyFactory keyFactory = SecretKeyFactory.getInstance(ALGORITHM);

     * SecretKey secretKey = keyFactory.generateSecret(dks);

     * </code>

     */ 

    public static final String ALGORITHM = "DES"; 

 

    /**

     * 转换密钥<br>

     * 

     * @param key

     * @return

     * @throws Exception

     */ 

    private static Key toKey(byte[] key) throws Exception { 

        DESKeySpec dks = new DESKeySpec(key); 

        SecretKeyFactory keyFactory = SecretKeyFactory.getInstance(ALGORITHM); 

        SecretKey secretKey = keyFactory.generateSecret(dks); 

 

        // 当使用其他对称加密算法时,如AES、Blowfish等算法时,用下述代码替换上述三行代码 

        // SecretKey secretKey = new SecretKeySpec(key, ALGORITHM); 

 

        return secretKey; 

    } 

 

    /**

     * 解密

     * 

     * @param data

     * @param key

     * @return

     * @throws Exception

     */ 

    public static byte[] decrypt(byte[] data, String key) throws Exception { 

        Key k = toKey(decryptBASE64(key)); 

 

        Cipher cipher = Cipher.getInstance(ALGORITHM); 

        cipher.init(Cipher.DECRYPT_MODE, k); 

 

        return cipher.doFinal(data); 

    } 

 

    /**

     * 加密

     * 

     * @param data

     * @param key

     * @return

     * @throws Exception

     */ 

    public static byte[] encrypt(byte[] data, String key) throws Exception { 

        Key k = toKey(decryptBASE64(key)); 

        Cipher cipher = Cipher.getInstance(ALGORITHM); 

        cipher.init(Cipher.ENCRYPT_MODE, k); 

 

        return cipher.doFinal(data); 

    } 

 

    /**

     * 生成密钥

     * 

     * @return

     * @throws Exception

     */ 

    public static String initKey() throws Exception { 

        return initKey(null); 

    } 

 

    /**

     * 生成密钥

     * 

     * @param seed

     * @return

     * @throws Exception

     */ 

    public static String initKey(String seed) throws Exception { 

        SecureRandom secureRandom = null; 

 

        if (seed != null) { 

            secureRandom = new SecureRandom(decryptBASE64(seed)); 

        } else { 

            secureRandom = new SecureRandom(); 

        } 

 

        KeyGenerator kg = KeyGenerator.getInstance(ALGORITHM); 

        kg.init(secureRandom); 

 

        SecretKey secretKey = kg.generateKey(); 

 

        return encryptBASE64(secretKey.getEncoded()); 

    } 





延续上一个类的实现,我们通过MD5以及SHA对字符串加密生成密钥,这是比较常见的密钥生成方式。

再给出一个测试类:

Java代码  收藏代码

import static org.junit.Assert.*; 

 

 

import org.junit.Test; 

 

/**



* @author 梁栋

* @version 1.0

* @since 1.0

*/ 

public class DESCoderTest { 

 

    @Test 

    public void test() throws Exception { 

        String inputStr = "DES"; 

        String key = DESCoder.initKey(); 

        System.err.println("原文:\t" + inputStr); 

 

        System.err.println("密钥:\t" + key); 

 

        byte[] inputData = inputStr.getBytes(); 

        inputData = DESCoder.encrypt(inputData, key); 

 

        System.err.println("加密后:\t" + DESCoder.encryptBASE64(inputData)); 

 

        byte[] outputData = DESCoder.decrypt(inputData, key); 

        String outputStr = new String(outputData); 

 

        System.err.println("解密后:\t" + outputStr); 

 

        assertEquals(inputStr, outputStr); 

    } 





得到的输出内容如下:

Console代码  收藏代码

原文: DES 

密钥: f3wEtRrV6q0= 

 

加密后:    C6qe9oNIzRY= 

 

解密后:    DES 



    由控制台得到的输出,我们能够比对加密、解密后结果一致。这是一种简单的加密解密方式,只有一个密钥。

    其实DES有很多同胞兄弟,如DESede(TripleDES)、AES、Blowfish、RC2、RC4(ARCFOUR)。这里就不过多阐述了,大同小异,只要换掉ALGORITHM换成对应的值,同时做一个代码替换SecretKey secretKey = new SecretKeySpec(key, ALGORITHM);就可以了,此外就是密钥长度不同了。



Java代码  收藏代码

/**

* DES          key size must be equal to 56

* DESede(TripleDES) key size must be equal to 112 or 168

* AES          key size must be equal to 128, 192 or 256,but 192 and 256 bits may not be available

* Blowfish     key size must be multiple of 8, and can only range from 32 to 448 (inclusive)

* RC2          key size must be between 40 and 1024 bits

* RC4(ARCFOUR) key size must be between 40 and 1024 bits

**/

Java加密技术(二)——对称加密算法DES&AES的更多相关文章

  1. 常用加密算法的Java实现总结(二) ——对称加密算法DES、3DES和AES

    1.对称加密算法 1.1 定义 对称加密算法是应用较早的加密算法,技术成熟.在对称加密算法中,数据发信方将明文(原始数据)和加密密钥(mi yue)一起经过特殊加密算法处理后,使其变成复杂的加密密文发 ...

  2. Java进阶(七)Java加密技术之非对称加密算法RSA

    Java加密技术(四)--非对称加密算法RSA 非对称加密算法--RSA 基本概念 非对称加密算法是一种密钥的保密方法. 非对称加密算法需要两个密钥:公开密钥(publickey)和私有密钥(priv ...

  3. Java进阶(八)Java加密技术之对称加密 非对称加密 不可逆加密算法

    对称加密 非对称加密 不可逆加密算法 根据密钥类型不同可以将现代密码技术分为两类:对称加密算法(私钥密码体系)和非对称加密算法(公钥密码体系). 1 对称加密算法 原理 对称加密算法中,数据加密和解密 ...

  4. 对称加密算法DES,3重DES,TDEA,Blowfish,RC5,IDEA,AES。

    对称加密算法:DES,3重DES,TDEA,Blowfish,RC5,IDEA,AES. 1.对称加密算法 1.1 定义 对称加密算法是应用较早的加密算法,技术成熟.在对称加密算法中,数据发信方将明文 ...

  5. Atitit.加密算法 des  aes 各个语言不同的原理与解决方案java php c#

    Atitit.加密算法 des  aes 各个语言不同的原理与解决方案java php c# 1. 加密算法的参数::算法/模式/填充 1 2. 标准加密api使用流程1 2.1. Md5——16bi ...

  6. 对称加密算法DES、3DES和AES 原理总结(转载)

    1.对称加密算法 1.1 定义 对称加密算法是应用较早的加密算法,技术成熟.在对称加密算法中,数据发信方将明文(原始数据)和加密密钥(mi yue)一起经过特殊加密算法处理后,使其变成复杂的加密密文发 ...

  7. Java加密技术(一)——BASE64与单向加密算法MD5&SHA&MAC

    Java加密技术(一)——BASE64与单向加密算法MD5&SHA&MAC 博客分类: Java/Security Javabase64macmd5sha     加密解密,曾经是我一 ...

  8. Java加密技术

    相关链接: Java加密技术(一)——BASE64与单向加密算法MD5&SHA&MAC Java加密技术(二)——对称加密DES&AES Java加密技术(三)——PBE算法  ...

  9. Java加密技术(八)——数字证书

    原文:http://snowolf.iteye.com/blog/391931 请大家在阅读本篇内容时先阅读 Java加密技术(四),预先了解RSA加密算法. 在构建Java代码实现前,我们需要完成证 ...

  10. [转] 对称加密算法DES、3DES

    转自:http://www.blogjava.net/amigoxie/archive/2014/07/06/415503.html 1.对称加密算法 1.1 定义 对称加密算法是应用较早的加密算法, ...

随机推荐

  1. pandas教程02: 查找表中数据

      在上篇教程中,我们介绍了pandas的安装.数据的导入与导出以及删除行列的操作.这次让我们一起研究下在pandas中如何根据指定的条件查找表中数据. 1. 数据准备   这次,我们使用一张学生成绩 ...

  2. 阿里云数仓Dataworks数据导出到文件step by step

    背景 假设你在阿里云上Dataworks的空间space下有一个表table_A,想要把它的数据导出到文件以供后续使用,但是数据量又很多,从浏览器复制不太现实.阿里云提供了Java和Python版本的 ...

  3. Jackson objectMapper.readValue 方法 详解

    直接说结论方便一目了然: 1. 简单的直接Bean.class 2. 复杂的用 TypeReference 这样就完事了. public class TestMain2 { public static ...

  4. ASP.NET Core分布式项目实战(oauth2 + oidc 实现 client部分)--学习笔记

    任务16:oauth2 + oidc 实现 client部分 实现 client 之前启动一下上一节的 server,启动之前需要清除一些代码 注释 Program 的 MigrateDbContex ...

  5. Excel分类后数字类型的内容值后面变为0

    背景 在工作中经常遇到从日志或者其他地方拷贝过来的文本,里面使用其他分隔符进行分割.然而,使用Excel的分列功能进行分列后,发现数字类型的数值后面变为0. 有时候我们就是需要原先的数值,该怎么办呢? ...

  6. NC24870 [USACO 2009 Dec G]Video Game Troubles

    题目链接 题目 题目描述 Farmer John's cows love their video games! FJ noticed that after playing these games th ...

  7. Linux IOS镜像中查看Kernel 版本号

    开ISO镜像,到rpm包的目录里面去找到kernel-********.RPM这个包,中间的星号那一段就是内核版本

  8. Swift —— 一、架构解析

    一.简介 OpenStack 对象存储 (swift) 用于冗余.可扩展的数据 使用标准化服务器集群存储PB的存储 可访问的数据.它是一种长期存储系统,可存储大量 可以检索和更新的静态数据.对象存储使 ...

  9. redis7源码分析:redis 单线程模型解析,一条get命令执行流程

    有了下文的梳理后 redis 启动流程 再来解析redis 在单线程模式下解析并处理客户端发来的命令 1. 当 client fd 可读时,会回调readQueryFromClient函数 void ...

  10. C语言变量和数据类型整理

    03-变量和数据类型 3.1 大话C语言变量和数据类型 在<数据在内存中的存储>一节中讲到: ●计算机要处理的数据(诸如数字.文字.符号.图形.音频.视频等)是以二进制的形式存放在内存中的 ...