溫馨提示×

Ubuntu Java如何進行數據加密解密

小樊
44
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
亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女