All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.rx.security.AESUtil Maven / Gradle / Ivy

package org.rx.security;

import lombok.SneakyThrows;
import org.rx.core.App;
import org.rx.core.Contract;

import static org.rx.core.Contract.require;

import javax.crypto.Cipher;
import javax.crypto.KeyGenerator;
import javax.crypto.spec.SecretKeySpec;
import java.security.Key;
import java.security.SecureRandom;

public class AESUtil {
    private static final String AES_ALGORITHM = "AES/ECB/PKCS5Padding";

    @SneakyThrows
    public static byte[] generateKey() {
        KeyGenerator keygen = KeyGenerator.getInstance(AES_ALGORITHM);
        SecureRandom random = new SecureRandom();
        keygen.init(random);
        Key key = keygen.generateKey();
        return key.getEncoded();
    }

    public static String genarateRandomKeyWithBase64() {
        return App.convertToBase64String(generateKey());
    }

    @SneakyThrows
    public static String encryptToBase64(String data, String key) {
        require(data, key);

        byte[] valueByte = encrypt(data.getBytes(Contract.Utf8), key.getBytes(Contract.Utf8));
        return App.convertToBase64String(valueByte);
    }

    @SneakyThrows
    public static String decryptFromBase64(String data, String key) {
        require(data, key);

        byte[] valueByte = decrypt(App.convertFromBase64String(data), key.getBytes(Contract.Utf8));
        return new String(valueByte, Contract.Utf8);
    }

    @SneakyThrows
    public static String encryptWithKeyBase64(String data, String key) {
        require(data, key);

        byte[] valueByte = encrypt(data.getBytes(Contract.Utf8), App.convertFromBase64String(key));
        return App.convertToBase64String(valueByte);
    }

    @SneakyThrows
    public static String decryptWithKeyBase64(String data, String key) {
        require(data, key);

        byte[] valueByte = decrypt(App.convertFromBase64String(data), App.convertFromBase64String(key));
        return new String(valueByte, Contract.Utf8);
    }

    /**
     * 加密
     *
     * @param data 待加密内容
     * @param key  加密密钥
     * @return
     */
    @SneakyThrows
    public static byte[] encrypt(byte[] data, byte[] key) {
        require(data, key);
        require(key, key.length == 16);

        SecretKeySpec secretKey = new SecretKeySpec(key, "AES");
        byte[] enCodeFormat = secretKey.getEncoded();
        SecretKeySpec seckey = new SecretKeySpec(enCodeFormat, "AES");
        Cipher cipher = Cipher.getInstance(AES_ALGORITHM);// 创建密码器
        cipher.init(Cipher.ENCRYPT_MODE, seckey);// 初始化
        return cipher.doFinal(data);// 加密
    }

    /**
     * 解密
     *
     * @param data 待解密内容
     * @param key  解密密钥
     * @return
     */
    @SneakyThrows
    public static byte[] decrypt(byte[] data, byte[] key) {
        require(data, key);
        require(key, key.length == 16);

        SecretKeySpec secretKey = new SecretKeySpec(key, "AES");
        byte[] enCodeFormat = secretKey.getEncoded();
        SecretKeySpec seckey = new SecretKeySpec(enCodeFormat, "AES");
        Cipher cipher = Cipher.getInstance(AES_ALGORITHM);// 创建密码器
        cipher.init(Cipher.DECRYPT_MODE, seckey);// 初始化
        return cipher.doFinal(data); // 加密
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy