DES hex加密

本文介绍了一个基于Java实现的DES加密工具类,该类使用了javax.crypto包下的Cipher和SecretKeySpec类,以及Apache Commons Codec库进行Hex编码和解码。通过从配置文件中读取密钥并使用UTF-8编码,实现了对任意字符串的加密处理,适用于需要进行数据加密保护的应用场景。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

import javax.crypto.Cipher;
import javax.crypto.spec.SecretKeySpec;
import javax.xml.bind.annotation.adapters.HexBinaryAdapter;
import com.jfinal.kit.PropKit;
import org.apache.commons.codec.binary.Hex;

/**
 * DES加密工具类
 */
public class DesUtil {
    //密钥最好从配置文件获取
    private static final String secretKey = "mhez2018";

    /**
     * 加密
     * @param str 需要加密的内容
     * @return 加密后的数据
     */
    public static String encrypt(String str) {
        String result="";
        try {
            byte[] encoded = secretKey.getBytes("utf8");
            // 生成密钥字符串
            String encodeHexString = Hex.encodeHexString(encoded);
            // 再把我们的字符串转变为字节数组,可以用于另一方使用,验证
            byte[] decodeHex = Hex.decodeHex(encodeHexString.toCharArray());
            // 生成密钥对象
            SecretKeySpec secretKeySpec = new SecretKeySpec(decodeHex, "DES");

            // 获取加解密实例
            Cipher cipher = Cipher.getInstance("DES/ECB/NoPadding");
            // 初始化加密模式
            cipher.init(Cipher.ENCRYPT_MODE, secretKeySpec);
            // 加密
            byte[] strByte = str.getBytes();
            int length = strByte.length;
            //加密的字节数组如果不是8的倍数要进行补位
            byte[] byteTemp = new byte[length % 8 == 0?(length):((length / 8) * 8 + 8)];
            System.arraycopy(strByte, 0, byteTemp, 0, length);

            byte[] doFinal = cipher.doFinal(byteTemp);
            result = new HexBinaryAdapter().marshal(doFinal);
        } catch (Exception e) {
            e.printStackTrace();
        }
        return result;
    }

}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值