java.security.*篇(3) AES加密解密demo

本文涉及的产品
密钥管理服务KMS,1000个密钥,100个凭据,1个月
简介: java.security.*篇(3) AES加密解密demo

Aes 是对称加密,所谓对称加密就是加密和解密均用同样的key即可,非对称加密解密参考《java.security.*篇(1) RSA加密解密

涉及类Cipher SecretKeySpec IvParameterSpec

试用场景

由于是对称机密,因此适合一些加密破解不是很核心的场景,

适用场景主要如下:

非核心机密内容的通信,比如服务端-客户端聊天通信

非核心机密文件加密,查看时解密

非核心机密数据库数据内容加密,查看时解密等等

ase 加密解密 详细demo 如下

<dependency>
    <groupId>commons-codec</groupId>
    <artifactId>commons-codec</artifactId>
    <version>1.11</version>
</dependency>
 //加密key 必须是16bytes长度
    private static final String AES_KEY = "aes-key-aes-key?";
    //cbc模式向量iv 必须是16bytes长度
    private static final String AES_IV = "abcdefg123456789";
 /**
     * @description: demos of jdk8 java.security Cipher SecretKeySpec IvParameterSpec
     * Aes 算法加密解密
     */
    @Test
    public void testAesEncryptAndDecrypt() throws Exception {
        String data = "你好世界";
        System.out.println("需要加密的字符串:"+data);
        String encryptData = encryptAes(data);
        System.out.println("aes 加密后的字符串为:"+encryptData);
        String decryptData = decryptAES(encryptData);
        System.out.println("aes 解密后的字符串为:"+decryptData);
    }

加密方法

/**
     * @description: aes 加密方法
     * @param data 传入待加密数据
     * @return 加密后的字符串
     * */
    public String encryptAes(String data) throws Exception {
        //创建密码器对象 并获取aes/cbc instance
        Cipher cipher = Cipher.getInstance("AES/CBC/NoPadding");
        //获取块大小
        int blockSize = cipher.getBlockSize();
        //获取要加密数据字节
        byte[] dataBytes = data.getBytes();
        //获取字节长度
        int plaintextLength = dataBytes.length;
        //判断数据字节长度是否是块大小倍数,不是的话补齐
        if (plaintextLength % blockSize != 0) {
            plaintextLength = plaintextLength + (blockSize - (plaintextLength % blockSize));
        }
        //初始化字节数组并将数据拷贝过去
        byte[] plaintext = new byte[plaintextLength];
        System.arraycopy(dataBytes, 0, plaintext, 0, dataBytes.length);
        //初始化aes eySpec
        SecretKeySpec keyspec = new SecretKeySpec(AES_KEY.getBytes(), "AES");
        //初始化iv 向量,可增加加密算法的强度,cbc模式必须
        IvParameterSpec ivspec = new IvParameterSpec(AES_IV.getBytes());
        //初始化cipher 并赋值为encrypt对象
        cipher.init(Cipher.ENCRYPT_MODE, keyspec, ivspec);
        //执行加密
        byte[] encrypted = cipher.doFinal(plaintext);
        //base64 转码加密数据
        return Base64.encodeUrlSafe(encrypted).trim();
    }

解密方法

/**
     * @description: aes 解密方法
     * @param data 传入加密后的数据
     * @return 解密后的字符串
     * */
    public String decryptAES(String data) throws Exception {
        //base 解码数据
        byte[] encrypted1 = Base64.decode(data);
        //初始化密码器并获取aes/cbc 模式对象
        Cipher cipher = Cipher.getInstance("AES/CBC/NoPadding");
        //获取aes KeySpec
        SecretKeySpec keyspec = new SecretKeySpec(AES_KEY.getBytes(), "AES");
        //初始化iv 向量,可增加加密算法的强度,cbc模式必须
        IvParameterSpec ivspec = new IvParameterSpec(AES_IV.getBytes());
        //初始化cipher 对象为decrpt 模式
        cipher.init(Cipher.DECRYPT_MODE, keyspec, ivspec);
        //执行解码
        byte[] original = cipher.doFinal(encrypted1);
        //转为字符串并返回
        String originalString = new String(original);
        return originalString.trim();
    }

输出结果


12dcfed67f994d3bbb14fb7c9108c0b6.png


