MySQL和Java通用加密解密方式小结

 更新时间:2023年12月07日 11:22:14   作者:旷野历程  
这篇文章主要介绍了MySQL和Java通用加密解密方式,加密方式使用AES加密,在转成Base64,本文结合实例代码给大家介绍的非常详细,需要的朋友参考下吧

加密方式使用 AES 加密,再转成 Base64。

SQL

-- 加密
update your_table set your_column=to_base64(aes_encrypt(your_column, "password"));
-- 解密
select aes_decrypt(from_base64(your_column) ,"password") from your_table;

使用原生

public class AESUtils {
    /**
     * AES 加密操作
     *
     * @param data   待加密内容
     * @param aesKey 加密的Key
     * @return 返回Base64转码后的加密数据
     * @throws Exception
     */
    public static String encrpt(String encrptData, String aesKey) throws Exception {
        Cipher cipher = Cipher.getInstance("AES/ECB/PKCS5Padding");
        cipher.init(Cipher.ENCRYPT_MODE, getSecretKeySpec(aesKey));
        byte[] encrypted = cipher.doFinal(encrptData.getBytes());
        return Base64.encode(encrypted);
    }
    /**
     * AES 解密操作
     *
     * @param decrptData
     * @param aesKey
     * @return 返回解密内容
     * @throws Exception
     */
    public static String decrpt(String decrptData, String aesKey) throws Exception {
        Cipher cipher = Cipher.getInstance("AES/ECB/PKCS5Padding");
        cipher.init(Cipher.DECRYPT_MODE, getSecretKeySpec(aesKey));
        byte[] doFinal = cipher.doFinal(Base64.decode(decrptData));
        return new String(doFinal);
    }
    private static SecretKeySpec getSecretKeySpec(String key) {
        byte[] keyBytes = Arrays.copyOf(key.getBytes(), 16);
        return new SecretKeySpec(keyBytes, "AES");
    }
    public static void main(String[] args) throws Exception {
        String aesKey = "1234567890";
        String encrpt = encrpt("128931739@163.com", aesKey);
        System.out.println(encrpt);
        System.out.println(decrpt(encrpt, aesKey)); //解密 加密的数据
    }
}

使用 Hutool

public class AESUtils {
    /**
     * AES 加密操作
     *
     * @param encodedData 待加密内容
     * @param aesKey      加密的Key
     * @return 返回Base64转码后的加密数据
     * @throws Exception
     */
    public static String encrpt(String encodedData, String aesKey) {
        return Base64.encode(SecureUtil.aes(getSecretKey(aesKey)).encrypt(encodedData));
    }
    /**
     * AES 解密操作
     *
     * @param decrptData 待解密内容
     * @param aesKey     解密的Key
     * @return 返回解密内容
     * @throws Exception
     */
    public static String decrpt(String decrptData, String aesKey) {
        return SecureUtil.aes(getSecretKey(aesKey)).decryptStr(Base64.decode(decrptData));
    }
    private static byte[] getSecretKey(String key) {
        byte[] keyBytes = Arrays.copyOf(key.getBytes(), 16);
        return SecureUtil.generateKey("AES", keyBytes).getEncoded();
    }
    public static void main(String[] args) {
        String aesKey = "1234567890";
        String encrpt = encrpt("128931739@163.com", aesKey);
        System.out.println("-->加密后字符串: " + encrpt);
        System.out.println("-->解密后字符串: " + decrpt(encrpt, aesKey)); //解密 加密的数据
    }
}

到此这篇关于MySQL和Java通用加密解密方式的文章就介绍到这了,更多相关java mysql加密解密内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • spring security自定义认证登录的全过程记录

    spring security自定义认证登录的全过程记录

    这篇文章主要给大家介绍了关于spring security自定义认证登录的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧。
    2017-12-12
  • 讲解Java编程中finally语句的基本使用方法

    讲解Java编程中finally语句的基本使用方法

    这篇文章主要介绍了讲解Java编程中finally语句的基本使用方法,finally在异常处理中的使用时Java入门学习中的基础知识,需要的朋友可以参考下
    2015-11-11
  • springboot读取application.yaml文件数据的方法

    springboot读取application.yaml文件数据的方法

    这篇文章主要为大家详细介绍了springboot读取application.yaml文件数据的方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-07-07
  • java.io.UncheckedIOException: Cannot delete C:\Users\guo\AppData\Local\Temp\tomcat.8081问题

    java.io.UncheckedIOException: Cannot delete C

    本文主要介绍了java.io.UncheckedIOException: Cannot delete C:\Users\guo\AppData\Local\Temp\tomcat.8081问题,具有一定的参考价值,感兴趣的可以了解一下
    2024-05-05
  • Java如何跳出当前的多重嵌套循环的问题

    Java如何跳出当前的多重嵌套循环的问题

    Java中的循环结构包括for循环、while循环、do-while循环和增强型for循环,每种循环都有其适用场景,在循环中,break、continue和return分别用于跳出循环、跳过当前循环和结束当前方法,对于多重嵌套循环
    2025-01-01
  • Spring Boot常见外部配置文件方式详析

    Spring Boot常见外部配置文件方式详析

    这篇文章主要给大家介绍了关于Spring Boot常见外部配置文件方式的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者使用Spring Boot具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2020-07-07
  • 浅析JVM的垃圾回收器

    浅析JVM的垃圾回收器

    这篇文章主要介绍了JVM垃圾回收器的相关资料,帮助大家更好的理解和学习Java虚拟机的相关知识,感兴趣的朋友可以了解下
    2020-11-11
  • 别在Java代码里乱打日志了,这才是正确的打日志姿势

    别在Java代码里乱打日志了,这才是正确的打日志姿势

    这篇文章主要介绍了别在Java代码里乱打日志了,这才是正确的打日志姿势,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-06-06
  • Java使用ByteArrayOutputStream 和 ByteArrayInputStream 避免重复读取配置文件的方法

    Java使用ByteArrayOutputStream 和 ByteArrayInputStream 避免重复读取配置文

    这篇文章主要介绍了Java使用ByteArrayOutputStream 和 ByteArrayInputStream 避免重复读取配置文件的方法,需要的朋友可以参考下
    2015-12-12
  • springboot整合mqtt的详细图文教程

    springboot整合mqtt的详细图文教程

    MQTT是一种基于发布/订阅(publish/subscribe)模式的“轻量级”通讯协议,该协议构建于TCP/IP协议上,由IBM在1999年发布,下面这篇文章主要给大家介绍了关于springboot整合mqtt的详细图文教程,需要的朋友可以参考下
    2023-02-02

最新评论