对称加密 CBC 模式 JAVA 工具类,mysql面试题查询语句

文章介绍了AESUtil类,用于在Java中实现AES算法的CBC模式加密和解密,包括使用PKCS5Padding填充和Base64编码/解码操作。
摘要由CSDN通过智能技术生成

工具类二(PKCS5Padding)


package com.eversec.ctf.util;

import java.io.UnsupportedEncodingException;

import java.nio.charset.StandardCharsets;

import java.security.NoSuchAlgorithmException;

import java.security.SecureRandom;

import java.security.Security;

import javax.crypto.Cipher;

import javax.crypto.KeyGenerator;

import javax.crypto.SecretKey;

import javax.crypto.spec.IvParameterSpec;

import javax.crypto.spec.SecretKeySpec;

import org.apache.commons.codec.binary.Base64;

/**

  • @author XUWEICHAO

  • 对称加密 CBC模式

*/

public class AESUtil {

/**

  • randomSourceLength:随机源长度.

  • @since JDK 1.8

*/

private static int RANDOM_SOURCE_LENGTH = 128;

public static final String CIPHER_MODE_CBC_PKCS5PADDING = “AES/CBC/PKCS5Padding”;

public static final String ENCRY_ALG = “AES”;

public static final String ENCODE_NAME_UTF8 = “utf-8”;

// =============================== 有向量 =====================

/**

  • createIV:创建指定长度向量.

  • @param ivSize 向量长度

  • @param password 密码

  • @return 向量

  • @author atc

  • @since JDK 1.8

*/

private static IvParameterSpec createIV(int ivSize, String password) {

StringBuffer sb = new StringBuffer(ivSize);

sb.append(password);

if (sb.length() > ivSize) {

sb.setLength(ivSize);

}

if (sb.length() < ivSize) {

while (sb.length() < ivSize) {

sb.append(“0”);

}

}

byte[] data = null;

try {

data = sb.toString().getBytes(ENCODE_NAME_UTF8);

} catch (UnsupportedEncodingException e) {

e.printStackTrace();

}

return new IvParameterSpec(data);

}

/**

  • aesCbcPkcsNPaddingEncrypt:有向量CBC模式.

  • @param password 密码

  • @param content 待加密内容

  • @param ivSize 向量长度

  • @param ivStr 偏移量

  • @return

  • @author atc

  • @since JDK 1.8

*/

public static String aesCbcPkcsNPaddingEncrypt(String password, String content,

int ivSize, String ivStr) {

try {

byte[] byteEncode = content.getBytes(ENCODE_NAME_UTF8);

SecretKeySpec key = (SecretKeySpec) passwordKeyBytes(password);

Cipher cipher = Cipher.getInstance(CIPHER_MODE_CBC_PKCS5PADDING);

cipher.init(Cipher.ENCRYPT_MODE, key, createIV(ivSize, ivStr));

byte[] data = cipher.doFinal(byteEncode);

String result = Base64.encodeBase64String(data);

return result;

} catch (Exception e) {

e.printStackTrace();

}

return null;

}

/**

  • aesCbcPkcsNPaddingDecrypt:AES数据解密,有向量CBC模式.

  • @param password 密码

  • @param content 加密后的内容

  • @param ivSize 向量长度

  • @param ivStr 偏移量

  • @return 解密后的内容

  • @author atc

  • @since JDK 1.8

*/

public static String aesCbcPkcsNPaddingDecrypt(String password, String content, int ivSize, String ivStr) {

try {

byte[] data = Base64.decodeBase64(content);

SecretKeySpec key = (SecretKeySpec) passwordKeyBytes(password);

Cipher cipher = Cipher.getInstance(CIPHER_MODE_CBC_PKCS5PADDING);

cipher.init(Cipher.DECRYPT_MODE, key, createIV(ivSize, ivStr));

byte[] bs = cipher.doFinal(data);

String result = new String(bs, ENCODE_NAME_UTF8);

return result;

} catch (Exception e) {

e.printStackTrace();

}

return null;

}

/**

  • passwordKeyBytes:密钥KEY生成.

  • @param password 明文密码

  • @return 生成密码对应算法的密钥

  • @author atc

  • @since JDK 1.8

*/

public static SecretKey passwordKeyBytes(String password) {

// 1.构造密钥生成器,指定为AES算法,不区分大小写

KeyGenerator keygen;

try {

keygen = KeyGenerator.getInstance(ENCRY_ALG);

// 2.根据ecnodeRules规则初始化密钥生成器

小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级Java工程师,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新Java开发全套学习资料》送给大家,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频

如果你觉得这些内容对你有帮助,可以添加下面V无偿领取!(备注Java)
img

最后,附一张自己面试前准备的脑图:

image

面试前一定少不了刷题,为了方便大家复习,我分享一波个人整理的面试大全宝典

  • Java核心知识整理

image

  • Spring全家桶(实战系列)

image.png

Step3:刷题

既然是要面试,那么就少不了刷题,实际上春节回家后,哪儿也去不了,我自己是刷了不少面试题的,所以在面试过程中才能够做到心中有数,基本上会清楚面试过程中会问到哪些知识点,高频题又有哪些,所以刷题是面试前期准备过程中非常重要的一点。

以下是我私藏的面试题库:

image

很多人感叹“学习无用”,实际上之所以产生无用论,是因为自己想要的与自己所学的匹配不上,这也就意味着自己学得远远不够。无论是学习还是工作,都应该有主动性,所以如果拥有大厂梦,那么就要自己努力去实现它。

最后祝愿各位身体健康,顺利拿到心仪的offer!

Step3:刷题**

既然是要面试,那么就少不了刷题,实际上春节回家后,哪儿也去不了,我自己是刷了不少面试题的,所以在面试过程中才能够做到心中有数,基本上会清楚面试过程中会问到哪些知识点,高频题又有哪些,所以刷题是面试前期准备过程中非常重要的一点。

以下是我私藏的面试题库:

[外链图片转存中…(img-smBbBGv9-1711107494782)]

很多人感叹“学习无用”,实际上之所以产生无用论,是因为自己想要的与自己所学的匹配不上,这也就意味着自己学得远远不够。无论是学习还是工作,都应该有主动性,所以如果拥有大厂梦,那么就要自己努力去实现它。

最后祝愿各位身体健康,顺利拿到心仪的offer!

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

  • 29
    点赞
  • 30
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值