AES/CBC/PKCS5Padding (128)

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

 

AES/CBC/PKCS5Padding (128)_第1张图片

 

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));
    }
}

关注公众号,获取更多技术文章。

你可能感兴趣的:(JAVA)