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. PicGo + Gitee 实现 Markdown 图床

    最近再研究图床,注册的阿里云域名备案还在审批,所以七牛云图床暂时没用,所以试下用PicGo+ Gitee PicGo - 基于 electron-vue 开发的图床工具 PicGo目前支持了微博图床, ...

  2. webrtc终极版(二)搭建自己的iceserver服务,并用到RTCMultiConnection的demo中

    webrtc终极版(二)搭建自己的iceserver服务,并用到RTCMultiConnection的demo中 目录 webrtc终极版(二)搭建自己的iceserver服务,并用到RTCMulti ...

  3. 初次尝试GPU Driven —— 大范围植被渲染

    初次尝试GPU Driven -- 大范围植被渲染 GPU Driver简单概要,即把整体逻辑放到GPU上运行,解放CPU压榨GPU,初次尝试,记录一下研究过程. 渡神纪 塞尔达 塞尔达 塞尔达 在开 ...

  4. 微信小程序获取本日、本周、本月、本年时间段

    原文链接 https://cslaoxu.vip/110.html 说明 最近需要用到统计不同时间段内的记录数,所以找了一下现成的工具类.下面就演示一下如何引用到实际项目中. 详细用法请参考:http ...

  5. C++ 控制台程序的线程分析

    在无任何功能代码的情况下运行控制台,会发现有三个线程在运行 SO 的答案指出,在程序一开始运行时,为加快进程启动,windows 会利用多个 CPU 内核更快地初始化. ntdll.dll 线程实际上 ...

  6. win32 - 以编程方式访问远程计算机上的文件

    第一步,在一台计算机上将某个驱动器或者某个文件夹设为sharing模式.这是我们需要访问的共享文件夹.(不需要设置everyone权限) 第二步,我们需要为两台在同一domain下的计算机上建立连接. ...

  7. pika

    生产者代码 # -*- coding: utf-8 -*- # pylint: disable=C0111,C0103,R0205 import json import pika from pika. ...

  8. 图书管理系统---基于ajax删除数据

    book_list.html代码 {% load static %} <!DOCTYPE html> <html lang="en"> <head&g ...

  9. 【LeetCode二叉树#02】二叉树层序遍历(广度优先搜索),十合一专题

    二叉树层序遍历(广度优先搜索) 102 二叉树的层序遍历 力扣题目链接(opens new window) 给你一个二叉树,请你返回其按 层序遍历 得到的节点值. (即逐层地,从左到右访问所有节点). ...

  10. 基于Python GDAL为长时间序列遥感图像绘制时相变化曲线图

      本文介绍基于Python中gdal模块,对大量多时相栅格图像,批量绘制像元时间序列折线图的方法.   首先,明确一下本文需要实现的需求:现有三个文件夹,其中第一个文件夹存放了某一研究区域原始的多时 ...