java - AES アルゴリズムの暗号化と復号化

AES の簡単な紹介:

Advanced Encryption Standard(英語: Advanced Encryption Standard、略称: AES)は、ブロック暗号化の規格です。この標準は元の DES を置き換えるために使用され、多くの関係者によって分析され、世界中で広く使用されています。AES は 128、192、および 256 ビットのキーを使用でき、比較的安全な 128 ビット ブロックでデータを暗号化および復号化します。完璧な暗号化アルゴリズムは、徹底的な方法が使用されない限り、理論的には解読できません。鍵長が 128 ビットを超える暗号化データを網羅的な方法で解読することは非現実的であり、可能性があるのは理論上のみです。統計によると、世界最速のコンピュータを使用したとしても、128 ビットのキーを使い果たすには数十億年かかり、ましてや 256 ビットのキー長の AES アルゴリズムを解読するには数十億年かかります。

AES-128-ECB ツール:

import org.apache.commons.codec.binary.Base64;
import org.springframework.util.StringUtils;

import javax.crypto.*;
import javax.crypto.spec.SecretKeySpec;
import java.io.UnsupportedEncodingException;
import java.security.InvalidKeyException;
import java.security.NoSuchAlgorithmException;

/**
 * @Author :feiyang
 * @Date :Created in 5:37 PM 2018/11/28
 */
public class AesEcbUtil {

    /**
     * aes-128-ecb 密钥字节数
     */
    private static final int AES_KEY_LENGTH = 16;
    private static final String AES_KEY = "abcdefghijklmnop";

    /**
     * 加密
     * @param content
     * @return
     */
    public static String encrypt(String content){
        if (StringUtils.isEmpty(AES_KEY)){
            return null;
        }
        if (AES_KEY.length() != AES_KEY_LENGTH){
            return null;
        }
        try {
            byte[] raw =AES_KEY.getBytes("utf-8");
            SecretKeySpec secretKeySpec = new SecretKeySpec(raw, "AES");
            Cipher cipher = Cipher.getInstance("AES/ECB/PKCS5Padding");
            cipher.init(Cipher.ENCRYPT_MODE, secretKeySpec);
            byte[] encrypt = cipher.doFinal(content.getBytes("utf-8"));
            return new Base64().encodeToString(encrypt);
        } catch (UnsupportedEncodingException e) {
            e.printStackTrace();
        } catch (NoSuchPaddingException e) {
            e.printStackTrace();
        } catch (NoSuchAlgorithmException e) {
            e.printStackTrace();
        } catch (InvalidKeyException e) {
            e.printStackTrace();
        } catch (BadPaddingException e) {
            e.printStackTrace();
        } catch (IllegalBlockSizeException e) {
            e.printStackTrace();
        }
        return null;
    }

    /**
     * 解密
     * @param content
     * @return
     */
    public static String decrypt(String content){
        if (StringUtils.isEmpty(AES_KEY)){
            return null;
        }
        if (AES_KEY.length() != AES_KEY_LENGTH){
            return null;
        }
        try {
            byte[] raw = AES_KEY.getBytes();
            SecretKeySpec secretKeySpec = new SecretKeySpec(raw, "AES");
            Cipher cipher = Cipher.getInstance("AES/ECB/PKCS5Padding");
            cipher.init(Cipher.DECRYPT_MODE, secretKeySpec);
            byte[] decrypt = new Base64().decode(content);
            byte[] original = cipher.doFinal(decrypt);
            return new String(original, "utf-8");
        } catch (NoSuchAlgorithmException e) {
            e.printStackTrace();
        } catch (NoSuchPaddingException e) {
            e.printStackTrace();
        } catch (InvalidKeyException e) {
            e.printStackTrace();
        } catch (BadPaddingException e) {
            e.printStackTrace();
        } catch (IllegalBlockSizeException e) {
            e.printStackTrace();
        } catch (UnsupportedEncodingException e) {
            e.printStackTrace();
        }
        return null;
    }
}

おすすめ

転載: blog.csdn.net/qq_42133100/article/details/90242869