亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Java實(shí)現(xiàn)AES加密和解密方式完整示例

 更新時(shí)間:2023年10月12日 10:21:37   作者:=蝸牛=  
這篇文章主要給大家介紹了關(guān)于Java實(shí)現(xiàn)AES加密和解密方式的相關(guān)資料,AES加密為最常見(jiàn)的對(duì)稱加密算法,是一種區(qū)塊加密標(biāo)準(zhǔn),這個(gè)標(biāo)準(zhǔn)用來(lái)替代原先的DES,已經(jīng)被多方分析且廣為全世界所使用,需要的朋友可以參考下

1、簡(jiǎn)介

AES,全稱為 Advanced Encryption Standard,是一種分組密碼算法,用于保護(hù)敏感數(shù)據(jù)的傳輸和存儲(chǔ)。AES 分為 128 位和 256 位兩種密鑰長(zhǎng)度,可以對(duì)數(shù)據(jù)進(jìn)行加密和解密,保證數(shù)據(jù)的安全性和完整性。AES 主要應(yīng)用于電子商務(wù)、移動(dòng)支付、網(wǎng)絡(luò)安全等領(lǐng)域,被廣泛運(yùn)用于現(xiàn)代社會(huì)的各個(gè)方面。AES 算法被設(shè)計(jì)為高度安全,可以在理論上保證其分組密碼的安全性。然而,由于其復(fù)雜性和密鑰長(zhǎng)度,AES 算法的實(shí)現(xiàn)和應(yīng)用也具有一定的技術(shù)難度。因此,在應(yīng)用 AES算法時(shí),需要注意加強(qiáng)密鑰管理和安全性保障。

這個(gè)標(biāo)準(zhǔn)用來(lái)替代原先的 DES(Data Encryption Standard),已經(jīng)被多方分析且廣為全世界所使用。

AES 算法具有很多優(yōu)點(diǎn),例如快速、安全、可靠等。它可以加密大量數(shù)據(jù),而不會(huì)因?yàn)榧用苓^(guò)程中的數(shù)據(jù)量過(guò)大而變得緩慢。此外,AES 算法還支持塊大小的自動(dòng)調(diào)整,可以處理不同大小的數(shù)據(jù)塊。

2、AES 加密模式

2.1、加密方式

ECB(Electronic Codebook)模式:這種模式是將整個(gè)明文分成若干段相同的小段,然后對(duì)每一小段進(jìn)行加密。加密時(shí),使用一個(gè)密鑰,將明文中的每個(gè)字符與密鑰中對(duì)應(yīng)位置的字符進(jìn)行異或運(yùn)算,得到密文。

CBC(Cipher Block Chaining)模式:這種模式是先將明文切分成若干小段,然后每一小段與初始?jí)K或者上一段的密文段進(jìn)行異或運(yùn)算后,再與密鑰進(jìn)行加密。加密時(shí),使用一個(gè)密鑰和一個(gè)初始化向量(IV),初始化向量是一個(gè)16字節(jié)的向量,包含了加密算法所需的所有信息。

CFB(Cipher Feedback)模式:這種模式是一種較為復(fù)雜的加密模式,它結(jié)合了CBC和CTR兩種模式的優(yōu)點(diǎn)。在CFB模式中,加密過(guò)程中使用一個(gè)密鑰和一個(gè)隨機(jī)生成的初始化向量(IV),然后對(duì)明文進(jìn)行加密。在加密完成后,通過(guò)對(duì)明文進(jìn)行非對(duì)稱加密來(lái)生成密文的向量。隨后,通過(guò)對(duì)密文進(jìn)行反向操作,將密文的向量與明文的向量進(jìn)行異或運(yùn)算,得到解密所需的密鑰。

需要注意的是,ECB、CBC、CFB等模式都是對(duì)稱加密算法,加密和解密使用相同的密鑰。在使用這些算法時(shí),需要注意保護(hù)密鑰的安全,避免被惡意獲取。

2.2、安全性

ECB 不夠安全,只適合于短數(shù)據(jù)的加密,而 CBC 和 CFB 相較于 ECB 更加安全,因?yàn)榍耙粋€(gè)密文塊會(huì)影響當(dāng)前明文塊,使攻擊者難以預(yù)測(cè)密文的結(jié)構(gòu)。

2.3、速度

