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加密解密内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • MyBatis Generator使用小结

    MyBatis Generator使用小结

    本文主要介绍了MyBatis Generator使用小结,它能够根据数据库表,自动生成java实体类、dao层接口及mapper.xml文件,具有一定的参考价值,感兴趣的可以了解一下
    2023-11-11
  • Java封装数组之动态数组实现方法详解

    Java封装数组之动态数组实现方法详解

    这篇文章主要介绍了Java封装数组之动态数组实现方法,结合实例形式详细分析了java动态数组的实现原理、操作步骤与相关注意事项,需要的朋友可以参考下
    2020-03-03
  • JAVA如何按字节截取字符串

    JAVA如何按字节截取字符串

    这篇文章主要介绍了JAVA如何按字节截取字符串,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-01-01
  • java开发时各类工具的使用规范

    java开发时各类工具的使用规范

    这篇文章主要介绍了java编码时各类工具的使用规范,多人协作、共同开发一个项目,如果没有统一的代码规范的话,项目中的每个人都按照自己的习惯率性而为,就会导致整个项目的代码看上去杂乱无章,可读性非常差,并且持续增加后续的维护成本。对此感兴趣可以来了解一下
    2020-07-07
  • SpringBoot接收参数的8种方式示例详解

    SpringBoot接收参数的8种方式示例详解

    这篇文章主要介绍了SpringBoot接收参数的8种方式,本文通过示例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-08-08
  • Java利用Socket和IO流实现文件的上传与下载

    Java利用Socket和IO流实现文件的上传与下载

    本文主要介绍了Java利用Socket和IO流实现文件的上传与下载,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-04-04
  • Spring MVC利用Swagger2如何构建动态RESTful API详解

    Spring MVC利用Swagger2如何构建动态RESTful API详解

    这篇文章主要给大家介绍了关于在Spring MVC中利用Swagger2如何构建动态RESTful API的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧。
    2017-10-10
  • Java Web用户登录实例代码

    Java Web用户登录实例代码

    这篇文章主要介绍了Java Web用户登录实例代码的相关资料,非常不错具有参考借鉴价值,感兴趣的朋友一起看看吧
    2016-05-05
  • Spring boot 应用实现动态刷新配置详解

    Spring boot 应用实现动态刷新配置详解

    这篇文章主要介绍了spring boot 配置动态刷新实现详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2021-09-09
  • Spring Boot 中的任务执行器基本概念及使用方法

    Spring Boot 中的任务执行器基本概念及使用方法

    务执行器是 Spring Boot 中的一个非常实用的模块,它可以简化异步任务的开发和管理,在本文中,我们介绍了任务执行器的基本概念和使用方法,以及一个完整的示例代码,需要的朋友可以参考下
    2023-07-07

最新评论