/***
*@authorngh
* AES128 算法
*
* CBC 模式
*
* PKCS7Padding 填充模式
*
* CBC模式需要添加一个参数iv
*
* 介于java 不支持PKCS7Padding,只支持PKCS5Padding 但是PKCS7Padding 和 PKCS5Padding 没有什么区别
* 要实现在java端用PKCS7Padding填充,需要用到bouncycastle组件来实现*/
public classAES {//算法名称
final String KEY_ALGORITHM = "AES";//加解密算法/模式/填充方式
final String algorithmStr = "AES/CBC/PKCS7Padding";// privateKey key;privateCipher cipher;boolean isInited = false;byte[] iv = { 0x30, 0x31, 0x30, 0x32, 0x30, 0x33, 0x30, 0x34, 0x30, 0x35, 0x30, 0x36, 0x30, 0x37, 0x30, 0x38};public void init(byte[] keyBytes) {//如果密钥不足16位,那么就补足. 这个if 中的内容很重要
int base = 16;if (keyBytes.length % base != 0) {int groups = keyBytes.length / base + (keyBytes.length % base != 0 ? 1 : 0);byte[] temp = new byte[groups *base];
<