ECB 是最簡(jiǎn)單的加密方式,速度最快,但由于安全性差不建議使用,CBC 因?yàn)槊總€(gè)明文塊都要與前一個(gè)密文塊進(jìn)行異或操作,比 ECB 要慢一些,CFB 因?yàn)樾枰磸?fù)加密和解密,速度可能會(huì)更慢。

總的來(lái)說(shuō),選擇 AES 的算法模式需要根據(jù)加密需要的安全性和速度來(lái)進(jìn)行選擇,通常推薦使用CBC 或 CFB 模式,而不是 ECB 模式。

3、Java 實(shí)現(xiàn)完整示例

在 Java 中,可以使用 javax.crypto 包中的 Cipher 類來(lái)實(shí)現(xiàn) AES 加密和解密。完整代碼如下:

package com.csdn.woniu.example;
import javax.crypto.Cipher;
import javax.crypto.spec.IvParameterSpec;
import javax.crypto.spec.SecretKeySpec;
import java.nio.charset.StandardCharsets;
import java.util.Base64;
import java.util.Random;
/**
 * <h1>AES 加密和解密示例代碼</h1>
 * Created by woniu
 * */
public class AESExample {
    /** 加密模式之 ECB,算法/模式/補(bǔ)碼方式 */
    private static final String AES_ECB = "AES/ECB/PKCS5Padding";
    /** 加密模式之 CBC,算法/模式/補(bǔ)碼方式 */
    private static final String AES_CBC = "AES/CBC/PKCS5Padding";
    /** 加密模式之 CFB,算法/模式/補(bǔ)碼方式 */
    private static final String AES_CFB = "AES/CFB/PKCS5Padding";
    /** AES 中的 IV 必須是 16 字節(jié)(128位)長(zhǎng) */
    private static final Integer IV_LENGTH = 16;
    /***
     * <h2>空校驗(yàn)</h2>
     * @param str 需要判斷的值
     */
    public static boolean isEmpty(Object str) {
        return null == str || "".equals(str);
    }
    /***
     * <h2>String 轉(zhuǎn) byte</h2>
     * @param str 需要轉(zhuǎn)換的字符串
     */
    public static byte[] getBytes(String str){
        if (isEmpty(str)) {
            return null;
        }
        try {
            return str.getBytes(StandardCharsets.UTF_8);
        } catch (Exception e) {
            throw new RuntimeException(e);
        }
    }
    /***
     * <h2>初始化向量(IV),它是一個(gè)隨機(jī)生成的字節(jié)數(shù)組,用于增加加密和解密的安全性</h2>
     */
    public static String getIV(){
        String str = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789";
        Random random = new Random();
        StringBuffer sb = new StringBuffer();
        for(int i = 0 ; i < IV_LENGTH ; i++){
            int number = random.nextInt(str.length());
            sb.append(str.charAt(number));
        }
        return sb.toString();
    }
    /***
     * <h2>獲取一個(gè) AES 密鑰規(guī)范</h2>
     */
    public static SecretKeySpec getSecretKeySpec(String key){
        SecretKeySpec secretKeySpec = new SecretKeySpec(getBytes(key), "AES");
        return secretKeySpec;
    }
    /**
     * <h2>加密 - 模式 ECB</h2>
     * @param text 需要加密的文本內(nèi)容
     * @param key 加密的密鑰 key
     * */
    public static String encrypt(String text, String key){
        if (isEmpty(text) || isEmpty(key)) {
            return null;
        }
        try {
            // 創(chuàng)建AES加密器
            Cipher cipher = Cipher.getInstance(AES_ECB);
            SecretKeySpec secretKeySpec = getSecretKeySpec(key);
            cipher.init(Cipher.ENCRYPT_MODE, secretKeySpec);
            // 加密字節(jié)數(shù)組
            byte[] encryptedBytes = cipher.doFinal(getBytes(text));
            // 將密文轉(zhuǎn)換為 Base64 編碼字符串
            return Base64.getEncoder().encodeToString(encryptedBytes);
        } catch (Exception e) {
            throw new RuntimeException(e);
        }
    }
    /**
     * <h2>解密 - 模式 ECB</h2>
     * @param text 需要解密的文本內(nèi)容
     * @param key 解密的密鑰 key
     * */
    public static String decrypt(String text, String key){
        if (isEmpty(text) || isEmpty(key)) {
            return null;
        }
        // 將密文轉(zhuǎn)換為16字節(jié)的字節(jié)數(shù)組
        byte[] textBytes = Base64.getDecoder().decode(text);
        try {
            // 創(chuàng)建AES加密器
            Cipher cipher = Cipher.getInstance(AES_ECB);
            SecretKeySpec secretKeySpec = getSecretKeySpec(key);
            cipher.init(Cipher.DECRYPT_MODE, secretKeySpec);
            // 解密字節(jié)數(shù)組
            byte[] decryptedBytes = cipher.doFinal(textBytes);
            // 將明文轉(zhuǎn)換為字符串
            return new String(decryptedBytes, StandardCharsets.UTF_8);
        } catch (Exception e) {
            throw new RuntimeException(e);
        }
    }
    /**
     * <h2>加密 - 自定義加密模式</h2>
     * @param text 需要加密的文本內(nèi)容
     * @param key 加密的密鑰 key
     * @param iv 初始化向量
     * @param mode 加密模式
     * */
    public static String encrypt(String text, String key, String iv, String mode){
        if (isEmpty(text) || isEmpty(key) || isEmpty(iv)) {
            return null;
        }
        try {
            // 創(chuàng)建AES加密器
            Cipher cipher = Cipher.getInstance(mode);
            SecretKeySpec secretKeySpec = getSecretKeySpec(key);
            cipher.init(Cipher.ENCRYPT_MODE, secretKeySpec, new IvParameterSpec(getBytes(iv)));
            // 加密字節(jié)數(shù)組
            byte[] encryptedBytes = cipher.doFinal(getBytes(text));
            // 將密文轉(zhuǎn)換為 Base64 編碼字符串
            return Base64.getEncoder().encodeToString(encryptedBytes);
        } catch (Exception e) {
            throw new RuntimeException(e);
        }
    }
    /**
     * <h2>解密 - 自定義加密模式</h2>
     * @param text 需要解密的文本內(nèi)容
     * @param key 解密的密鑰 key
     * @param iv 初始化向量
     * @param mode 加密模式
     * */
    public static String decrypt(String text, String key, String iv, String mode){
        if (isEmpty(text) || isEmpty(key) || isEmpty(iv)) {
            return null;
        }
        // 將密文轉(zhuǎn)換為16字節(jié)的字節(jié)數(shù)組
        byte[] textBytes = Base64.getDecoder().decode(text);
        try {
            // 創(chuàng)建AES加密器
            Cipher cipher = Cipher.getInstance(mode);
            SecretKeySpec secretKeySpec = getSecretKeySpec(key);
            cipher.init(Cipher.DECRYPT_MODE, secretKeySpec, new IvParameterSpec(getBytes(iv)));
            // 解密字節(jié)數(shù)組
            byte[] decryptedBytes = cipher.doFinal(textBytes);
            // 將明文轉(zhuǎn)換為字符串
            return new String(decryptedBytes, StandardCharsets.UTF_8);
        } catch (Exception e) {
            throw new RuntimeException(e);
        }
    }
    public static void main(String[] args) {
        String text = "嗨,您好!";
        String key  = "woniucsdnvip8888"; // 16字節(jié)的密鑰
        String iv  = getIV();
        String encryptTextEBC = encrypt(text, key);
        System.out.println("EBC 加密后內(nèi)容:" + encryptTextEBC);
        System.out.println("EBC 解密后內(nèi)容:" + decrypt(encryptTextEBC, key));
        System.out.println();
        String encryptTextCBC = encrypt(text, key, iv, AES_CBC);
        System.out.println("CBC 加密IV:" + iv);
        System.out.println("CBC 加密后內(nèi)容:" + encryptTextCBC);
        System.out.println("CBC 解密后內(nèi)容:" + decrypt(encryptTextCBC, key, iv, AES_CBC));
        System.out.println();
        String encryptTextCFB = encrypt(text, key, iv, AES_CFB);
        System.out.println("CFB 加密IV:" + iv);
        System.out.println("CFB 加密后內(nèi)容:" + encryptTextCFB);
        System.out.println("CFB 解密后內(nèi)容:" + decrypt(encryptTextCFB, key, iv, AES_CFB));
    }
}

