ubuntu

Ubuntu Java如何进行数据加密解密

小樊
48
2025-10-22 18:06:34
栏目: 编程语言

在Ubuntu上使用Java进行数据加密和解密,你可以使用Java Cryptography Extension (JCE)提供的API。以下是一个简单的示例,展示了如何使用Java进行AES加密和解密。

首先,确保你的Ubuntu系统已经安装了Java。如果没有,请使用以下命令安装:

sudo apt update
sudo apt install default-jdk

接下来,创建一个名为EncryptionDemo.java的Java文件,并将以下代码粘贴到其中:

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

public class EncryptionDemo {

    public static void main(String[] args) throws Exception {
        String originalText = "Hello, World!";
        System.out.println("Original Text: " + originalText);

        // 加密
        String encryptedText = encrypt(originalText, "1234567890123456");
        System.out.println("Encrypted Text: " + encryptedText);

        // 解密
        String decryptedText = decrypt(encryptedText, "1234567890123456");
        System.out.println("Decrypted Text: " + decryptedText);
    }

    public static String encrypt(String plainText, String key) throws Exception {
        Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5Padding");
        SecretKey secretKey = new SecretKeySpec(key.getBytes(StandardCharsets.UTF_8), "AES");
        IvParameterSpec ivParameterSpec = new IvParameterSpec(key.getBytes(StandardCharsets.UTF_8), 0, 16);
        cipher.init(Cipher.ENCRYPT_MODE, secretKey, ivParameterSpec);
        byte[] encryptedBytes = cipher.doFinal(plainText.getBytes(StandardCharsets.UTF_8));
        return Base64.getEncoder().encodeToString(encryptedBytes);
    }

    public static String decrypt(String encryptedText, String key) throws Exception {
        Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5Padding");
        SecretKey secretKey = new SecretKeySpec(key.getBytes(StandardCharsets.UTF_8), "AES");
        IvParameterSpec ivParameterSpec = new IvParameterSpec(key.getBytes(StandardCharsets.UTF_8), 0, 16);
        cipher.init(Cipher.DECRYPT_MODE, secretKey, ivParameterSpec);
        byte[] decodedBytes = Base64.getDecoder().decode(encryptedText);
        byte[] decryptedBytes = cipher.doFinal(decodedBytes);
        return new String(decryptedBytes, StandardCharsets.UTF_8);
    }
}

在这个示例中,我们使用了AES加密算法,CBC模式和PKCS5填充。我们创建了一个名为encrypt的方法来加密文本,以及一个名为decrypt的方法来解密文本。

要运行此示例,请确保你已经安装了Java,然后在终端中导航到包含EncryptionDemo.java文件的目录。接下来,使用以下命令编译和运行代码:

javac EncryptionDemo.java
java EncryptionDemo

你应该会看到原始文本、加密后的文本和解密后的文本的输出。

请注意,这个示例仅用于演示目的。在实际应用中,你需要确保密钥的安全存储和管理。此外,根据你的需求,你可以选择其他加密算法和模式。

0
看了该问题的人还看了