java实现des加密解密代码

胜哥 Java代码

以下是 Java 中使用DES算法进行加密和解密的示例代码:

import javax.crypto.Cipher;
import javax.crypto.spec.IvParameterSpec;
import javax.crypto.spec.SecretKeySpec;
import java.nio.charset.StandardCharsets;
import java.util.Base64;

public class DesEncryptDecryptExample {

    public static String encrypt(String data, String key) throws Exception {
        Cipher cipher = Cipher.getInstance("DES/CBC/PKCS5Padding");
        byte[] keyBytes = key.getBytes(StandardCharsets.UTF_8);
        SecretKeySpec keySpec = new SecretKeySpec(keyBytes, "DES");
        byte[] ivBytes = new byte[8];
        IvParameterSpec ivSpec = new IvParameterSpec(ivBytes);
        cipher.init(Cipher.ENCRYPT_MODE, keySpec, ivSpec);
        byte[] encrypted = cipher.doFinal(data.getBytes());
        return Base64.getEncoder().encodeToString(encrypted);
    }

    public static String decrypt(String encryptedData, String key) throws Exception {
        Cipher cipher = Cipher.getInstance("DES/CBC/PKCS5Padding");
        byte[] keyBytes = key.getBytes(StandardCharsets.UTF_8);
        SecretKeySpec keySpec = new SecretKeySpec(keyBytes, "DES");
        byte[] ivBytes = new byte[8];
        IvParameterSpec ivSpec = new IvParameterSpec(ivBytes);
        cipher.init(Cipher.DECRYPT_MODE, keySpec, ivSpec);
        byte[] encrypted = Base64.getDecoder().decode(encryptedData);
        byte[] decrypted = cipher.doFinal(encrypted);
        return new String(decrypted, StandardCharsets.UTF_8);
    }

    public static void main(String[] args) throws Exception {
        String data = "This is a secret message.";
        String key = "12345678";
        String encryptedData = encrypt(data, key);
        System.out.println("Encrypted: " + encryptedData);
        String decryptedData = decrypt(encryptedData, key);
        System.out.println("Decrypted: " + decryptedData);
    }
}

在该java实现des加密解密代码示例中,我们使用了 Java 内置的加密库 javax.crypto 中的 Cipher 类。encrypt() 和 decrypt() 方法分别用于加密和解密数据。在加密方法中,我们首先使用密钥将 SecretKeySpec 对象进行初始化,然后使用 IvParameterSpec 对象初始化 Cipher 对象,使用加密模式对数据进行加密,最后对加密后的数据进行 Base64 编码以便于传输和存储。

在解密方法中,我们使用密钥和 IV 对象初始化 Cipher 对象,使用解密模式对加密后的数据进行解密,最后将解密后的数据以 UTF-8 编码的字符串形式返回。

在主函数中,我们定义了要加密的数据和密钥,并调用加密和解密方法进行测试。