返回顶部
首页 > 资讯 > 后端开发 > JAVA >Java 实现 AES 加密和解密完整示例
  • 501
分享到

Java 实现 AES 加密和解密完整示例

javaaesAES加密解密 2023-09-09 12:09:14 501人浏览 泡泡鱼
摘要

1、简介 AES,全称为 Advanced Encryption Standard,是一种分组密码算法,用于保护敏感数据的传输和存储。AES 分为 128 位和 256 位两种密钥长度,可以对数据进行

1、简介

AES,全称为 Advanced Encryption Standard,是一种分组密码算法,用于保护敏感数据的传输和存储。AES 分为 128 位和 256 位两种密钥长度,可以对数据进行加密和解密,保证数据的安全性和完整性。AES 主要应用于电子商务、移动支付、网络安全等领域,被广泛运用于现代社会的各个方面。AES 算法被设计为高度安全,可以在理论上保证其分组密码的安全性。然而,由于其复杂性和密钥长度,AES 算法的实现和应用也具有一定的技术难度。因此,在应用 AES算法时,需要注意加强密钥管理和安全性保障。

这个标准用来替代原先的 DES(Data Encryption Standard),已经被多方分析且广为全世界所使用。

AES 算法具有很多优点,例如快速、安全、可靠等。它可以加密大量数据,而不会因为加密过程中的数据量过大而变得缓慢。此外,AES 算法还支持块大小的自动调整,可以处理不同大小的数据块。

2、AES 加密模式

2.1、加密方式

ECB(Electronic Codebook)模式:这种模式是将整个明文分成若干段相同的小段,然后对每一小段进行加密。加密时,使用一个密钥,将明文中的每个字符与密钥中对应位置的字符进行异或运算,得到密文。

CBC(Cipher Block Chaining)模式:这种模式是先将明文切分成若干小段,然后每一小段与初始块或者上一段的密文段进行异或运算后,再与密钥进行加密。加密时,使用一个密钥和一个初始化向量(IV),初始化向量是一个16字节的向量,包含了加密算法所需的所有信息。

CFB(Cipher Feedback)模式:这种模式是一种较为复杂的加密模式,它结合了CBC和CTR两种模式的优点。在CFB模式中,加密过程中使用一个密钥和一个随机生成的初始化向量(IV),然后对明文进行加密。在加密完成后,通过对明文进行非对称加密来生成密文的向量。随后,通过对密文进行反向操作,将密文的向量与明文的向量进行异或运算,得到解密所需的密钥。

需要注意的是,ECB、CBC、CFB等模式都是对称加密算法,加密和解密使用相同的密钥。在使用这些算法时,需要注意保护密钥的安全,避免被恶意获取。

2.2、安全性

ECB 不够安全,只适合于短数据的加密,而 CBC 和 CFB 相较于 ECB 更加安全,因为前一个密文块会影响当前明文块,使攻击者难以预测密文的结构。

2.3、速度

ECB 是最简单的加密方式,速度最快,但由于安全性差不建议使用,CBC 因为每个明文块都要与前一个密文块进行异或操作,比 ECB 要慢一些,CFB 因为需要反复加密和解密,速度可能会更慢。

总的来说,选择 AES 的算法模式需要根据加密需要的安全性和速度来进行选择,通常推荐使用CBC 或 CFB 模式,而不是 ECB 模式。

3、Java 实现完整示例

在 Java 中,可以使用 javax.crypto 包中的 Cipher 类来实现 AES 加密和解密。完整代码如下:

