java使用DES加密方式,实现对数据的加密解密

全栈工程师开发手册 (作者:栾鹏)

java教程全解

java使用DES加密方式,实现对数据的加密解密。加密和解密中需要使用同一个秘钥

第一种方式,使用类型Key作为加密解密的共同秘钥。

测试代码

public static void main(String[] args) 
    {
        try {
            DESDemo des=new DESDemo();
            des.generateKey();
            byte[] data="Hello World!".getBytes();
            byte[] data1=des.des_encrypt(data);  //加密
            byte[] data2=des.des_dencrypt(data1);  //解密
            String back=new String(data2);
            System.out.println(back);
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

DES加密解密工具类的实现

package com.lp.app.safe;
import java.security.*;
import javax.crypto.*;
public class DESDemo {

    Key key;
    //产生秘钥
    public void generateKey() throws Exception {
        // 得到DES私钥
        KeyGenerator keyGen = KeyGenerator.getInstance("DES");
        keyGen.init(56);
        key = keyGen.generateKey();
    }

    //des加密,输入明文字节流
    public byte[] des_encrypt(byte[] plainText) throws Exception {
        // 得到DES cipher 对象
        Cipher cipher = Cipher.getInstance("DES/ECB/PKCS5Padding");
        // 使用密钥对明文进行加密
        cipher.init(Cipher.ENCRYPT_MODE, key);
        byte[] cipherText = cipher.doFinal(plainText);
        return cipherText;
    }

    //des解密
    public byte[] des_dencrypt(byte[] cipherText) throws Exception {
        // 使用同一把密钥对密文进行解密
        // 得到DES cipher 对象
        Cipher cipher = Cipher.getInstance("DES/ECB/PKCS5Padding");
        cipher.init(Cipher.DECRYPT_MODE, key);
        byte[] newPlainText = cipher.doFinal(cipherText);
        return newPlainText;
    }
}

第二种方式,使用字节数组byte[]作为加密解密的共同秘钥

测试代码

 public static void main(String[] args) {

        String str1="12014-11-15";
         // DES数据加密  
        String s1=encryptBasedDes(str1);
        System.out.println("加密后"+s1);  

        // DES数据解密  
        String s2=decryptBasedDes(s1);  
        System.out.println("解密后"+s2);  
    }

加密解密工具类的实现

package com.lp.app.util;

import java.security.SecureRandom;

import javax.crypto.Cipher;
import javax.crypto.SecretKey;
import javax.crypto.SecretKeyFactory;
import javax.crypto.spec.DESKeySpec;



public class DESUtil {


    //算法密匙
    private static final byte[] DES_KEY = { 21, 1, -110, 82, -32, -85, -128, -65 };  

    //数据加密,算法(DES)  
    public static String encryptBasedDes(String data) {  
        String encryptedData = null;  
        try {  
            // DES算法要求有一个可信任的随机数源  
            SecureRandom sr = new SecureRandom();  
            DESKeySpec deskey = new DESKeySpec(DES_KEY);  
            // 创建一个密匙工厂,然后用它把DESKeySpec转换成一个SecretKey对象  
            SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES");  
            SecretKey key = keyFactory.generateSecret(deskey);  
            // 加密对象  
            Cipher cipher = Cipher.getInstance("DES");  
            cipher.init(Cipher.ENCRYPT_MODE, key, sr);  
            // 加密,并把字节数组编码成字符串  
            encryptedData = new sun.misc.BASE64Encoder().encode(cipher.doFinal(data.getBytes()));  
        } catch (Exception e) {  
//            log.error("加密错误,错误信息:", e);  
            throw new RuntimeException("加密错误,错误信息:", e);  
        }  
        return encryptedData;  
    }  

    //解密(DES)  
    public static String decryptBasedDes(String cryptData) {  
        String decryptedData = null;
        try {  
            // DES算法要求有一个可信任的随机数源  
            SecureRandom sr = new SecureRandom();  
            DESKeySpec deskey = new DESKeySpec(DES_KEY);  
            // 创建一个密匙工厂,然后用它把DESKeySpec转换成一个SecretKey对象  
            SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES");  
            SecretKey key = keyFactory.generateSecret(deskey);  
            // 解密对象  
            Cipher cipher = Cipher.getInstance("DES");  
            cipher.init(Cipher.DECRYPT_MODE, key, sr);  
            // 把字符串解码为字节数组,并解密  
            decryptedData = new String(cipher.doFinal(new sun.misc.BASE64Decoder().decodeBuffer(cryptData)));  
        } catch (Exception e) {  
//            log.error("解密错误,错误信息:", e);  
            throw new RuntimeException("解密错误,错误信息:", e);  
        }  
        return decryptedData;  
    }  


}
  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

腾讯AI架构师

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值