AES/CBC/PKCS5Padding (128)

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

 

 

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

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值