package com.csdn.woniu.example;import javax.crypto.Cipher;import javax.crypto.spec.IvParameterSpec;import javax.crypto.spec.SecreTKEySpec;import java.NIO.charset.StandardCharsets;import java.util.Base64;import java.util.Random;public class AESExample {        private static final String AES_ECB = "AES/ECB/PKCS5Padding";        private static final String AES_CBC = "AES/CBC/PKCS5Padding";        private static final String AES_CFB = "AES/CFB/PKCS5Padding";        private static final Integer IV_LENGTH = 16;        public static boolean isEmpty(Object str) {        return null == str || "".equals(str);    }        public static byte[] getBytes(String str){        if (isEmpty(str)) {            return null;        }        try {            return str.getBytes(StandardCharsets.UTF_8);        } catch (Exception e) {            throw new RuntimeException(e);        }    }        public static String getIV(){        String str = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789";        Random random = new Random();        StringBuffer sb = new StringBuffer();        for(int i = 0 ; i < IV_LENGTH ; i++){            int number = random.nextInt(str.length());            sb.append(str.charAt(number));        }        return sb.toString();    }        public static SecretKeySpec getSecretKeySpec(String key){        SecretKeySpec secretKeySpec = new SecretKeySpec(getBytes(key), "AES");        return secretKeySpec;    }        public static String encrypt(String text, String key){        if (isEmpty(text) || isEmpty(key)) {            return null;        }        try {            // 创建AES加密器            Cipher cipher = Cipher.getInstance(AES_ECB);            SecretKeySpec secretKeySpec = getSecretKeySpec(key);            cipher.init(Cipher.ENCRYPT_MODE, secretKeySpec);            // 加密字节数组            byte[] encryptedBytes = cipher.doFinal(getBytes(text));            // 将密文转换为 Base64 编码字符串            return Base64.getEncoder().encodeToString(encryptedBytes);        } catch (Exception e) {            throw new RuntimeException(e);        }    }        public static String decrypt(String text, String key){        if (isEmpty(text) || isEmpty(key)) {            return null;        }        // 将密文转换为16字节的字节数组        byte[] textBytes = Base64.getDecoder().decode(text);        try {            // 创建AES加密器            Cipher cipher = Cipher.getInstance(AES_ECB);            SecretKeySpec secretKeySpec = getSecretKeySpec(key);            cipher.init(Cipher.DECRYPT_MODE, secretKeySpec);            // 解密字节数组            byte[] decryptedBytes = cipher.doFinal(textBytes);            // 将明文转换为字符串            return new String(decryptedBytes, StandardCharsets.UTF_8);        } catch (Exception e) {            throw new RuntimeException(e);        }    }        public static String encrypt(String text, String key, String iv, String mode){        if (isEmpty(text) || isEmpty(key) || isEmpty(iv)) {            return null;        }        try {            // 创建AES加密器            Cipher cipher = Cipher.getInstance(mode);            SecretKeySpec secretKeySpec = getSecretKeySpec(key);            cipher.init(Cipher.ENCRYPT_MODE, secretKeySpec, new IvParameterSpec(getBytes(iv)));            // 加密字节数组            byte[] encryptedBytes = cipher.doFinal(getBytes(text));            // 将密文转换为 Base64 编码字符串            return Base64.getEncoder().encodeToString(encryptedBytes);        } catch (Exception e) {            throw new RuntimeException(e);        }    }        public static String decrypt(String text, String key, String iv, String mode){        if (isEmpty(text) || isEmpty(key) || isEmpty(iv)) {            return null;        }        // 将密文转换为16字节的字节数组        byte[] textBytes = Base64.getDecoder().decode(text);        try {            // 创建AES加密器            Cipher cipher = Cipher.getInstance(mode);            SecretKeySpec secretKeySpec = getSecretKeySpec(key);            cipher.init(Cipher.DECRYPT_MODE, secretKeySpec, new IvParameterSpec(getBytes(iv)));            // 解密字节数组            byte[] decryptedBytes = cipher.doFinal(textBytes);            // 将明文转换为字符串            return new String(decryptedBytes, StandardCharsets.UTF_8);        } catch (Exception e) {            throw new RuntimeException(e);        }    }    public static void main(String[] args) {        String text = "嗨,您好!";        String key  = "woniucsdnvip8888"; // 16字节的密钥        String iv  = getIV();        String encryptTextEBC = encrypt(text, key);        System.out.println("EBC 加密后内容:" + encryptTextEBC);        System.out.println("EBC 解密后内容:" + decrypt(encryptTextEBC, key));        System.out.println();        String encryptTextCBC = encrypt(text, key, iv, AES_CBC);        System.out.println("CBC 加密IV:" + iv);        System.out.println("CBC 加密后内容:" + encryptTextCBC);        System.out.println("CBC 解密后内容:" + decrypt(encryptTextCBC, key, iv, AES_CBC));        System.out.println();        String encryptTextCFB = encrypt(text, key, iv, AES_CFB);        System.out.println("CFB 加密IV:" + iv);        System.out.println("CFB 加密后内容:" + encryptTextCFB);        System.out.println("CFB 解密后内容:" + decrypt(encryptTextCFB, key, iv, AES_CFB));    }}

运行结果如下:

EBC 加密后内容:Nc6r9GCghANVXeAek8OQAg==EBC 解密后内容:嗨,您好!CBC 加密IV:sIVxRsEWgAHNNLYoCBC 加密后内容:515S8VG52TqbhUwB1T9DiA==CBC 解密后内容:嗨,您好!CFB 加密IV:sIVxRsEWgAHNNLYoCFB 加密后内容:C3MNkL3f4be9hwkrA0VsNg==CFB 解密后内容:嗨,您好!

本文教程到此结束,祝愿小伙伴们在编程之旅中能够愉快地探索、学习、成长!

来源地址:https://blog.csdn.net/u011374856/article/details/130635405

--结束END--

本文标题: Java 实现 AES 加密和解密完整示例

本文链接: https://lsjlt.com/news/401516.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Java 实现 AES 加密和解密完整示例
    1、简介 AES,全称为 Advanced Encryption Standard,是一种分组密码算法,用于保护敏感数据的传输和存储。AES 分为 128 位和 256 位两种密钥长度,可以对数据进行...
    99+
    2023-09-09
    java aes AES 加密 解密
  • 国密SM2: 加解密实现 java代码完整示例
    目录  具体Java代码SM2算法加解密实现Demo: pom依赖引入 :  国家密码管理局于2010年12月17日发布了SM2算法,并要求现有的基于RSA算法的电子认证系统、密钥管理系统、应用系统进升级改造,使用支持国密SM2算法的证...
    99+
    2023-08-31
    java 算法
  • JAVA实现AES加密,解密
    java提供了加解密工具,可以将字节转成加密字节. 因此在加解密前需要对内容进行转换. 一般情况我们希望以字符串的形式展示加密串 可以将byte[] 转换为base64字符串 也可以转换为16进制字符串 这里提供两个工具类 加密串为base...
    99+
    2023-08-24
    java 数据库 mysql
  • Golang实现AES加密和解密的示例代码
    目录对称加密 AES 算法加解密文件加密解密说明对称加密 AES 算法 (Advanced Encryption Standard ,AES) 优点 算法公开、计算量小、加密速度快、...
    99+
    2024-04-02
  • AES 加密解密示例(walker)
    AES 简介 密码学中的高级加密标准(Advanced Encryption Standard,AES),又称Rijndael加密法,是美国联邦政府采用的一种区块加密标准。这个标准用来替代原先的DES(Data Encryption St...
    99+
    2023-01-31
    示例 加密解密 AES
  • Java实现加密(一)AES加解密
    目录 1.背景知识2.AES简介3.AES的加密过程(AES处理单位:字节)4.Java实现4.1 生成密钥和偏移量4.2 AESUtil.java 源码4.3 执行结果4.4 线上验证 1.背景知识 在密码学中,加...
    99+
    2023-08-18
    java
  • Java使用AES加密和解密的实例详解
    Java使用AES加密和解密的实例详解前言:AES的基本要求是,采用对称分组密码体制,密钥长度的最少支持为128、192、256,分组长度128位,算法应易于各种硬件和软件实现。1998年NIST开始AES第一轮分析、测试和征集,共产生了1...
    99+
    2023-05-31
    java aes 加密
  • PHP AES加解密示例
    PHP 有两种方式调用AES加解密,一种是使用mcrypt库,示例如下: 还有一种是使用openssl,示例如下: 测试运行效果如下: sc7ubaY39/e3gxJCRqfn9jJWJkeH1pZHMlZW5/Cw==ecuyhasd...
    99+
    2023-09-14
    php android 开发语言
  • Java加密解密和数字签名完整代码示例
    常见的加密算法基本的单向加密算法:BASE64严格地说,属于编码格式,而非加密算法MD5(MessageDigestalgorithm5,信息摘要算法)SHA(SecureHashAlgorithm,安全散列算法)HMAC(HashMess...
    99+
    2023-05-30
    java 加密解密代码 数字签名
  • 使用Java实现加密之AES加解密
    目录1.背景知识2.AES简介3.AES的加密过程(AES处理单位:字节)4.Java实现4.1 生成密钥和偏移量4.2 AESUtil.java 源码4.3 执行结果4.4 线上验...
    99+
    2023-05-18
    Java AES AES 加解密
  • AES加密解密python实现
    1.前言         关于现代密码学算法,可以查看以下博客全面了解 CISSP考试要求里的“应用密码学”内容辅助记忆趣味串讲_晓翔仔的博客-CSDN博客         AES的细节知识,可以查阅 AES加密算法的详细介绍与实现_Tim...
    99+
    2023-09-20
    python 开发语言 密码学 非对称加密 AES
  • jquery实现aes加密解密
    随着互联网技术的发展,网络安全问题变得越来越突出。许多网站都要求用户输入敏感信息,如密码等。这些信息往往需要进行加密处理,以保证安全性。AES(Advanced Encryption Standard)是一种流行的加密算法,具有高效、安全、...
    99+
    2023-05-24
  • Java实现对称加密DES和AES的示例代码
    目录实验内容和要求参考代码实验内容和要求 采用Java实现采用对称密码算法的应用软件,所用算法包括DES算法和AES算法。要求该软件具有图形用户界面,能生成密钥,以及对字符串和文件进...
    99+
    2023-05-14
    Java实现对称加密DES AES Java对称加密DES AES Java对称加密 Java DES AES
  • java实现AES 32位加密解密的方案
    目录1、常用加密32位原因2、解决方案3、AES工具类1、常用加密32位原因 网上很多解密加密是16位的,用32位密钥加密会报java.security.InvalidKeyExc...
    99+
    2024-04-02
  • Java AES加密解密的简单实现方法
    废话不多说,直接上代码package com.mstf.aes; import java.io.UnsupportedEncodingException;import java.security.InvalidKeyException;im...
    99+
    2023-05-31
    java rsa 加密
  • python AES对称加密示例
    基本概念: 高级加密标准(英语:Advanced Encryption Standard,缩写:AES) 注意点: 1.字符集处理 2.秘钥的生成,建议按照某种规则产生,比如对用户id进行一定规则加工后,进行md5计算,再从中取出1...
    99+
    2023-01-31
    示例 对称 python
  • Python:实现密码加密解密(含完整源码)
    Python:实现密码加密解密(含完整源码) 密码加密是保护用户隐私的一种有效手段。本文将讲解如何使用Python编写一个简单的密码加密解密程序,并提供完整源代码。 步骤一:安装依赖库 我们需要使用到...
    99+
    2023-09-11
    python 开发语言
  • python3.6 实现AES加密---
    前端日子写完的Python入库脚本,通过直接读取配置文件的内容(包含了数据库的ip,数据库的用户名,数据库的密码),因为配置文件中的数据库密码是明文显示的,所以不太安全,由此对其进行加密。 编程环境 Python3.6 第三...
    99+
    2023-01-31
    AES
  • Java和PHP完美对接AES加解密,密钥处理要注意
    对于应用程序进行加密保护,AES算法被广泛使用。但是在使用Java和PHP进行AES加解密时,很多人都会遇到一些困难。本文就来介绍一下如何实现Java和PHP的完美对接AES加解密。 在进行AES加解密时,我们需要注意以下几个方面: 确定加...
    99+
    2023-08-31
    php java
  • android使用AES加密和解密文件实例代码
    前言最近公司需要对本公司的一些下载文件进行加密解密需求,也就尝试去实现下,其实需要借助第三方的jar包:bcprov-jdk15on-155.jar,下载这个可以到网上搜或者下载本人的demo即可,注意:需要加密和解密的key是一致的才可以...
    99+
    2023-05-31
    android aes 加密
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作