AES算法工具類

 什麼是對稱加密算法?java

AES已經變成目前對稱加密中最流行算法之一;AES能夠使用12八、19二、和256位密鑰,而且用128位分組加密和解密數據。

 

 

 

對稱加密算法安全嗎?算法

看過間諜局的知友們必定知道電臺和密碼本的功能。潛伏裏面孫紅雷經過電臺收聽到一堆數字,而後拿出密碼本比對,找到數字對應的漢字,就明白上級傳達的指令。
而軍統的監聽臺沒有密碼本,只看到一堆沒有意義的數字,這就是對稱算法的原理。

 

 

有哪些應用?apache

AES是對稱加密算法,包含三種密鑰長度(12八、19二、256),目前都是安全的,商業用途使用AES 128目前是足夠的,AES 256更好。
AES主要的業務場景是對內容進行加密,效率高。

 

 

AES對稱加密工具類:tomcat

package com.bootdo.common.demo;

import java.security.NoSuchAlgorithmException;
import java.security.SecureRandom;
import java.util.logging.Level;
import java.util.logging.Logger;

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

import org.apache.tomcat.util.codec.binary.Base64;

public class AESUtil {
    private static final String KEY_ALGORITHM = "AES";
    private static final String DEFAULT_CIPHER_ALGORITHM = "AES/ECB/PKCS5Padding";//默認的加密算法

    /**
     * AES 加密操做
     *
     * @param content 待加密內容
     * @param password 加密密碼
     * @return 返回Base64轉碼後的加密數據
     */
    public static String encrypt(String content, String password) {
        try {
            Cipher cipher = Cipher.getInstance(DEFAULT_CIPHER_ALGORITHM);// 建立密碼器

            byte[] byteContent = content.getBytes("utf-8");

            cipher.init(Cipher.ENCRYPT_MODE, getSecretKey(password));// 初始化爲加密模式的密碼器

            byte[] result = cipher.doFinal(byteContent);// 加密

            return Base64.encodeBase64String(result);//經過Base64轉碼返回
        } catch (Exception ex) {
            Logger.getLogger(AESUtil.class.getName()).log(Level.SEVERE, null, ex);
        }

        return null;
    }

    /**
     * AES 解密操做
     *
     * @param content
     * @param password
     * @return
     */
    public static String decrypt(String content, String password) {

        try {
            //實例化
            Cipher cipher = Cipher.getInstance(DEFAULT_CIPHER_ALGORITHM);

            //使用密鑰初始化,設置爲解密模式
            cipher.init(Cipher.DECRYPT_MODE, getSecretKey(password));

            //執行操做
            byte[] result = cipher.doFinal(Base64.decodeBase64(content));

            return new String(result, "utf-8");
        } catch (Exception ex) {
            Logger.getLogger(AESUtil.class.getName()).log(Level.SEVERE, null, ex);
        }
        
        return null;
    }

    /**
     * 生成加密祕鑰
     *
     * @return
     */
    private static SecretKeySpec getSecretKey(final String password) {
        //返回生成指定算法密鑰生成器的 KeyGenerator 對象
        KeyGenerator kg = null;

        try {
            kg = KeyGenerator.getInstance(KEY_ALGORITHM);

            //AES 要求密鑰長度爲 128
            kg.init(128, new SecureRandom(password.getBytes()));

            //生成一個密鑰
            SecretKey secretKey = kg.generateKey();

            return new SecretKeySpec(secretKey.getEncoded(), KEY_ALGORITHM);// 轉換爲AES專用密鑰
        } catch (NoSuchAlgorithmException ex) {
            Logger.getLogger(AESUtil.class.getName()).log(Level.SEVERE, null, ex);
        }

        return null;
    }

    
    /**
     * 測試Main方法
     * 
     * @param args
     */
    public static void main(String[] args) {
        String s = "你好,我是伍卿,helloWorld";
        System.out.println("s:" + s);
        String s1 = AESUtil.encrypt(s, "1234");
        System.out.println("s1:" + s1);
        System.out.println("s2:"+AESUtil.decrypt(s1, "1234"));
        

    }

}

 

測試結果:安全

 

 

參考連接:dom

https://mp.weixin.qq.com/s?__biz=MzIxMjE5MTE1Nw==&mid=2653191686&idx=1&sn=bdfad27d53831d56a0072705b13c65ef&chksm=8c990cdcbbee85ca1eb9e3b89aba28ba4c01f2c729b35524f475cb2cdcf4fc09a2b6dc1df2c6&mpshare=1&scene=1&srcid=1017gN92w3EQwe8K4UwudEEN#rd工具

相關文章
相關標籤/搜索