運(yùn)行結(jié)果如下:

EBC 加密后內(nèi)容:Nc6r9GcghANVXeAek8OQAg==
EBC 解密后內(nèi)容:嗨,您好!

CBC 加密IV:sIVxRsEWgAHNNLYo
CBC 加密后內(nèi)容:515S8VG52TqbhUwB1T9DiA==
CBC 解密后內(nèi)容:嗨,您好!

CFB 加密IV:sIVxRsEWgAHNNLYo
CFB 加密后內(nèi)容:C3MNkL3f4be9hwkrA0VsNg==
CFB 解密后內(nèi)容:嗨,您好!

總結(jié)

到此這篇關(guān)于Java實(shí)現(xiàn)AES加密和解密方式的文章就介紹到這了,更多相關(guān)Java AES加密解密內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Java使用多線程處理未知任務(wù)數(shù)的方案介紹

    Java使用多線程處理未知任務(wù)數(shù)的方案介紹

    這篇文章主要為大家詳細(xì)介紹了Java如何使用多線程實(shí)現(xiàn)處理未知任務(wù)數(shù),文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2025-03-03
  • Spring?createBeanInstance實(shí)例化Bean

    Spring?createBeanInstance實(shí)例化Bean

    這篇文章主要為大家介紹了Spring?createBeanInstance實(shí)例化Bean源碼解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-03-03
  • Java 讀取excel 文件流代碼實(shí)例

    Java 讀取excel 文件流代碼實(shí)例

    這篇文章主要介紹了Java 讀取excel 文件流代碼實(shí)例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-09-09
  • Spring實(shí)戰(zhàn)之FileSystemResource加載資源文件示例

    Spring實(shí)戰(zhàn)之FileSystemResource加載資源文件示例

    這篇文章主要介紹了Spring實(shí)戰(zhàn)之FileSystemResource加載資源文件,結(jié)合實(shí)例形式分析了spring FileSystemResource加載xml資源文件的具體實(shí)現(xiàn)步驟與相關(guān)操作技巧,需要的朋友可以參考下
    2019-12-12
  • SpringBoot中Controller的傳參方式詳細(xì)講解

    SpringBoot中Controller的傳參方式詳細(xì)講解

    這篇文章主要介紹了SpringBoot在Controller層接收參數(shù)的常用方法,Controller接收參數(shù)的常用方式總體可以分為三類,第一類是Get請(qǐng)求通過(guò)拼接url進(jìn)行傳遞,第二類是Post請(qǐng)求通過(guò)請(qǐng)求體進(jìn)行傳遞,第三類是通過(guò)請(qǐng)求頭部進(jìn)行參數(shù)傳遞,下面我們來(lái)詳細(xì)看看
    2023-01-01
  • Java虛擬機(jī)JVM性能優(yōu)化(三):垃圾收集詳解

    Java虛擬機(jī)JVM性能優(yōu)化(三):垃圾收集詳解

    這篇文章主要介紹了Java虛擬機(jī)JVM性能優(yōu)化(三):垃圾收集詳解,本文講解了眾多的JVM垃圾收集器知識(shí)點(diǎn),需要的朋友可以參考下
    2014-09-09
  • SpringBoot項(xiàng)目實(shí)現(xiàn)關(guān)閉數(shù)據(jù)庫(kù)配置和springSecurity

    SpringBoot項(xiàng)目實(shí)現(xiàn)關(guān)閉數(shù)據(jù)庫(kù)配置和springSecurity

    這篇文章主要介紹了SpringBoot項(xiàng)目實(shí)現(xiàn)關(guān)閉數(shù)據(jù)庫(kù)配置和springSecurity的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-08-08
  • SpringBoot實(shí)現(xiàn)文件下載的四種方式

    SpringBoot實(shí)現(xiàn)文件下載的四種方式

    本文主要介紹了SpringBoot實(shí)現(xiàn)文件下載的四種方式,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-11-11
  • 基于Spring@Autowired注解與自動(dòng)裝配詳談

    基于Spring@Autowired注解與自動(dòng)裝配詳談

    下面小編就為大家?guī)?lái)一篇基于Spring@Autowired注解與自動(dòng)裝配詳談。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-10-10
  • JVM進(jìn)階教程之字段訪問(wèn)優(yōu)化淺析

    JVM進(jìn)階教程之字段訪問(wèn)優(yōu)化淺析

    這篇文章主要給大家介紹了關(guān)于JVM進(jìn)階教程之字段訪問(wèn)優(yōu)化的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-01-01

最新評(píng)論