目录
打赏
0
0
0
0
18
分享
相关文章
基于AES的遥感图像加密算法matlab仿真
本程序基于MATLAB 2022a实现,采用AES算法对遥感图像进行加密与解密。主要步骤包括:将彩色图像灰度化并重置大小为256×256像素,通过AES的字节替换、行移位、列混合及轮密钥加等操作完成加密,随后进行解密并验证图像质量(如PSNR值)。实验结果展示了原图、加密图和解密图,分析了图像直方图、相关性及熵的变化,确保加密安全性与解密后图像质量。该方法适用于保护遥感图像中的敏感信息,在军事、环境监测等领域具有重要应用价值。
打造安全防线!Python AES&RSA加密工具,黑客绕道走的秘籍
【9月更文挑战第9天】随着数字化时代的到来,信息安全问题日益凸显。本文将介绍如何使用Python结合AES与RSA两种加密算法,构建强大的加密工具。AES以其高效性和强安全性著称,适用于大量数据的快速加密;RSA作为非对称加密算法,在加密小量数据及实现数字签名方面表现卓越。通过整合两者,可以构建既安全又灵活的加密系统。首先,需要安装pycryptodome库。接着,实现AES加密与解密功能,最后利用RSA加密AES密钥,确保其安全传输。这种设计不仅提高了数据传输效率,还增强了密钥交换的安全性,为敏感数据提供坚实保护。
278 43
|
2月前
|
java语言后台管理ruoyi后台管理框架-登录提示“无效的会话,或者会话已过期,请重新登录。”-扩展知识数据库中密码加密的方法-问题如何解决-以及如何重置若依后台管理框架admin密码-优雅草卓伊凡
java语言后台管理ruoyi后台管理框架-登录提示“无效的会话,或者会话已过期,请重新登录。”-扩展知识数据库中密码加密的方法-问题如何解决-以及如何重置若依后台管理框架admin密码-优雅草卓伊凡
235 3
java语言后台管理ruoyi后台管理框架-登录提示“无效的会话,或者会话已过期,请重新登录。”-扩展知识数据库中密码加密的方法-问题如何解决-以及如何重置若依后台管理框架admin密码-优雅草卓伊凡
如何实现Java打包程序的加密代码混淆,避免被反编译?
【10月更文挑战第15天】如何实现Java打包程序的加密代码混淆,避免被反编译?
1098 2
数据库信息/密码加盐加密 —— Java代码手写+集成两种方式,手把手教学!保证能用!
本文提供了在数据库中对密码等敏感信息进行加盐加密的详细教程,包括手写MD5加密算法和使用Spring Security的BCryptPasswordEncoder进行加密,并强调了使用BCryptPasswordEncoder时需要注意的Spring Security配置问题。
352 0
数据库信息/密码加盐加密 —— Java代码手写+集成两种方式,手把手教学!保证能用!
安全升级!Python AES加密实战,为你的代码加上一层神秘保护罩
【9月更文挑战第12天】在软件开发中,数据安全至关重要。本文将深入探讨如何使用Python中的AES加密技术保护代码免受非法访问和篡改。AES(高级加密标准)因其高效性和灵活性,已成为全球最广泛使用的对称加密算法之一。通过实战演练,我们将展示如何利用pycryptodome库实现AES加密,包括生成密钥、初始化向量(IV)、加密和解密文本数据等步骤。此外,还将介绍密钥管理和IV随机性等安全注意事项。通过本文的学习,你将掌握使用AES加密保护敏感数据的方法,为代码增添坚实的安全屏障。
220 8
深度揭秘!Python加密技术的背后,AES与RSA如何守护你的数据安全
【9月更文挑战第10天】随着数字化时代的到来,数据安全成为企业和个人面临的重大挑战。Python 作为功能强大的编程语言,在数据加密领域扮演着重要角色。AES 和 RSA 是两种主流加密算法,分别以对称和非对称加密方式保障数据安全。AES(Advanced Encryption Standard)因其高效性和安全性,在数据加密中广泛应用;而 RSA 则利用公钥和私钥机制,在密钥交换和数字签名方面表现卓越。
116 3
双重防护,无懈可击!Python AES+RSA加密方案,构建最强数据安全堡垒
【9月更文挑战第11天】在数字时代,数据安全至关重要。AES与RSA加密技术相结合,构成了一道坚固防线。AES以其高效性保障数据加密,而RSA则确保密钥安全传输,二者相辅相成,提供双重保护。本文通过Python代码示例展示了这一加密方案的魅力,强调了其在实际应用中的重要性和安全性。使用HTTPS等安全协议传输加密密钥和密文,确保数据在数字世界中自由流通而无忧。
166 1

热门文章

最新文章

AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等