前面的仅仅是做了编码或者摘要,下面看看真正的加密技术。

DES

public class DESUtil {

    static final String ALGORITHM = "DES";

    /**
* 生成文本格式的DES Key
* @return
* @throws Exception
*/
public static String getKey() throws Exception{
KeyGenerator generator = KeyGenerator.getInstance(ALGORITHM);
generator.init(new SecureRandom());//加盐
return Base64Util.encode(generator.generateKey().getEncoded());
} /**
* 从文本 格式DES Key转换成SecretKey对象
* @param key
* @return
*/
public static SecretKey parseKeyFromString(String key)throws Exception{
DESKeySpec desKeySpec = new DESKeySpec(Base64Util.decode(key));
SecretKeyFactory factory = SecretKeyFactory.getInstance(ALGORITHM);
SecretKey secretKey = factory.generateSecret(desKeySpec);
return secretKey;
} /**
* DES 加密
* @param data
* @param key
* @return
* @throws Exception
*/
public static String encrypt(String data,String key)throws Exception{
SecretKey secretKey = parseKeyFromString(key);
Cipher cipher = Cipher.getInstance(ALGORITHM);
cipher.init(Cipher.ENCRYPT_MODE, secretKey);
byte[] bytes = cipher.doFinal(data.getBytes("UTF-8"));
return Base64Util.encode(bytes);
} /**
* DES 解密
* @param data
* @param key
* @return
* @throws Exception
*/
public static String decrypt(String data,String key)throws Exception{
SecretKey secretKey = parseKeyFromString(key);
Cipher cipher = Cipher.getInstance(ALGORITHM);
cipher.init(Cipher.DECRYPT_MODE, secretKey);
byte[] bytes = cipher.doFinal(Base64Util.decode(data));
return new String(bytes,"UTF-8");
} public static void main(String[] args)throws Exception {
String str = "Hello,DES";
String key = getKey();
System.out.println("原文:" + str);
System.out.println("密钥:" + key);
String encryptedStr = encrypt(str, key);
System.out.println("加密后:" + encryptedStr);
String decryptedStr = decrypt(encryptedStr, key);
System.out.println("解密后:" + decryptedStr);
} }

类似DESKeySpec,Java中很多*KeySpec的类都实现了KeySpec的空接口,Java只关心某个类是否是一种Key的实现,至于具体如何实现的是具体加密解密算法要关心的。

再次看到Base64的身影,由此可以看出,Base64其实充当着字符串和byte数组之间的转换器,真实的的密钥数据其实是byte类型的,但是在阅读和传输过程中字符串比较方便,所以我们能看到的很多密钥信息其实都是Base64编码。

Ciper为密文工具类,它是一个很高级的抽象类,有很多种Cipher的实现,可以通过Cipher.getInstance()方法获取到。

getInstance方法接收的算法名称非常多:

测试:

原文:Hello,DES
密钥:8ePQx0m1I4k=
加密后:bM06WR8OIL2sQOB8SUSXRA==
解密后:Hello,DES

AES

AES是DES的升级版,解决了DES的很多不足,上述DES代码改成AES的改动很小:

static final String ALGORITHM = "AES";
/**
* 从文本 格式AES Key转换成SecretKey对象
* @param key
* @return
*/
public static SecretKey parseKeyFromString(String key)throws Exception{
SecretKey secretKey = new SecretKeySpec(Base64Util.decode(key), ALGORITHM);
return secretKey;
}

PBE

PBE与DES、AES同属对称加密,不同之处在于其密钥可以由用户管理,即密钥可以不用通过KeyGenerator来生成,可以是任意字符。为了增强安全性,PBE强制必须要有参数(java.security.spec.AlgorithmParameterSpec),可以理解为强制加盐,否则将报错。

public class PBEUtil {

    static final String ALGORITHM = "PBEWITHMD5andDES";

    private static SecretKey parseKeyFromString(String key) throws Exception{
PBEKeySpec pbeKey = new PBEKeySpec(key.toCharArray());
SecretKeyFactory factory = SecretKeyFactory.getInstance(ALGORITHM);
return factory.generateSecret(pbeKey);
} /**
* PBE 加密
* @param data
* @param key
* @return
* @throws Exception
*/
public static String encrypt(String data,String key,byte[] salt)throws Exception{
SecretKey secretKey = parseKeyFromString(key);
Cipher cipher = Cipher.getInstance(ALGORITHM);
PBEParameterSpec params = new PBEParameterSpec(salt, 100);
cipher.init(Cipher.ENCRYPT_MODE, secretKey,params);
byte[] bytes = cipher.doFinal(data.getBytes("UTF-8"));
return Base64Util.encode(bytes);
} /**
* DES 解密
* @param data
* @param key
* @return
* @throws Exception
*/
public static String decrypt(String data,String key,byte[] salt)throws Exception{
SecretKey secretKey = parseKeyFromString(key);
Cipher cipher = Cipher.getInstance(ALGORITHM);
PBEParameterSpec params = new PBEParameterSpec(salt, 100);
cipher.init(Cipher.DECRYPT_MODE, secretKey,params);
byte[] bytes = cipher.doFinal(Base64Util.decode(data));
return new String(bytes,"UTF-8");
} public static void main(String[] args)throws Exception {
String str = "Hello,PBE";
String key = "abc";
byte[] salt = new byte[8];
new Random().nextBytes(salt);
System.out.println("原文:" + str);
System.out.println("密钥:" + key);
String encryptedStr = encrypt(str, key,salt);
System.out.println("加密后:" + encryptedStr);
String decryptedStr = decrypt(encryptedStr, key,salt);
System.out.println("解密后:" + decryptedStr);
} }

