通过mybatis-plus进行数据库字段加解密方式

 更新时间:2026年01月09日 08:37:00   作者:ronshi  
文章主要介绍了在Java开发中,从编写处理程序(handler)到实现加解密工具(util),再到配置实体和字段,以及自定义MyBatis的mapper语句的全过程

1、编写handler

@MappedJdbcTypes(JdbcType.VARCHAR)
public class EncryptHandler extends BaseTypeHandler<String> {

    @Override
    public void setNonNullParameter(PreparedStatement preparedStatement, int i, String parameter, JdbcType jdbcType) throws SQLException {
        preparedStatement.setString(i, EncryptFieldUtil.encrypt(parameter));
    }

    @Override
    public String getNullableResult(ResultSet resultSet, String columnName) throws SQLException {
        return EncryptFieldUtil.decrypt(resultSet.getString(columnName));
    }

    @Override
    public String getNullableResult(ResultSet resultSet, int columnIndex) throws SQLException {
        return EncryptFieldUtil.decrypt(resultSet.getString(columnIndex));
    }

    @Override
    public String getNullableResult(CallableStatement callableStatement, int columnIndex) throws SQLException {
        return EncryptFieldUtil.decrypt(callableStatement.getString(columnIndex));
    }

}

2、编写加解密util

public class EncryptFieldUtil {
    /**
     * 数据库字段加密key
     */
    private static final byte[] KEY = "sdfdfsdfdfghhhss".getBytes(StandardCharsets.UTF_8);

    /**
     * 加密字段
     */
    public static String encrypt(String value) {
        if (StrUtil.isBlank(value)) {
            return value;
        }
        AES aes = SecureUtil.aes(KEY);
        return aes.encryptHex(value);
    }

    /**
     * 解密字段
     */
    public static String decrypt(String value) {
        if (null == value) {
            return null;
        }
        try {
            return SecureUtil.aes(KEY).decryptStr(value);
        } catch (CryptoException e) {
            return value;
        }
    }

}

3、实体及字段配置

@TableName(value = "表名", autoResultMap = true)

@TableField(typeHandler = EncryptHandler.class)

4、自定义mapper语句

 <resultMap id="TitlePO" type="com.techhf.tenant.infrastruture.po.TitlePO">
       <result column="title_name" property="titleName" typeHandler="com.techhf.common.mybatis.handler.EncryptHandler"/>
 </resultMap>

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Mybatis自定义插件Interceptor问题

    Mybatis自定义插件Interceptor问题

    这篇文章主要介绍了Mybatis自定义插件Interceptor问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-11-11
  • 微服务Nacos配置动态刷新方式(简易版)附配置

    微服务Nacos配置动态刷新方式(简易版)附配置

    这篇文章主要介绍了微服务Nacos配置动态刷新方式(简易版)附配置,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2025-05-05
  • 详解hbase与hive数据同步

    详解hbase与hive数据同步

    这篇文章主要介绍了详解hbase与hive数据同步的相关资料,需要的朋友可以参考下
    2017-09-09
  • java占位符替换五种方式小结

    java占位符替换五种方式小结

    我们经常会遇到需要替换字符串中的占位符的情况,本文主要介绍了java占位符替换五种方式小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2024-06-06
  • Java工作环境的配置与Eclipse的安装过程

    Java工作环境的配置与Eclipse的安装过程

    这篇文章主要介绍了Java工作环境的配置与Eclipse的安装过程,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-02-02
  • 反射机制:getDeclaredField和getField的区别说明

    反射机制:getDeclaredField和getField的区别说明

    这篇文章主要介绍了反射机制:getDeclaredField和getField的区别说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-06-06
  • Java中缓冲流的使用与性能提升(让文件操作更高效)

    Java中缓冲流的使用与性能提升(让文件操作更高效)

    本文通过实例代码介绍了Java中缓冲流的概念、工作原理和性能提升,并提供了字节缓冲流和字符缓冲流的使用示例,缓冲流通过在内存中创建缓冲区,减少实际的I/O操作次数,从而提升文件读写性能,结合实例代码给大家讲解的非常详细,感兴趣的朋友跟随小编一起看看吧
    2024-12-12
  • Java编程获取文件列表及子文件目录的方法(非递归)

    Java编程获取文件列表及子文件目录的方法(非递归)

    这篇文章主要介绍了Java编程获取文件列表及子文件目录的方法(非递归),具有一定参考价值,需要的朋友可以了解下。
    2017-10-10
  • 实例分析java中重载与重写的区别

    实例分析java中重载与重写的区别

    这篇文章主要介绍了实例分析java中重载与重写的区别,需要的朋友可以参考下
    2014-07-07
  • java学习之JasperReport踩坑

    java学习之JasperReport踩坑

    本篇文章介绍的是在JAVA学习中JasperReport遇到的坑以及解决办法,有需要的朋友参考下吧。
    2018-01-01

最新评论