AES工具类的实现

2 篇文章 0 订阅
1 篇文章 0 订阅

AES简介:

AES是一种对称加密算法,用来替代原先的DES加密算法。

  • 对称加密算法

对称加密算法是应用较早的加密算法,技术成熟。加密和解密用到的密钥是相同的,这种加密方式加密速度非常快,适合经常发送数据的场合。缺点是密钥的传输比较麻烦。常见的对称加密算法有:AES算法,DES算法,3DES算法等等。

  • 非对称加密算法

非对称加密算法的加密和解密用的密钥是不同的,这种加密方式是用数学上的难解问题构造的,通常加密解密的速度比较慢,适合偶尔发送数据的场合。优点是密钥传输方便。常见的非对称加密算法有:RSA算法、ECC算法和EIGamal算法。

实际中,一般是通过RSA加密AES的密钥,传输到接收方,接收方解密得到AES密钥,然后发送方和接收方用AES密钥来通信。
 

AES工具类的实现:


import javax.crypto.Cipher;
import javax.crypto.spec.IvParameterSpec;
import javax.crypto.spec.SecretKeySpec;
import org.apache.commons.net.util.Base64;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;


/**
 * AES工具类
 *
 *   因为某些国家的进口管制限制,Java发布的运行环境包中的加解密有一定的限制。比如默认不允许256位密钥的AES加解密,解决方法就是修改策略文件。
 *   替换的文件:%JDK_HOME%\jre\lib\security\local_policy.jar
 * 参考: http://czj4451.iteye.com/blog/1986483
 */
public class AESUtil {
    private static Logger log = LoggerFactory.getLogger(AESUtil.class);

    // 密钥
    public static String key = "AD42F6697B035B7580E4FEF93BE20BAD"; //长度必须为16、24、32位,即128bit、192bit、256bit
    private static String charset = "utf-8";
    // 偏移量
    private static int offset = 16;
    private static String transformation = "AES/CBC/PKCS5Padding";
    private static String algorithm = "AES";

    /**
     * 加密
     *
     * @param content
     * @return
     */
    public static String encrypt(String content) {
        return encrypt(content, key);
    }

    /**
     * 解密
     *
     * @param content
     * @return
     */
    public static String decrypt(String content) {
        return decrypt(content, key);
    }

    /**
     * 加密
     *
     * @param content 需要加密的内容
     * @param key 加密密码
     * @return
     */
    public static String encrypt(String content, String key) {
        try {
            SecretKeySpec skey = new SecretKeySpec(key.getBytes(), algorithm);
            IvParameterSpec iv = new IvParameterSpec(key.getBytes(), 0, offset);
            Cipher cipher = Cipher.getInstance(transformation);
            byte[] byteContent = content.getBytes(charset);
            cipher.init(Cipher.ENCRYPT_MODE, skey, iv);// 初始化
            byte[] result = cipher.doFinal(byteContent);
            return new Base64().encodeToString(result); // 加密
        } catch (Exception e) {
            log.error("Encryption failed!");
            e.printStackTrace();
        }
        return null;
    }

    /**
     * AES(256)解密
     *
     * @param content 待解密内容
     * @param key 解密密钥
     * @return 解密之后
     * @throws Exception
     */
    public static String decrypt(String content, String key) {
        try {

            SecretKeySpec skey = new SecretKeySpec(key.getBytes(), algorithm);
            IvParameterSpec iv = new IvParameterSpec(key.getBytes(), 0, offset);
            Cipher cipher = Cipher.getInstance(transformation);
            cipher.init(Cipher.DECRYPT_MODE, skey, iv);// 初始化
            byte[] result = cipher.doFinal(new Base64().decode(content));
            return new String(result); // 解密
        } catch (Exception e) {
            log.error("Decryption failed!");
            e.printStackTrace();
        }
        return null;
    }
}

AES工具类的测试类:

import common.utils.AESUtil;
import org.junit.Test;

