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);
    }
}
相关文章
|
6月前
|
算法 Java
Java使用Cipher.getInstance(“AES/ECB/PKCS5Padding“);加解密算法工具类实现
Java使用Cipher.getInstance(“AES/ECB/PKCS5Padding“);加解密算法工具类实现
599 0
|
5月前
|
存储 算法 安全
Java中的DES和3DES加密算法详解
Java中的DES和3DES加密算法详解
|
5月前
|
算法 安全 Java
深入解析ECC(椭圆曲线密码学)加解密算法
深入解析ECC(椭圆曲线密码学)加解密算法
深入解析ECC(椭圆曲线密码学)加解密算法
|
5月前
|
Java C# 数据安全/隐私保护
|
5月前
|
算法 安全 Java
AES加解密算法:原理、应用与安全性解析
AES加解密算法:原理、应用与安全性解析
|
6月前
|
算法 数据安全/隐私保护 数据格式
基于混沌序列的图像加解密算法matlab仿真,并输出加解密之后的直方图
该内容是一个关于混沌系统理论及其在图像加解密算法中的应用摘要。介绍了使用matlab2022a运行的算法,重点阐述了混沌系统的特性,如确定性、非线性、初值敏感性等,并以Logistic映射为例展示混沌序列生成。图像加解密流程包括预处理、混沌序列生成、数据混淆和扩散,以及密钥管理。提供了部分核心程序,涉及混沌序列用于图像像素的混淆和扩散过程,通过位操作实现加密。
|
6月前
|
存储 算法 安全
java des加解密啊
【2月更文挑战第8天】
|
24天前
|
算法 安全 数据安全/隐私保护
基于game-based算法的动态频谱访问matlab仿真
本算法展示了在认知无线电网络中,通过游戏理论优化动态频谱访问,提高频谱利用率和物理层安全性。程序运行效果包括负载因子、传输功率、信噪比对用户效用和保密率的影响分析。软件版本:Matlab 2022a。完整代码包含详细中文注释和操作视频。
|
9天前
|
算法 数据挖掘 数据安全/隐私保护
基于FCM模糊聚类算法的图像分割matlab仿真
本项目展示了基于模糊C均值(FCM)算法的图像分割技术。算法运行效果良好,无水印。使用MATLAB 2022a开发,提供完整代码及中文注释,附带操作步骤视频。FCM算法通过隶属度矩阵和聚类中心矩阵实现图像分割,适用于灰度和彩色图像,广泛应用于医学影像、遥感图像等领域。
|
11天前
|
算法 调度
基于遗传模拟退火混合优化算法的车间作业最优调度matlab仿真,输出甘特图
车间作业调度问题(JSSP)通过遗传算法(GA)和模拟退火算法(SA)优化多个作业在并行工作中心上的加工顺序和时间,以最小化总完成时间和机器闲置时间。MATLAB2022a版本运行测试,展示了有效性和可行性。核心程序采用作业列表表示法,结合遗传操作和模拟退火过程,提高算法性能。