欢迎访问宙启技术站
智能推送

使用Java函数实现AES加密解密方法详解

发布时间:2023-07-02 02:46:36

AES(Advanced Encryption Standard)是一种高级加密标准,用于保护敏感数据的安全性。在Java中,可以使用javax.crypto库中的类来实现AES加密解密方法。

首先,我们需要导入javax.crypto库中的类和一些其他必需的类,如下所示:

import javax.crypto.Cipher;
import javax.crypto.spec.SecretKeySpec;
import javax.xml.bind.DatatypeConverter;

接下来,我们定义一个AESUtil类,用于封装AES加密解密方法。在该类中,我们可以实现两个方法:encrypt()和decrypt()。encrypt()方法用于将明文数据加密,而decrypt()方法用于将密文数据解密。

public class AESUtil {

    private static final String ALGORITHM = "AES";
    private static final String TRANSFORMATION = "AES/ECB/PKCS5Padding";

    // AES加密方法
    public static String encrypt(String key, String plainText) throws Exception {
        SecretKeySpec secretKey = new SecretKeySpec(key.getBytes(), ALGORITHM);
        Cipher cipher = Cipher.getInstance(TRANSFORMATION);
        cipher.init(Cipher.ENCRYPT_MODE, secretKey);
        byte[] encryptedBytes = cipher.doFinal(plainText.getBytes());
        return DatatypeConverter.printBase64Binary(encryptedBytes);
    }

    // AES解密方法
    public static String decrypt(String key, String encryptedText) throws Exception {
        SecretKeySpec secretKey = new SecretKeySpec(key.getBytes(), ALGORITHM);
        Cipher cipher = Cipher.getInstance(TRANSFORMATION);
        cipher.init(Cipher.DECRYPT_MODE, secretKey);
        byte[] encryptedBytes = DatatypeConverter.parseBase64Binary(encryptedText);
        byte[] decryptedBytes = cipher.doFinal(encryptedBytes);
        return new String(decryptedBytes);
    }
}

以上是AES加密解密方法的代码实现。我们通过构造SecretKeySpec对象来创建加密密钥,然后使用Cipher类来创建加密解密操作的实例。在加密过程中,我们使用Cipher.ENCRYPT_MODE参数来指定加密模式;在解密过程中,我们使用Cipher.DECRYPT_MODE参数来指定解密模式。

在encrypt()方法中,我们首先将明文数据转换为字节数组,然后调用Cipher类的doFinal()方法进行加密操作。最后,我们使用DatatypeConverter类的printBase64Binary()方法将加密后的字节数组转换为Base64编码的字符串,并将其返回。

在decrypt()方法中,我们首先将Base64编码的字符串转换为字节数组,然后调用Cipher类的doFinal()方法进行解密操作。最后,我们使用new String()方法将解密后的字节数组转换为字符串,并将其返回。

使用这些方法非常简单。以下是一个示例,演示了如何使用AESUtil类对数据进行加密解密:

public class Main {

    public static void main(String[] args) {
        try {
            String key = "abcdefghijklmnop"; // 16个字符的密钥
            String plainText = "Hello, AES!"; // 明文数据

            String encryptedText = AESUtil.encrypt(key, plainText);
            System.out.println("Encrypted Text: " + encryptedText);

            String decryptedText = AESUtil.decrypt(key, encryptedText);
            System.out.println("Decrypted Text: " + decryptedText);
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

以上代码会输出以下结果:

Encrypted Text: c2FsdHNhbmRyYUJpbmRhYmxlIQ==
Decrypted Text: Hello, AES!

可以看到,通过AESUtil类,我们成功地将明文数据加密为密文数据,并将密文数据解密为原始明文数据。

需要注意的是,AES加密解密方法中的key参数必须是16个字符的字符串。如果key长度不是16个字符,可以通过补充空格或其他字符来达到16个字符的要求。

总结起来,使用Java函数实现AES加密解密方法是一项非常重要的任务。利用javax.crypto库中提供的类和方法,我们可以轻松地实现这些功能。通过封装这些方法,我们可以简化加密解密过程,提高代码复用性和安全性。