参考资料:

http://snowolf.iteye.com/blog/380034

http://snowolf.iteye.com/blog/380761

Java加密与解密笔记(二) 对称加密的更多相关文章

  1. Java加密与解密笔记(三) 非对称加密

    非对称的特点是加密和解密时使用的是不同的钥匙.密钥分为公钥和私钥,用公钥加密的数据只能用私钥进行解密,反之亦然. 另外,密钥还可以用于数字签名.数字签名跟上文说的消息摘要是一个道理,通过一定方法对数据 ...

  2. Java加密与解密笔记(一) Base64和数据摘要算法

    对加密解密下面的内容一定要先理解: 甲乙双方要通信,中间的连接可能被人窃听甚至篡改.解决办法就是把传输的内容进行加密,用密文去传输,这样即使被监听也没办法知道信息的具体内容. 加密时,甲乙双方可以约定 ...

  3. Java加密与解密笔记(四) 高级应用

    术语列表: CA:证书颁发认证机构(Certificate Authority) PEM:隐私增强邮件(Privacy Enhanced Mail),是OpenSSL使用的一种密钥文件. PKI:公钥 ...

  4. 非对称加解密 Asymmetric encryption 对称加密和非对称加密的区别

    考虑这样一个问题:一切的装备文件都存储在 Git 长途库房,RAR密码破解装备文件中的一些信息又是比较灵敏的.所以,我们需求对这些灵敏信息进行加密处理.首要的加密方法分为两种:一种是同享密钥加 密(对 ...

  5. 【Quick 3.3】资源脚本加密及热更新(二)资源加密

    [Quick 3.3]资源脚本加密及热更新(二)资源加密 注:本文基于Quick-cocos2dx-3.3版本编写 一.介绍 在前一篇文章中介绍了代码加密,加密方式是XXTEA.对于资源文件来说,同样 ...

  6. java之jvm学习笔记二(类装载器的体系结构)

    java的class只在需要的时候才内转载入内存,并由java虚拟机的执行引擎来执行,而执行引擎从总的来说主要的执行方式分为四种, 第一种,一次性解释代码,也就是当字节码转载到内存后,每次需要都会重新 ...

  7. Java常用的加密解密类(对称加密类)

    Java常用的加密解密类 原文转载至:http://blog.csdn.net/wyc_cs/article/details/8793198 原创 2013年04月12日 14:33:35 1704 ...

  8. java 加密与解密艺术二

    首先需要明确的是RSA的密钥对不能手动指定,需要通过代码系统生成 接下来我们来介绍下生成密钥对 package com.weiyuan.test; import java.security.KeyPa ...

  9. Java Des加解密方法(c#加密Java解密)

    最近我们用Java把一个用.net编写的老系统重新做了翻版,但是登录还是用.net的登录.这样就会遇到一个比较棘手的问题,我们登录用的cookie信息都是.net用des加密的,但我们不得不用Java ...

随机推荐

  1. 如何实现border-width:0.5px;

    工作中遇到了一个产品需求,要求把列表分割线改成0.5px,直接写成border:0.5px solid #cccccc;是不符合规范的写法,会存在Android和IOS手机上的兼容问题,故,我们可以利 ...

  2. JDK自带VM分析工具jps,jstat,jmap,jconsole

    一.概述 SUN 的JDK中的几个工具,非常好用.秉承着有免费,不用商用的原则.以下简单介绍一下这几种工具.(注:本文章下的所有工具都存在JDK5.0以上版本的工具集里,同javac一样,不须特意安装 ...

  3. 基于Flink秒级计算时CPU监控图表数据中断问题

     基于Flink进行秒级计算时,发现监控图表中CPU有数据中断现象,通过一段时间的跟踪定位,该问题目前已得到有效解决,以下是解决思路:   一.问题现象       以SQL02为例,发现本来10秒一 ...

  4. dedecms注入漏洞

    版本:Powered by DedeCMSV57_GBK © 2004-2011 DesDev Inc. 漏洞利用EXP:plus/recommend.php?action=&aid=1&am ...

  5. Django 2.0 新特性 抢先看!

    一.Python兼容性 Django 2.0支持Python3.4.3.5和3.6.Django官方强烈推荐每个系列的最新版本. 最重要的是Django 2.0不再支持Python2! Django ...

  6. 作为新手,SEO要避免的五大误区

    越来越多人在做网站的时候关注的不是网站的界面,而是网站的seo排名.Seo其实没有我们相信中的那么简单,特别对于新手,在实际操作过程中很容易遇到一些误区,今天我们简单说说新手要避免的五大seo误区. ...

  7. springboot集成swagger

    对于搬砖的同学来说,写接口容易,写接口文档很烦,接口变动,维护接口文档就更更更烦,所以经常能发现文档与程序不匹配. 等过一段时间就连开发者也蒙圈了 Swagger2快速方便的解决了以上问题.一个能与S ...

  8. Yii2如何添加sql日志记录的配置信息

    在使用Yii2框架的时候,常常会出现没有sql日志记录的问题.在代码里一句一句的打印sql语句也不现实.所以就要用文件记录起来. 在 config/web.php 里面的 log配置中增加如下配置 [ ...

  9. swiper3插件无缝滚动配置

    <html> <head> <link rel="stylesheet" href="https://cdn.bootcss.com/Swi ...

  10. JavaScript学习笔记(一)数组排序

    数组(Array)在JavaScript中是非常常用的类型,关于数组的排序,与C#等语法中的排序,乍看相似,其实差别比较大. Array的排序方法有两个,分别是reverse()和sort(). re ...