天天看點

Java AES加密介紹以及工具類(ecb加密)一、AES加密是什麼?二、工具類代碼

文章目錄

  • 一、AES加密是什麼?
    • 簡介
    • 特點
  • 二、工具類代碼

⚠️⚠️⚠️注意:

本文工具類針對的是Java環境下, AES對稱加密的工具類, 包括加密和解密。

想直接看工具類代碼的點選工具類代碼

一、AES加密是什麼?

簡介

AES的全稱是Advanced Encryption Standard(進階加密标準)

是最常見的對稱加密算法。

大概的意思如下圖:

Java AES加密介紹以及工具類(ecb加密)一、AES加密是什麼?二、工具類代碼

在 AES 對稱加密算法中,加密與解密的密鑰是相同的。密鑰為接收方與發送方協商産生,但不可以直接在網絡上傳輸,否則會導緻密鑰洩漏,通常是通過非對稱加密算法加密密鑰,然後再通過網絡傳輸給對方,或者直接面對面商量密鑰。密鑰是絕對不可以洩漏的,否則會被攻擊者還原密文,竊取機密資料。

說人話就是雙方約定一個key,發送方用key加密。接收方用key解密。

特點

密鑰隻有一個,加密和解密使用同一個密鑰;

長度與明文大緻相同;

相比非對稱加密速度很快;

安全性較非對稱加密弱;

如果存在很多使用者,那麼相比非對稱加密需要維護大量的密碼,不利于管理;

要求提供一條安全的管道使通訊雙方在首次通訊時協商一個共同的密鑰。直接的面對面協商可能是不現實而且難于實施的,是以雙方可能需要借助于郵件和電話等其它相對不夠安全的手段來進行協商;

對稱加密算法一般不能提供資訊完整性的鑒别。它無法驗證發送者和接受者的身份。

二、工具類代碼

⚠️注意:本文介紹的是ecb加密的方式。

⚠️注意:在導包的時候注意不要導錯

package com.iou.common.utils;


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

import javax.crypto.Cipher;
import javax.crypto.spec.SecretKeySpec;

/**
 * @description: AES加密工具類
 * @author: 孤獨的小餅幹
 * @create: 
 **/
public class AesUtil {


    /**
     * 加密
     * @param sSrc 需要加密的字元串
     * @param sKey 此處使用AES-128-ECB加密模式,key需要為16位。
     * @return
     * @throws Exception
     */
    public static String Encrypt(String sSrc, String sKey) throws Exception {

        // 判斷Key是否為16位
        if (sKey.length() != 16) {
            System.out.print("Key長度不是16位");
            return null;
        }
        byte[] raw = sKey.getBytes("utf-8");
        SecretKeySpec skeySpec = new SecretKeySpec(raw, "AES");
        Cipher cipher = Cipher.getInstance("AES/ECB/PKCS5Padding");//"算法/模式/補碼方式"
        cipher.init(Cipher.ENCRYPT_MODE, skeySpec);
        byte[] encrypted = cipher.doFinal(sSrc.getBytes("utf-8"));

        return new Base64().encodeToString(encrypted);//此處使用BASE64做轉碼功能,同時能起到2次加密的作用。
    }

    /**
     * 解密
     * @param sSrc 需要解密的字元串
     * @param sKey 此處使用AES-128-ECB加密模式,key需要為16位。
     * @return
     * @throws Exception
     */
    public static String Decrypt(String sSrc, String sKey) throws Exception {
        try {
            // 判斷Key是否正确
            if (sKey == null) {
                System.out.print("Key為空null");
                return null;
            }
            // 判斷Key是否為16位
            if (sKey.length() != 16) {
                System.out.print("Key長度不是16位");
                return null;
            }
            byte[] raw = sKey.getBytes("utf-8");
            SecretKeySpec skeySpec = new SecretKeySpec(raw, "AES");
            Cipher cipher = Cipher.getInstance("AES/ECB/PKCS5Padding");
            cipher.init(Cipher.DECRYPT_MODE, skeySpec);
            byte[] encrypted1 = new Base64().decode(sSrc);//先用base64解密
            try {
                byte[] original = cipher.doFinal(encrypted1);
                String originalString = new String(original,"utf-8");
                return originalString;
            } catch (Exception e) {
                System.out.println(e.toString());
                return null;
            }
        } catch (Exception ex) {
            System.out.println(ex.toString());
            return null;
        }
    }

    public static void main(String[] args) throws Exception {
        /*
         * 此處使用AES-128-ECB加密模式,key需要為16位。
         */
        String cKey = "1234567890123456";
        // 需要加密的字串
        String cSrc = "test.888888";
        System.out.println(cSrc);
        // 加密
        String enString = AesUtil.Encrypt(cSrc, cKey);
        System.out.println("加密後的字串是:" + enString);

        // 解密
        String DeString = AesUtil.Decrypt(enString, cKey);
        System.out.println("解密後的字串是:" + DeString);
    }
}

           

至此,Java環境下, AES對稱加密的工具類, 包括加密和解密就介紹的差不多了,足以入門。

如文章有什麼問題請評論或私信部落客❤️❤️❤️。