Java实现AES加密工具类 - 简单易用的数据加密解决方案

当我们涉及到敏感数据的存储和传输时,数据加密是非常重要的。加密可以确保数据的保密性和完整性,并帮助我们防止数据泄露和攻击。在Java中,使用标准的加密算法和库可以很容易地实现数据加密和解密。本篇文章将介绍一个简单的Java工具类,该工具类使用AES对称加密算法来对数据进行加密和解密。

Java已经提供了许多加密库和算法,包括常用的对称加密算法和非对称加密算法,例如AES、DES、RSA等。

以下是一个简单的Java加解密工具类的示例,可以使用AES算法进行加密和解密:

  1. ENCRYPTION_ALGORITHMSECRET_KEY_ALGORITHM常量分别表示使用的加密算法和密钥算法。在此例中,使用AES算法进行加密和解密,并使用AES算法作为密钥算法。

  1. HASH_ALGORITHM常量表示使用的哈希算法。在此例中,使用SHA-256哈希算法将密钥生成为16字节的密钥。

  1. encrypt方法使用给定的密钥对字符串进行加密。首先,使用密钥生成SecretKeySpec对象,然后使用Cipher对象和ENCRYPTION_ALGORITHM常量进行初始化。然后,将数据字节数组进行加密,并使用Base64编码返回密文字符串。

  1. decrypt方法使用给定的密钥对字符串进行解密。首先,使用密钥生成SecretKeySpec对象,然后使用Cipher对象和ENCRYPTION_ALGORITHM常量进行初始化。然后,使用Base64解码密文字符串,并将解码后的字节数组进行解密。最后,返回解密后的明文字符串。

  1. generateSecretKeySpec方法生成SecretKeySpec对象。它使用给定的密钥字符串和HASH_ALGORITHM常量生成哈希值。然后,它将哈希值截取前16个字节,用于生成SecretKeySpec对象。

注意,这只是一个简单的示例,真正的加密应该考虑更多的安全因素。此外,为了确保密钥安全,密钥应该存储在安全的地方,并且只有授权的人员才能访问它。

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

public class EncryptionUtils {
    private static final String ENCRYPTION_ALGORITHM = "AES";
    private static final String SECRET_KEY_ALGORITHM = "AES";
    private static final String HASH_ALGORITHM = "SHA-256";

    public static String encrypt(String data, String key) throws Exception {
        SecretKeySpec secretKeySpec = generateSecretKeySpec(key);
        Cipher cipher = Cipher.getInstance(ENCRYPTION_ALGORITHM);
        cipher.init(Cipher.ENCRYPT_MODE, secretKeySpec);
        byte[] encryptedBytes = cipher.doFinal(data.getBytes(StandardCharsets.UTF_8));
        return Base64.getEncoder().encodeToString(encryptedBytes);
    }

    public static String decrypt(String data, String key) throws Exception {
        SecretKeySpec secretKeySpec = generateSecretKeySpec(key);
        Cipher cipher = Cipher.getInstance(ENCRYPTION_ALGORITHM);
        cipher.init(Cipher.DECRYPT_MODE, secretKeySpec);
        byte[] decodedBytes = Base64.getDecoder().decode(data);
        byte[] decryptedBytes = cipher.doFinal(decodedBytes);
        return new String(decryptedBytes, StandardCharsets.UTF_8);
    }

    private static SecretKeySpec generateSecretKeySpec(String key) throws Exception {
        MessageDigest sha = MessageDigest.getInstance(HASH_ALGORITHM);
        byte[] keyBytes = key.getBytes(StandardCharsets.UTF_8);
        byte[] hashedBytes = sha.digest(keyBytes);
        byte[] truncatedBytes = new byte[16];
        System.arraycopy(hashedBytes, 0, truncatedBytes, 0, truncatedBytes.length);
        return new SecretKeySpec(truncatedBytes, SECRET_KEY_ALGORITHM);
    }
}

在上述示例中,我们使用AES算法和SHA-256哈希算法。加密和解密函数均接受一个字符串数据和一个字符串密钥,并返回相应的加密/解密字符串。

