我的编程空间,编程开发者的网络收藏夹
学习永远不晚

JAVA实现AES加密,解密

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

JAVA实现AES加密,解密

java提供了加解密工具,可以将字节转成加密字节.
因此在加解密前需要对内容进行转换.
一般情况我们希望以字符串的形式展示加密串
可以将byte[] 转换为base64字符串 也可以转换为16进制字符串
这里提供两个工具类
加密串为base64字符串
可以直接在数据库中进行解密,无需查到后再遍历解密

public class AESUtil {    // 加密    public static String Encrypt(String sclass="lazy" data-src, String sKey) throws Exception {        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.ENCRYPT_MODE, skeySpec);        byte[] encrypted = cipher.doFinal(sclass="lazy" data-src.getBytes("utf-8"));        return new BASE64Encoder().encode(encrypted);//此处使用BASE64做转码功能,同时能起到2次加密的作用。    }    // 解密    public static String Decrypt(String sclass="lazy" data-src, 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 BASE64Decoder().decodeBuffer(sclass="lazy" data-src);//先用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 {                String cKey = "jkl;POIU1234++==";        // 需要加密的字串        String cclass="lazy" data-src = "www.gowhere.so";        System.out.println(cclass="lazy" data-src);        // 加密        String enString = MyAESUtil.Encrypt(cclass="lazy" data-src, cKey);        System.out.println("加密后的字串是:" + enString);        // 解密        String DeString = MyAESUtil.Decrypt(enString, cKey);        System.out.println("解密后的字串是:" + DeString);    }}

加密串为16进制字符串

import org.slf4j.Logger;import org.slf4j.LoggerFactory;import javax.crypto.Cipher;import javax.crypto.spec.SecretKeySpec;public class MyAESUtil {    private static final Logger logger = LoggerFactory.getLogger(MyAESUtil.class);        public static String Encrypt(String sclass="lazy" data-src, String sKey) throws Exception {        if (sKey == null) {            logger.error("Key为空null");            return null;        }        // 判断Key是否为16位        if (sKey.length() != 16) {            logger.error("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(sclass="lazy" data-src.getBytes("utf-8"));        return encodeHexString(encrypted);    }        public static String encodeHexString(byte[] byteArray) {        StringBuffer hexStringBuffer = new StringBuffer();        for (int i = 0; i < byteArray.length; i++) {            hexStringBuffer.append(byteToHex(byteArray[i]));        }        return hexStringBuffer.toString();    }        public static String byteToHex(byte num) {        char[] hexDigits = new char[2];        hexDigits[0] = Character.forDigit((num >> 4) & 0xF, 16);        hexDigits[1] = Character.forDigit((num & 0xF), 16);        return new String(hexDigits);    }        public static String Decrypt(String sclass="lazy" data-src, String sKey)  {        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 =  parseHexStr2Byte(sclass="lazy" data-src); //new BASE64Decoder().decodeBuffer(sclass="lazy" data-src);//先用base64解密            try {                byte[] original = cipher.doFinal(encrypted1);                String originalString = new String(original,"utf-8");                return originalString;            } catch (Exception e) {                logger.error(e.toString());                return null;            }        } catch (Exception ex) {            logger.error(ex.toString());            return null;        }    }        public static byte[] parseHexStr2Byte(String hexStr) {        if (hexStr.length() < 1)            return null;        byte[] result = new byte[hexStr.length()/2];        for (int i = 0;i< hexStr.length()/2; i++) {            int high = Integer.parseInt(hexStr.substring(i*2, i*2+1), 16);            int low = Integer.parseInt(hexStr.substring(i*2+1, i*2+2), 16);            result[i] = (byte) (high * 16 + low);        }        return result;    }    // 测试    public static void main(String[] args)  {        try {            String key = "8ISIwyJodASysWTM";            String encrypt = MyAESUtil.Encrypt("123456", key); // 加密            System.out.println(encrypt);            String decrypt = MyAESUtil.Decrypt(encrypt, key); // 解密            System.out.println(decrypt);        }catch (Exception e){            e.printStackTrace();        }    }}

参考文章:https://blog.csdn.net/fuhanghang/article/details/124010261

来源地址:https://blog.csdn.net/Passer_hua/article/details/128827608

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

JAVA实现AES加密,解密

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

JAVA实现AES加密,解密

java提供了加解密工具,可以将字节转成加密字节. 因此在加解密前需要对内容进行转换. 一般情况我们希望以字符串的形式展示加密串 可以将byte[] 转换为base64字符串 也可以转换为16进制字符串 这里提供两个工具类 加密串为base
2023-08-24

Java实现加密(一)AES加解密

目录 1.背景知识2.AES简介3.AES的加密过程(AES处理单位:字节)4.Java实现4.1 生成密钥和偏移量4.2 AESUtil.java 源码4.3 执行结果4.4 线上验证 1.背景知识 在密码学中,加
2023-08-18

使用Java实现加密之AES加解密

这篇文章主要介绍了使用Java实现加密之AES加解密,AES为最常见的对称加密算法,对称加密算法也就是加密和解密用相同的密钥,需要的朋友可以参考下
2023-05-18

jquery实现aes加密解密

随着互联网技术的发展,网络安全问题变得越来越突出。许多网站都要求用户输入敏感信息,如密码等。这些信息往往需要进行加密处理,以保证安全性。AES(Advanced Encryption Standard)是一种流行的加密算法,具有高效、安全、可靠的特点。在前端开发中,使用jQuery实现AES加密和解密是一种常用的方法。一、AES加密和解密简介AES加密和解密是一种对称加密算法,
2023-05-24

Java AES加密解密的简单实现方法

废话不多说,直接上代码package com.mstf.aes; import java.io.UnsupportedEncodingException;import java.security.InvalidKeyException;im
2023-05-31

python3.6 实现AES加密---

前端日子写完的Python入库脚本,通过直接读取配置文件的内容(包含了数据库的ip,数据库的用户名,数据库的密码),因为配置文件中的数据库密码是明文显示的,所以不太安全,由此对其进行加密。编程环境Python3.6第三方库–pyCrypto
2023-01-31

Rust实现AES加解密详解

这篇文章主要为大家详细介绍了如何利用Rust语言实现AES加解密算法,文中的示例代码讲解详细,具有一定的借鉴价值,需要的可以了解一下
2022-11-13

PHP AES 加密解密

PHP 有一个使用 PHP 的 AES 方法加密和解密字符串的内置扩展。函数 openssl_encrypt() 用于加密字符串,openssl_decrypt() 用于解密字符串。在 PHP 中使用 Open SSL 函数加密和解密字符串
PHP AES 加密解密
2024-02-27

golang实现aes-cbc-256加密解密功能

这篇文章主要介绍了golang实现aes-cbc-256加密解密功能,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
2023-05-18

Java使用AES加密和解密的实例详解

Java使用AES加密和解密的实例详解前言:AES的基本要求是,采用对称分组密码体制,密钥长度的最少支持为128、192、256,分组长度128位,算法应易于各种硬件和软件实现。1998年NIST开始AES第一轮分析、测试和征集,共产生了1
2023-05-31

AES 加密解密示例(walker)

AES 简介密码学中的高级加密标准(Advanced Encryption Standard,AES),又称Rijndael加密法,是美国联邦政府采用的一种区块加密标准。这个标准用来替代原先的DES(Data Encryption Stan
2023-01-31

php怎么实现aes加密

在PHP中,可以利用“openssl_encrypt()”函数实现aes加密,只需要将参数中加密方法设置为“AES-128-ECB”即可,语法为“openssl_decrypt(加密明文,'AES-128-ECB',加密密钥,数据格式)”。
2018-04-30

php怎么实现aes加密

PHP中AES加密实现AES加密通过openssl_encrypt()函数实现,提供方便的加密功能。支持CBC、CFB、OFB和ECB模式,密钥长度可选128、192或256位。需考虑密钥安全、IV生成、填充模式和加密算法选择,以确保加密安全性。
php怎么实现aes加密
2024-04-26

编程热搜

目录