日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程语言 > java >内容正文

java

Java笔记-AES加解密(PKCS7padding可用)

發(fā)布時(shí)間:2025/3/15 java 36 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Java笔记-AES加解密(PKCS7padding可用) 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

如下代碼:

package cn.it1995.tool;import org.apache.tomcat.util.codec.binary.Base64; import sun.misc.BASE64Decoder; import sun.misc.BASE64Encoder;import javax.crypto.*; import javax.crypto.spec.IvParameterSpec; import javax.crypto.spec.SecretKeySpec; import java.io.UnsupportedEncodingException; import java.security.InvalidAlgorithmParameterException; import java.security.InvalidKeyException; import java.security.Key; import java.security.NoSuchAlgorithmException;public class AESUtil {public static String decrypt(String content, String key, String vi) throws NoSuchPaddingException, NoSuchAlgorithmException, InvalidKeyException, BadPaddingException, IllegalBlockSizeException, UnsupportedEncodingException, UnsupportedEncodingException, InvalidAlgorithmParameterException {// System.out.println("content : " + content); // System.out.println("key : " + key); // System.out.println("vi : " + vi);//Key k = toKey(Base64.decodeBase64(key));Key k = toKey(key.getBytes());byte[] encoded = k.getEncoded();SecretKeySpec aes = new SecretKeySpec(encoded, "AES");Cipher cipher = Cipher.getInstance("AES/CBC/PKCS7Padding");IvParameterSpec iv = new IvParameterSpec(vi.getBytes());cipher.init(Cipher.DECRYPT_MODE, aes, iv);byte[] bytes = cipher.doFinal(Base64.decodeBase64(content));return new String(bytes, "UTF-8");}public static String encrypt(String data, String key, String vi) throws NoSuchPaddingException, NoSuchAlgorithmException, InvalidKeyException, UnsupportedEncodingException, BadPaddingException, IllegalBlockSizeException, InvalidAlgorithmParameterException {//Key k = toKey(Base64.decodeBase64(key));Key k = toKey(key.getBytes());byte[] encoded = k.getEncoded();SecretKeySpec aes = new SecretKeySpec(encoded, "AES");Cipher cipher = Cipher.getInstance("AES/CBC/PKCS7Padding");IvParameterSpec iv = new IvParameterSpec(vi.getBytes());cipher.init(Cipher.ENCRYPT_MODE, aes, iv);byte[] bytes = cipher.doFinal(data.getBytes("UTF-8"));return Base64.encodeBase64String(bytes);}private static Key toKey(byte[] key){SecretKeySpec aes = new SecretKeySpec(key, "AES");return aes;}public static void main(String[] args) throws NoSuchPaddingException, BadPaddingException, InvalidAlgorithmParameterException, NoSuchAlgorithmException, IllegalBlockSizeException, UnsupportedEncodingException, InvalidKeyException {String content = "7mv2MJPHj1o/rdar1I4i0Q==";String key = "sN1DEJAVZNf3OdM3";String vi = "GDHgt7hbKpsIR4b4";System.out.println("原文 : root");String e = AESUtil.encrypt("root", key, vi);System.out.println("密文 : " + e);String f = AESUtil.decrypt(e, key, vi);System.out.println("解密 : " + f);}}

運(yùn)行截圖如下:

這里Cipher.getInstance中使用PKCS7padding。需要Maven中新增:

<dependency><groupId>org.bouncycastle</groupId><artifactId>bcprov-ext-jdk16</artifactId><version>1.45</version> </dependency>

?這里可以接的值有

AES加密模式:ECB、CBC、CTR、OFB、CFB;

AES填充模式:pkcs5padding、pkcs7padding、zeropadding、ISO0126、ansix923、no padding。

總結(jié)

以上是生活随笔為你收集整理的Java笔记-AES加解密(PKCS7padding可用)的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。