什么是DES加密算法
常见加密算法有对称加密算法和非对称加密算法,它们的区别是加密和解密使用的是否是同一把钥匙,常见的对称加密算法有DES,非对称算法有RSA,我们这里重点介绍DES加密算法,我们希望把这种算法应用在本地账号密码信息的加密上。顾名思义,秘钥在这里用来加密数据,解密数据的,我们通过原字符串和秘钥可以获得加密后的字节数组,保存在本地,取出后,利用秘钥解密得到之前存储的字符串,在生产字符串之前,我们是无法通过别的途径拿到数据的。我们这里重点介绍DES算法的使用,在Java中,有一组DES的API,我们需要学会如何去使用它。
DES加密算法的特点
- 秘钥是字节数组,且其长度必须是8的整数倍。
- 加密、解密都需要同一把秘钥参与(它是一个字节数组)。
- 对称加密算法,加密和解密的流程类似。
需要注意的地方
- 我们采用IO流的方式存取数据,存数据的时候是直接把字节数组写入文件流。
- 取出数据时,我们先用一个长数组接收(假设长度未知),再获取字节数组的长度,然后截取相应长度到新数组。
- 解密后得到的是字节数组,且其中每个元素都是用ASCII码表示的,我们需要把它转为字符串。
Java实现DES加密、解密字符串及本地存取数据
1、字符串加密,解密,IO流本地存取:
public class Test {
/**
* 把字符串加密得到字节数组写入文件保存在本地,等待取出;当需要用到的时候,取出字节数组,解密 ,转字符串
* @param args
*/
public static void main(String[] args){
byte[] buff1 = null; //申明变量,等下要用到
String password = "231rg34324234324dgdgdg3"; //需要加密的内容
System.out.println("需要加密的字符串:"+password);
byte[] key ={
1,2,3,4,5,6,7,8}; //8位密钥
byte[] result1 = DES.desEncrypt(password.getBytes(), key ) ;//加密,返回加密后的字节数组
System.out.println("加密后的字节数组:"+Arrays.toString(result1<