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. CF911G Mass Change Queries 题解

    题目链接:CF 或者 洛谷 前置知识点:平衡树合并: CF文章 与维基百科 看上去这题有很多人用线段树分裂与合并去做,其实这种需要分裂和合并的,我们用文艺平衡树去维护区间信息是最容易写的. 考虑本题的 ...

  2. spring-cloud 配置管理

    作用: 实现配置热更新 实现网关配置热部署 配置模板 spring: datasource: driver-class-name: com.mysql.cj.jdbc.Driver url: jdbc ...

  3. (python)做题记录||2024.2.4||题目是codewars的【 All Balanced Parentheses】

    题目链接:https://www.codewars.com/kata/5426d7a2c2c7784365000783/python 我的解决方案: def balanced_parens(n): # ...

  4. 高精度模板 大数减大数 可变数组vector实现

    vector<int> Sub(vector<int>& A, vector<int>& B)//这里默认长数减去短数 { vector<in ...

  5. 数学问题,2的n次方 - 1 是怎么来的? 通常用作计算数值

  6. P1405 苦恼的小明 题解

    题目传送门 前置知识 扩展欧拉定理 解法 本题幂塔是有限层的,这里与 luogu P4139 上帝与集合的正确用法 中的无限层幂塔不同,故需要在到达递归边界 \(n+1\) 时进行特殊处理,对于处理 ...

  7. 【Unity3D】Renderer Feature简介

    1 3D 项目迁移到 URP 项目后出现的问题 ​ 3D 项目迁移至 URP 项目后,会出现很多渲染问题,如:材质显示异常.GL 渲染不显示.多 Pass 渲染异常.屏幕后处理异常等问题.下面将针对这 ...

  8. 【OpenGL ES】透视变换原理

    1 前言 ​ MVP矩阵变换 中主要介绍了模型变换(平移.旋转.对称.缩放)和观测变换基本原理,本文将介绍透视变换的基本原理. ​ 如下图,近平面和远平面间棱台称为视锥体,表示可见区域范围,视锥体以外 ...

  9. Laravel入坑指南(8)——控制台程序

    我们知道,php代码不仅可以用web的形式对外提供服务,同时也可以在命令行下执行. 对于原生的php来说,假设我们有一个php文件,名为Command.php,如果想要在控制台下执行这个文件,那么我们 ...

  10. Typora关于 插入图片 居中 靠左 靠右设置

    style="float: left;" <img src="C:\Users\mlx\AppData\Roaming\Typora\typora-user-ima ...