Java AES加密介绍以及工具类(ecb加密)

作者: lhlaishui 分类: 成长之路 发布时间: 2022-09-14 18:23

⚠️⚠️⚠️注意:
本文工具类针对的是Java环境下, AES对称加密的工具类, 包括加密和解密。

想直接看工具类代码的点击工具类代码

一、AES加密是什么?

简介

AES的全称是Advanced Encryption Standard(高级加密标准)
是最常见的对称加密算法。
大概的意思如下图:

在 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对称加密的工具类, 包括加密和解密就介绍的差不多了,足以入门。

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注