java的DES和3DES加解密算法

简介: java的DES和3DES加解密算法
package com.example.yang.myapplication;
import java.security.SecureRandom;
import javax.crypto.Cipher;
import javax.crypto.SecretKey;
import javax.crypto.SecretKeyFactory;
import javax.crypto.spec.DESKeySpec;
import static com.example.yang.myapplication.MyUtil.bytesToHexString;
import static com.example.yang.myapplication.MyUtil.hexStringToBytes;
import static java.lang.System.arraycopy;
/**
 * DES 加密算法 DES和3DES ECB模式的加解密
 * @author yangyongzhen
 *
 */
public class DesUtil {
    public final static String DES = "DES";
    /**
     * 加密
     * @param data byte[]
     * @param key byte[]
     * @return byte[]
     */
    public static byte[] DES_encrypt(byte[] data, byte[] key) {
        try{
            // 生成一个可信任的随机数源
            SecureRandom sr = new SecureRandom();
// 从原始密钥数据创建DESKeySpec对象
            DESKeySpec dks = new DESKeySpec(key);
// 创建一个密钥工厂,然后用它把DESKeySpec转换成SecretKey对象
            SecretKeyFactory keyFactory = SecretKeyFactory.getInstance(DES);
            SecretKey securekey = keyFactory.generateSecret(dks);
// Cipher对象实际完成加密操作
            Cipher cipher = Cipher.getInstance("DES/ECB/NoPadding");
// 用密钥初始化Cipher对象
            cipher.init(Cipher.ENCRYPT_MODE, securekey, sr);
            return cipher.doFinal(data);
        }catch(Throwable e){
            e.printStackTrace();
        }
        return null;
    }
    /**
     * 解密
     * @param data byte[]
     * @param key byte[]
     * @return byte[]
     */
    public static byte[] DES_decrypt(byte[] data, byte[] key) {
        try{
            // 生成一个可信任的随机数源
            SecureRandom sr = new SecureRandom();
// 从原始密钥数据创建DESKeySpec对象
            DESKeySpec dks = new DESKeySpec(key);
// 创建一个密钥工厂,然后用它把DESKeySpec转换成SecretKey对象
            SecretKeyFactory keyFactory = SecretKeyFactory.getInstance(DES);
            SecretKey securekey = keyFactory.generateSecret(dks);
// Cipher对象实际完成解密操作
            Cipher cipher = Cipher.getInstance("DES/ECB/NoPadding");
// 用密钥初始化Cipher对象
            cipher.init(Cipher.DECRYPT_MODE, securekey, sr);
            return cipher.doFinal(data);
        }catch(Throwable e){
            e.printStackTrace();
        }
        return null;
    }
    public static byte[] DES_encrypt_3(byte[] datasource, byte[] key){
        if ((key.length!= 16) || ((datasource.length%8 )!= 0)){
            return null;
        }
        byte[] Lkey = new byte[8];
        byte[] Rkey = new byte[8];
        arraycopy(key,0,Lkey,0,8);
        arraycopy(key,8,Rkey,0,8);
        byte[] outdata,tmpdata;
        outdata = DES_encrypt(datasource,Lkey);//加
        tmpdata = DES_decrypt(outdata,Rkey);//解
        outdata = DES_encrypt(tmpdata,Lkey);//加
        return outdata;
    }
    public static byte[] DES_decrypt_3(byte[] datasource, byte[] key){
        if ((key.length!= 16) || ((datasource.length%8 )!= 0)) {
            return null;
        }
        byte[] Lkey = new byte[8];
        byte[] Rkey = new byte[8];
        arraycopy(key,0,Lkey,0,8);
        arraycopy(key,8,Rkey,0,8);
        byte[] outdata,tmpdata;
        outdata = DES_decrypt(datasource,Lkey);//解
        tmpdata = DES_encrypt(outdata,Rkey);//加
        outdata = DES_decrypt(tmpdata,Lkey);//解
        return outdata;
    }
    public static void main(String[] args) {
        String strkey = "258FB0Ab70D025CDB99DF2C4D302D646";
        String K1 = strkey.substring(0, strkey.length() / 2);
        String K2 = strkey.substring(strkey.length() / 2);
        String strdata = "46F161A743497B32EAC760DF5EA57DF5";
        String D1 = strdata.substring(0, strdata.length() / 2);
        String D2 = strdata.substring(strdata.length() / 2);
        byte[] bt;
        String out;
        bt = DES_decrypt(hexStringToBytes(D1),hexStringToBytes(K1));
        out = bytesToHexString(bt);
        System.out.println("discryption结果为:"+out);
        bt = DES_encrypt(hexStringToBytes(D1),hexStringToBytes(K1));
        out = bytesToHexString(bt);
        System.out.println("encryption结果为:"+out);
        bt = DES_encrypt_3(hexStringToBytes(strdata),hexStringToBytes(strkey));
        out = bytesToHexString(bt);
        System.out.println("encryption_3结果为:"+out);
        bt = DES_decrypt_3(hexStringToBytes(strdata),hexStringToBytes(strkey));
        out = bytesToHexString(bt);
        System.out.println("decryption_3结果为:"+out);
    }
}
相关文章
|
算法 JavaScript 前端开发
对称加密算法解析:DES、AES及其在`pycryptodome` 和 `crypto-js` 模块中的应用
对称加密算法解析:DES、AES及其在`pycryptodome` 和 `crypto-js` 模块中的应用
651 1
|
存储 算法 安全
Java中的DES和3DES加密算法详解
Java中的DES和3DES加密算法详解
|
算法 安全 Java
深入解析ECC(椭圆曲线密码学)加解密算法
深入解析ECC(椭圆曲线密码学)加解密算法
深入解析ECC(椭圆曲线密码学)加解密算法
|
Java C# 数据安全/隐私保护
|
安全 算法 数据库
MD5、SHA、DES、AES、RSA的算法说明
【5月更文挑战第10天】MD5、SHA、DES、AES、RSA的算法说明
1595 2
|
算法 安全 Java
AES加解密算法:原理、应用与安全性解析
AES加解密算法:原理、应用与安全性解析
|
4月前
|
机器学习/深度学习 算法 机器人
【水下图像增强融合算法】基于融合的水下图像与视频增强研究(Matlab代码实现)
【水下图像增强融合算法】基于融合的水下图像与视频增强研究(Matlab代码实现)
474 0
|
4月前
|
数据采集 分布式计算 并行计算
mRMR算法实现特征选择-MATLAB
mRMR算法实现特征选择-MATLAB
318 2
|
5月前
|
传感器 机器学习/深度学习 编解码
MATLAB|主动噪声和振动控制算法——对较大的次级路径变化具有鲁棒性
MATLAB|主动噪声和振动控制算法——对较大的次级路径变化具有鲁棒性
299 3
|
4月前
|
机器学习/深度学习 算法 机器人
使用哈里斯角Harris和SIFT算法来实现局部特征匹配(Matlab代码实现)
使用哈里斯角Harris和SIFT算法来实现局部特征匹配(Matlab代码实现)
242 8