溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Java中如何實現字符串的加密解密

發布時間:2025-03-21 17:14:49 來源:億速云 閱讀:162 作者:小樊 欄目:編程語言

在Java中,可以使用Java Cryptography Extension (JCE)來實現字符串的加密和解密。JCE提供了一套加密算法,包括對稱加密算法(如AES、DES等)和非對稱加密算法(如RSA、DSA等)。以下是一個使用AES對稱加密算法實現字符串加密和解密的示例:

首先,確保你的Java環境已經安裝了JCE。

然后,創建一個名為AESEncryptionExample.java的文件,并添加以下代碼:

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

public class AESEncryptionExample {

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

        // 加密
        String encryptedString = encrypt(originalString, "mySecretKey123");
        System.out.println("Encrypted String: " + encryptedString);

        // 解密
        String decryptedString = decrypt(encryptedString, "mySecretKey123");
        System.out.println("Decrypted String: " + decryptedString);
    }

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

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

在這個示例中,我們使用了AES/ECB/PKCS5Padding加密模式。你可以根據需要更改加密模式和填充方式。運行這個程序,你將看到原始字符串、加密后的字符串和解密后的字符串。

注意:在實際應用中,密鑰管理非常重要。不要將密鑰硬編碼在代碼中,而是使用安全的方式存儲和管理密鑰。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女