国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

Java實現AES/CBC/PKCS7Padding加解密的方法

瀏覽:5日期:2022-08-27 11:21:30

最近項目需要選擇一套對稱加密算法,來滿足前后端之間的加解密操作。初步打算前端使用crypto-js來實現,后端使用java本身的加密算法實現,但遇到了一個問題:java本身只支持NoPadding和PKCS5Padding,而crypto-js提供的padding方式沒有PKCS5Padding,所以不得以,前后端最終使用PKCS7Padding來實現功能.因此只能通過引入第三方jar包的方式讓jave支持pkcs7padding

引入依賴

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

完整代碼

package com.hzjd.miniapp.util;import java.security.Security;import java.security.spec.AlgorithmParameterSpec;import javax.crypto.Cipher;import javax.crypto.spec.IvParameterSpec;import javax.crypto.spec.SecretKeySpec;import org.apache.commons.codec.binary.Base64;import org.apache.commons.lang.StringUtils;import org.bouncycastle.jce.provider.BouncyCastleProvider;import com.sun.istack.internal.NotNull;public class AESUtil {private static final String CHARSET_NAME = 'UTF-8';private static final String AES_NAME = 'AES';// 加密模式public static final String ALGORITHM = 'AES/CBC/PKCS7Padding';// 密鑰public static final String KEY = '1954682168745975';// 偏移量public static final String IV = '1954682168745975';static {Security.addProvider(new BouncyCastleProvider());}/** * 加密 * * @param content * @param key * @return */public String encrypt(@NotNull String content) {byte[] result = null;try {Cipher cipher = Cipher.getInstance(ALGORITHM);SecretKeySpec keySpec = new SecretKeySpec(KEY.getBytes(CHARSET_NAME), AES_NAME);AlgorithmParameterSpec paramSpec = new IvParameterSpec(IV.getBytes());cipher.init(Cipher.ENCRYPT_MODE, keySpec, paramSpec);result = cipher.doFinal(content.getBytes(CHARSET_NAME));} catch (Exception e) {e.printStackTrace();}return Base64.encodeBase64String(result);}/** * 解密 * * @param content * @param key * @return */public String decrypt(@NotNull String content) {try {Cipher cipher = Cipher.getInstance(ALGORITHM);SecretKeySpec keySpec = new SecretKeySpec(KEY.getBytes(CHARSET_NAME), AES_NAME);AlgorithmParameterSpec paramSpec = new IvParameterSpec(IV.getBytes());cipher.init(Cipher.DECRYPT_MODE, keySpec, paramSpec);return new String(cipher.doFinal(Base64.decodeBase64(content)), CHARSET_NAME);} catch (Exception e) {e.printStackTrace();}return StringUtils.EMPTY;}public static void main(String[] args) {AESUtil aes = new AESUtil();String contents = '121456465';String encrypt = aes.encrypt(contents);System.out.println('加密后:' + encrypt);String decrypt = aes.decrypt(encrypt);System.out.println('解密后:' + decrypt);}}

總結

到此這篇關于Java實現AES/CBC/PKCS7Padding加解密的方法的文章就介紹到這了,更多相關Java實現AES/CBC/PKCS7Padding加解密內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Java
相關文章:
主站蜘蛛池模板: 欧美日韩在线观看一区 | 古代级a毛片可以免费看 | 我要看a级毛片 | 国产a久久精品一区二区三区 | 亚洲加勒比久久88色综合1 | 午夜三级国产精品理论三级 | 国产精品久久久久久麻豆一区 | 欧美午夜精品久久久久久黑人 | 色视频在线观看免费 | 亚洲欧美日韩另类精品一区二区三区 | 欧美激情精品久久久久 | 国产精品一区二区国产 | 国产夫妇精品自在线 | 久久久久久久久一次 | dy888午夜国产午夜精品 | 成年女人毛片免费播放人 | 日本免费视频观看在线播放 | 欧美视频一区二区 | 亚洲综合91社区精品福利 | 国产亚洲一欧美一区二区三区 | 另类视频在线观看 | 在线成人亚洲 | 特及毛片 | 国产九九视频在线观看 | 日本亚欧乱色视频在线观看 | 九九99香蕉在线视频网站 | 国产成人一区二区三区视频免费 | 欧美啊啊啊 | bt天堂国产亚洲欧美在线 | 女人夜色黄网在线观看 | 国产女厕偷窥系列在线视频 | 日本不卡免费高清视频 | 国产一级爱做片免费观看 | 91情侣高清精品国产 | 国产欧美日韩不卡一区二区三区 | 亚洲国产精品一区二区三区 | 日韩美女强理论片 | 欧美日本在线三级视频 | 免费人成黄页网站在线观看国产 | 天天五月天丁香婷婷深爱综合 | 国产午夜精品理论片影院 |