Java中AES的加密解密算法(项目中可以直接使用)
今天给大家分享一套加密解密算法,可直接使用。需要更多实用小代码的可以关注我,我会持续更新!
package com.keenlycms.common.util;
import java.security.AlgorithmParameters;
import java.security.Key;
import java.security.SecureRandom;
import java.security.Security;
import java.util.Arrays;
import javax.crypto.Cipher;
import javax.crypto.KeyGenerator;
import javax.crypto.SecretKey;
import javax.crypto.spec.IvParameterSpec;
import javax.crypto.spec.SecretKeySpec;
public class AES128Util {
//算法名
public static final String KEY_ALGORITHM = "AES";
//加解密算法/模式/填充方式
//可以任意选择,为了方便后面与iOS端的加密解密,采用与其相同的模式与填充方式
//ECB模式只用密钥即可对数据进行加密解密,CBC模式需要添加一个参数iv
public static final String CIPHER_ALGORITHM = "AES/CBC/PKCS7Padding";
//生成密钥
private static byte[] generateKey(String aesKey) throws Exception{
Security.addProvider(new org.bouncycastle.jc