Laravel  
laravel
文档
数据库
架构
入门
php技术
    
Laravelphp
laravel / php / java / vue / mysql / linux / python / javascript / html / css / c++ / c#

java对称加密

作者:黑白灰调   发布日期:2026-06-03   浏览:23

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

public class SymmetricEncryptionExample {

    // 生成密钥
    public static byte[] generateKey() throws Exception {
        KeyGenerator keyGen = KeyGenerator.getInstance("AES");
        keyGen.init(128); // 可以选择192或256位密钥长度,但需要额外的JCE无限制权限策略文件
        SecretKey secretKey = keyGen.generateKey();
        return secretKey.getEncoded();
    }

    // 加密方法
    public static String encrypt(String plainText, byte[] key) throws Exception {
        SecretKeySpec secretKeySpec = new SecretKeySpec(key, "AES");
        Cipher cipher = Cipher.getInstance("AES");
        cipher.init(Cipher.ENCRYPT_MODE, secretKeySpec);
        byte[] encryptedBytes = cipher.doFinal(plainText.getBytes());
        return Base64.getEncoder().encodeToString(encryptedBytes);
    }

    // 解密方法
    public static String decrypt(String encryptedText, byte[] key) throws Exception {
        SecretKeySpec secretKeySpec = new SecretKeySpec(key, "AES");
        Cipher cipher = Cipher.getInstance("AES");
        cipher.init(Cipher.DECRYPT_MODE, secretKeySpec);
        byte[] decodedBytes = Base64.getDecoder().decode(encryptedText);
        byte[] decryptedBytes = cipher.doFinal(decodedBytes);
        return new String(decryptedBytes);
    }

    public static void main(String[] args) {
        try {
            // 生成密钥
            byte[] key = generateKey();
            System.out.println("Generated Key: " + Base64.getEncoder().encodeToString(key));

            // 原始文本
            String originalText = "Hello, World!";
            System.out.println("Original Text: " + originalText);

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

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

        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

解释说明

  1. 生成密钥:

    • 使用 KeyGenerator 类生成 AES 算法的密钥。这里选择了 128 位的密钥长度。
    • 密钥通过 getEncoded() 方法转换为字节数组,以便后续使用。
  2. 加密方法:

    • 使用 SecretKeySpec 将密钥字节数组转换为 AES 算法所需的密钥对象。
    • 创建 Cipher 对象并初始化为加密模式。
    • 使用 doFinal() 方法对明文进行加密,并将结果编码为 Base64 字符串以方便传输和存储。
  3. 解密方法:

    • 同样使用 SecretKeySpec 将密钥字节数组转换为 AES 算法所需的密钥对象。
    • 创建 Cipher 对象并初始化为解密模式。
    • 使用 doFinal() 方法对 Base64 编码的密文进行解码并解密,恢复原始明文。
  4. 主程序:

    • 生成密钥并打印出来。
    • 对原始文本进行加密并打印加密后的文本。
    • 对加密后的文本进行解密并打印解密后的文本,验证加密和解密过程是否正确。

希望这段代码和解释对你有所帮助!

上一篇:java 数字类型

下一篇:java获取文件创建时间

大家都在看

java url decode

java判断是windows还是linux

java连接数据库的代码

java date类型比较大小

java djl

ubuntu 卸载java

es java api

java list 查找

java 解压rar

jsonobject.tojavaobje

Laravel PHP 深圳智简公司。版权所有©2023-2043 LaravelPHP 粤ICP备2021048745号-3

Laravel 中文站