介绍对称加密算法,最常用的莫过于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加密技术(一)
- 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对字符串加密生成密钥,这是比较常见的密钥生成方式。
再给出一个测试类:
- 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);
 - }
 - }
 
得到的输出内容如下:
- 原文: DES
 - 密钥: f3wEtRrV6q0=
 - 加密后: C6qe9oNIzRY=
 - 解密后: DES
 
由控制台得到的输出,我们能够比对加密、解密后结果一致。这是一种简单的加密解密方式,只有一个密钥。
    其实DES有很多同胞兄弟,如DESede(TripleDES)、AES、Blowfish、RC2、RC4(ARCFOUR)。这里就不过多阐述了,大同小异,只要换掉ALGORITHM换成对应的值,同时做一个代码替换SecretKey secretKey = new SecretKeySpec(key, ALGORITHM);就可以了,此外就是密钥长度不同了。
介绍对称加密算法,最常用的莫过于DES数据加密算法的更多相关文章
- 介绍对称加密的另一个算法——PBE
		
除了DES,我们还知道有DESede(TripleDES,就是3DES).AES.Blowfish.RC2.RC4(ARCFOUR)等多种对称加密方式,其实现方式大同小异,这里介绍对称加密的另一个算法 ...
 - 加密算法—MD5、RSA、DES
		
最近因为要做一个加密的功能,简单了解了一下加密算法,现在比较常用的有三个加密算法MD5加密算法.RSA加密算法.DES加密算法. MD5加密算法 定义:MD5算法是将任意长度的“字 ...
 - 3DES(或称为Triple DES)是三重数据加密算法(TDEA,Triple Data Encryption Algorithm)
		
3DES(或称为Triple DES)是三重数据加密算法(TDEA,Triple Data Encryption Algorithm)块密码的通称.它相当于是对每个数据块应用三次DES加密算法.由于计 ...
 - Java Base64、HMAC、SHA1、MD5、AES DES 3DES加密算法
		
● BASE64 严格地说,属于编码格式,而非加密算法 ● MD5(Message Digest algorithm 5,信息摘要算法) ● SHA(Secure Hash Algo ...
 - 【asp.net core 系列】12 数据加密算法
		
0. 前言 这一篇我们将介绍一下.net core 的加密和解密.在Web应用程序中,用户的密码会使用MD5值作为密码数据存储起来.而在其他的情况下,也会使用加密和解密的功能. 常见的加密算法分为对称 ...
 - iOS常用的几种数据存储方式
		
之前由于刚入行不久,对数据持久化不是很了解,尤其是用数据库存储大量数据的操作.经过摸索就在此总结一下,方便以后查阅 下面就简单介绍一下: 1.NSUserDefaults 感觉最常用的小量数据,属性, ...
 - DES数据解密
		
/// <summary> /// DES数据解密 /// </summary> /// <param name="targetValue">& ...
 - 介绍下Java内存区域(运行时数据区)
		
介绍下Java内存区域(运行时数据区) Java 虚拟机在执行 Java 程序的过程中会把它管理的内存划分成若干个不同的数据区域.JDK 1.8 和之前的版本略有不同. 下图是 JDK 1.8 对JV ...
 - iOS中常用的四种数据持久化方法简介
		
iOS中常用的四种数据持久化方法简介 iOS中的数据持久化方式,基本上有以下四种:属性列表.对象归档.SQLite3和Core Data 1.属性列表涉及到的主要类:NSUserDefaults,一般 ...
 
随机推荐
- Linux如何查看JDK的安装路径
			
如何在一台Linux服务器上查找JDK的安装路径呢? 有那些方法可以查找定位JDK的安装路径?是否有一些局限性呢? 下面总结了一下如何查找JDK安装路径的方法. 1:echo $JAVA_HOME ...
 - ORACLE 物理读 逻辑读 一致性读 当前模式读总结浅析
			
在ORACLE数据库中有物理读(Physical Reads).逻辑读(Logical Reads).一致性读(Consistant Get).当前模式读(DB Block Gets)等诸多概念,如果 ...
 - C++: 主要知识点
			
大学期间,学了一学期的C语言,当然包括学习数据结构时,用的也是C语言.当时刚刚接触计算机,对于编程更是一无所知.上课学习学习,偶尔会照着书上敲一下代码.大二下学期,就丢掉了不用了.最近由于工作的需要, ...
 - IntelliJ IDEA 教程设置讲解
			
IntelliJ IDEA 常用设置讲解 说明 IntelliJ在业界被公认为最好的java开发工具之一,尤其在智能代码助手.代码自动提示.重构.J2EE支持.Ant.JUnit.CVS整合.代码审查 ...
 - SQL Server 2008 R2——CROSS APPLY 根据数据出现的次数和时间来给新字段赋值
			
=================================版权声明================================= 版权声明:原创文章 禁止转载 请通过右侧公告中的“联系邮 ...
 - 设置DIV可编辑
			
<div id="move" contentEditable="true">可编辑</div> 设置contentEditable属性可 ...
 - 【2016-11-6】【坚持学习】【Day21】【子窗口关闭时,同步关闭它的主窗口(方法二)】
			
根据上文,在子窗口设置一个委托.然后在子窗口关闭事件,执行委托实例,然后在主窗口增加监听委托的方法.... 想想,本事关闭事件就是一个特殊的委托.那么干嘛还要特意去声明一个新的呢?多此一举. 于是有下 ...
 - NOIP2010pj三国游戏[博弈论]
			
题目描述 小涵很喜欢电脑游戏,这些天他正在玩一个叫做<三国>的游戏. 在游戏中,小涵和计算机各执一方,组建各自的军队进行对战.游戏中共有 N 位武将(N为偶数且不小于 4),任意两个武将之 ...
 - org.hibernate.HibernateException: No Session found for current thread
			
spring.springmvc和hibernate整合 在sessionFactory.getCurrentSession()时,出现以下异常 No Session found for curren ...
 - android第一行代码-6.自定义控件的实现
			
0.假设一个应用中标题栏控件都是共用的,如果每个activity都需要设置button,绑定方法,那代码就会很臃肿.那我们可以自定义控件,然后继承这个控件就行了. 自定义控件为TitleLayout, ...