public class AESUtilTest {
    @Test
    public static void main(String[] args) {
        String s = "加密测试";
        // 加密  默认key
        System.out.println("加密前:" + s);
        String encryptResultStr1 = AESUtil.encrypt(s);
        System.out.println("加密后:" + encryptResultStr1);
        // 解密
        System.out.println("解密后:" + AESUtil.decrypt(encryptResultStr1));

        AESUtil.key = "1230485203699875";
        // 加密
        System.out.println("加密前:" + s);
        String encryptResultStr = AESUtil.encrypt(s);
        System.out.println("加密后:" + encryptResultStr);
        // 解密
        System.out.println("解密后:" + AESUtil.decrypt(encryptResultStr));

        System.out.println("---------------------------------------------");

        System.out.println("加密后:" + AESUtil.encrypt("test", AESUtil.key));
        System.out.println("解密后:" + AESUtil.decrypt(AESUtil.encrypt("test", AESUtil.key), AESUtil.key));

        System.out.println("32位密钥加密测试:" + AESUtil.encrypt("当我们把密钥定为大于128时(即192或256)时","01234567890123450123456789012345"));
        System.out.println("32位密钥解密测试:" + AESUtil.decrypt(AESUtil.encrypt("当我们把密钥定为大于128时(即192或256)时", "01234567890123450123456789012345"), "01234567890123450123456789012345"));

    }
}

 

github地址:

AESUtil.java:https://github.com/striner/javaCode/blob/master/utils/src/main/java/common/utils/AESUtil.java

AESUtilTest.java:https://github.com/striner/javaCode/blob/master/utils/src/test/java/utils/AESUtilTest.java

 

最后再附上AES加密算法的实现:https://blog.csdn.net/striner/article/details/85107921

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是使用Java实现AES加密的工具类: ``` import javax.crypto.Cipher; import javax.crypto.spec.IvParameterSpec; import javax.crypto.spec.SecretKeySpec; import java.security.MessageDigest; import java.util.Base64; public class AESUtils { public static final String AES_CBC_NOPADDING = "AES/CBC/NoPadding"; /** * AES加密 * * @param data 待加密数据 * @param key 密钥 * @param iv 偏移量 * @param mode 加密模式 * @param encoding 编码方式 * @return 加密后的数据 * @throws Exception */ public static String encrypt(String data, String key, String iv, String mode, String encoding) throws Exception { Cipher cipher = Cipher.getInstance(mode); int blockSize = cipher.getBlockSize(); byte[] dataBytes = data.getBytes(encoding); int plaintextLength = dataBytes.length; if (plaintextLength % blockSize != 0) { plaintextLength += blockSize - (plaintextLength % blockSize); } byte[] plaintext = new byte[plaintextLength]; System.arraycopy(dataBytes, 0, plaintext, 0, dataBytes.length); SecretKeySpec keyspec = new SecretKeySpec(key.getBytes(), "AES"); IvParameterSpec ivspec = new IvParameterSpec(iv.getBytes()); cipher.init(Cipher.ENCRYPT_MODE, keyspec, ivspec); byte[] encrypted = cipher.doFinal(plaintext); return Base64.getEncoder().encodeToString(encrypted); } /** * AES解密 * * @param data 待解密数据 * @param key 密钥 * @param iv 偏移量 * @param mode 加密模式 * @param encoding 编码方式 * @return 解密后的数据 * @throws Exception */ public static String decrypt(String data, String key, String iv, String mode, String encoding) throws Exception { Cipher cipher = Cipher.getInstance(mode); SecretKeySpec keyspec = new SecretKeySpec(key.getBytes(), "AES"); IvParameterSpec ivspec = new IvParameterSpec(iv.getBytes()); cipher.init(Cipher.DECRYPT_MODE, keyspec, ivspec); byte[] encrypted = Base64.getDecoder().decode(data); byte[] original = cipher.doFinal(encrypted); return new String(original, encoding); } /** * 生成AES密钥 * * @param length 密钥长度 * @return 密钥 * @throws Exception */ public static String generateAESKey(int length) throws Exception { MessageDigest md = MessageDigest.getInstance("SHA-256"); byte[] keyBytes = md.digest("my-secret-key".getBytes("UTF-8")); byte[] truncatedKey = new byte[length]; System.arraycopy(keyBytes, 0, truncatedKey, 0, length); return Base64.getEncoder().encodeToString(truncatedKey); } } ``` 使用示例: ``` public static void main(String[] args) throws Exception { String data = "Hello, world!"; String key = AESUtils.generateAESKey(16); // 生成16位密钥 String iv = "1234567890123456"; // 偏移量 String mode = AESUtils.AES_CBC_NOPADDING; // 加密模式 String encoding = "UTF-8"; // 编码方式 String encrypted = AESUtils.encrypt(data, key, iv, mode, encoding); System.out.println("加密后的数据:" + encrypted); String decrypted = AESUtils.decrypt(encrypted, key, iv, mode, encoding); System.out.println("解密后的数据:" + decrypted); } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值