0
点赞
收藏
分享

微信扫一扫

AES/CBC/PKCS5Padding (128)

佳简诚锄 2022-02-08 阅读 32


CBC模式,将明文分组与前一个密文分组进行XOR运算,然后再进行加密。每个分组的加解密都依赖于前一个分组。而第一个分组没有前一个分组,因此需要一个初始化向量 IV


AES/CBC/PKCS5Padding (128)_密钥长度


package com.framework.test;

import lombok.extern.slf4j.Slf4j;
import javax.crypto.Cipher;
import javax.crypto.KeyGenerator;
import javax.crypto.SecretKey;
import javax.crypto.spec.IvParameterSpec;
import javax.crypto.spec.SecretKeySpec;
import java.security.SecureRandom;

@Slf4j
public class MainTest {

/**
* AES/ECB/PKCS5Padding (128)
* AES加密 CBC模式 PKCS5填充方式
* 密钥长度必须为16个字节(128位)
* 初始向量长度必须为16个字节
*/
public static void main(String[] args) throws Exception {
//密钥生成器
KeyGenerator kgen = KeyGenerator.getInstance("AES");
//设置密钥长度128位
kgen.init(128, new SecureRandom());
//生成key
SecretKey key = kgen.generateKey();

//长度为16的二进制数组,密钥我们自己生成也可以.
byte[] keyBytes = key.getEncoded();
System.out.println("keyBytes长度是16 = " + keyBytes.length);

//创建AES的密钥
SecretKeySpec aesKey = new SecretKeySpec(keyBytes, "AES");

//初始向量
IvParameterSpec iv = new IvParameterSpec(keyBytes);

//加密 模式 填充方式
Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5PADDING");

cipher.init(Cipher.ENCRYPT_MODE, aesKey, iv);
byte[] encrypt = cipher.doFinal("abc".getBytes());
System.out.println(encrypt.length);

cipher.init(Cipher.DECRYPT_MODE, aesKey, iv);
byte[] decrypt = cipher.doFinal(encrypt);
System.out.println(new String(decrypt));
}
}

AES/CBC/PKCS5Padding (128)_java_02


举报

相关推荐

0 条评论