注意,这只是一个简单的示例,真正的加密应该考虑更多的安全因素。此外,为了确保密钥安全,密钥应该存储在安全的地方,并且只有授权的人员才能访问它。

下面是一个简单的示例,演示如何使用上面提供的EncryptionUtils工具类对字符串进行加密和解密:

public class Example {
    public static void main(String[] args) {
        String data = "Hello World!";
        String key = "mysecretkey";

        try {
            // 加密数据
            String encryptedData = EncryptionUtils.encrypt(data, key);
            System.out.println("加密后的数据: " + encryptedData);

            // 解密数据
            String decryptedData = EncryptionUtils.decrypt(encryptedData, key);
            System.out.println("解密后的数据: " + decryptedData);
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

在上面的示例中,我们使用EncryptionUtils工具类将字符串“Hello World!”加密,使用密钥“mysecretkey”进行加密。然后我们解密密文,使用相同的密钥来解密。输出结果应该为:

加密后的数据: eUFzznJhGxtFE4G4bJOx1A==
解密后的数据: Hello World!

注意,如果密钥不正确,解密过程将会失败,因此在实际使用中需要确保密钥的正确性。

下面给大家打个广告哈哈哈:给大家介绍一个公众号,亲测方便好用。主要功能是搜索最优优惠券,购物返利,但是不仅仅包括京东、淘宝、拼多多等电商购物会返利,包括滴滴打车、美团外卖以及美团优惠券等等都会有返利,并且返利是我见过最高的。反正用到就是赚到,绝对亏不了,能省一点是一点。而且现在还接入了最火热的chatGPT,没事的时候还可以和人工智能聊天,爽歪歪。我不允许你不知道这么牛的东西。哈哈哈,二维码放到下面了,微信扫一扫试用一下。

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
你可以使用python的cryptography库来实现AES加密和解密,以及使用zeropadding进行填充。 首先,你需要安装cryptography库。可以使用以下命令来安装: ``` pip install cryptography ``` 接下来,你可以使用以下代码示例来实现AES加密和解密,并使用zeropadding进行填充: ```python from cryptography.hazmat.primitives.ciphers import Cipher, algorithms, modes from cryptography.hazmat.primitives import padding from cryptography.hazmat.backends import default_backend import os def aes_encrypt(plain_text, key): # 生成一个随机的初始化向量 iv = os.urandom(16) # 使用zeropadding进行填充 padder = padding.ZeroPadding(128).padder() padded_data = padder.update(plain_text) + padder.finalize() # 创建AES加密器对象 cipher = Cipher(algorithms.AES(key), modes.CBC(iv), backend=default_backend()) encryptor = cipher.encryptor() # 执行加密操作 cipher_text = encryptor.update(padded_data) + encryptor.finalize() return iv + cipher_text def aes_decrypt(cipher_text, key): # 提取初始化向量和密文 iv = cipher_text[:16] cipher_text = cipher_text[16:] # 创建AES解密器对象 cipher = Cipher(algorithms.AES(key), modes.CBC(iv), backend=default_backend()) decryptor = cipher.decryptor() # 执行解密操作 padded_data = decryptor.update(cipher_text) + decryptor.finalize() # 使用zeropadding进行取消填充 unpadder = padding.ZeroPadding(128).unpadder() plain_text = unpadder.update(padded_data) + unpadder.finalize() return plain_text # 测试代码 key = os.urandom(32) # 生成一个随机密钥 plain_text = b"Hello, AES!" # 原始文本 # 加密 cipher_text = aes_encrypt(plain_text, key) print("Cipher Text: ", cipher_text) # 解密 decrypted_text = aes_decrypt(cipher_text, key) print("Decrypted Text: ", decrypted_text) ``` 这段代码中,我们使用了AES加密算法和CBC模式来加密和解密数据。同时,我们使用了zeropadding进行填充,确保数据长度满足加密算法的要求。需要注意的是,密钥的长度必须符合AES算法的要求(16、24、或32字节)。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值