spring boot + mybaties-plus 数据库字段加解密

前言

数据库突然要求对某些字段进行加密,因此我们在进行查询时候需要对字段进行加解密,此时需要对字段进行处理,但是如果字段用的地方比较多的话,修改还是挺复杂的,这里只是给大家一个方法,不一定是最好的,但是比较方便。就是使用typeHandler


提示:以下是本篇文章正文内容,下面案例可供参考

一、typeHandler是什么?

TypeHandler被称作类型处理器,MyBatis在设置预处理语句(PreparedStatement)中的参数或从结果集中取出一个值时,都会用类型处理器将Java对象转化为数据库支持的类型或者将获取到数据库值以合适的方式转换成 Java类型。
mybatis提供了31个默认的类型处理器,它们都位于org.apache.ibatis.type包下,这些默认的处理器能够满足我们大部分场景的需求。
本文接下来首先介绍TypeHandler接口的定义,之后介绍其在mybatis中如何使用,最后介绍一些mybatis如何注册TypeHandler。

 

二、使用步骤

1.引入库

代码如下(示例):

   implementation 'org.springframework.boot:spring-boot-starter-data-redis'
    implementation 'org.springframework.boot:spring-boot-starter-web'
    implementation 'org.springframework.boot:spring-boot-starter-validation'
    implementation 'org.springframework.boot:spring-boot-starter-aop'

    implementation 'com.squareup.okhttp3:okhttp:4.10.0'
    implementation 'org.mybatis.spring.boot:mybatis-spring-boot-starter:2.2.2'
    implementation 'com.alibaba:druid-spring-boot-starter:1.2.11'
    implementation 'com.alibaba:druid:1.1.10'
    runtimeOnly 'mysql:mysql-connector-java'
    annotationProcessor 'org.springframework.boot:spring-boot-configuration-processor'
    testImplementation 'org.springframework.boot:spring-boot-starter-test'
    annotationProcessor 'org.projectlombok:lombok:1.18.10'
    compileOnly 'org.projectlombok:lombok:1.18.10'
    testAnnotationProcessor 'org.projectlombok:lombok:1.18.10'
    testCompileOnly 'org.projectlombok:lombok:1.18.10'

//Mybatis-plus(简称MP)依赖
    implementation group: 'com.baomidou', name: 'mybatis-plus-boot-starter', version: '3.5.1'
    implementation group: 'com.github.yulichang', name: 'mybatis-plus-join', version: '1.2.4'

2.读入数据

代码如下(示例):

加入如下配置

# mybatis-plus
mybatis-plus:
    mapper-locations: classpath:mapper/*.xml  # 如果您在Mapper中有自定义方法(XML中有自定义实现),需要进行该配置
    type-aliases-package: classpath:com.xx.xx.xx.entity
    type-handlers-package: com.xx.xx.xx.config

别名类在mybaties 的xml文件中使用比较方便 

package com.xx.xx.xx.entity;


import org.apache.ibatis.type.Alias;


@Alias("SecretField")
public class SecretField {
}

typeHandler 处理类

package com.xx.xx.xx.config;


import com.xx.xx.xx.entity.SecretField;
import com.xx.xx.xx.utils.Sm4Utils;
import java.sql.CallableStatement;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import lombok.extern.slf4j.Slf4j;
import org.apache.ibatis.type.BaseTypeHandler;
import org.apache.ibatis.type.JdbcType;
import org.apache.ibatis.type.MappedTypes;
import org.springframework.util.StringUtils;


@MappedTypes(SecretField.class)
@Slf4j
public class SecretFieldTypeHandler extends BaseTypeHandler<String> {

    @Override
    public void setNonNullParameter(PreparedStatement ps, int i, String parameter, JdbcType jdbcType) throws SQLException {
        try {
            if (StringUtils.hasText(parameter)) {

            }
        } catch (Exception e) {
            ps.setString(i, parameter);
        }
    }


    @Override
    public String getNullableResult(ResultSet rs, String columnName) throws SQLException {
        String columnValue = rs.getString(columnName);
        try {
            if (StringUtils.hasText(columnValue)) {

                columnValue = Sm4Utils.decrypt( "d79cb1dd2b91434791262fed48a8e863",  columnValue);
            }
        } catch (Exception e) {
        }
        return columnValue;
    }

    @Override
    public String getNullableResult(ResultSet rs, int columnIndex) throws SQLException{
        return null;
    }

    @Override
    public String getNullableResult(CallableStatement cs, int columnIndex) throws SQLException {
        return null;
    }
}

 下面是使用方式

@TableName(value = "FZLDDB.SURVEY_CASE", autoResultMap = true)
@Data
public class SurveyCase implements Serializable {

    private static final long serialVersionUID = 1L;

    @ApiModelProperty("用户姓名")
    @TableField(typeHandler = SecretFieldTypeHandler.class)
    private String userName;


    @ApiModelProperty("证件号")
    @TableField(typeHandler = SecretFieldTypeHandler.class)
    private String idCard;

}

这样就可以在需要解密的字段上进行操作了。

如果是xml文件写的sql,可以使用以下方法

 <resultMap id="resultMap " type="SurveyCase">
        <result column="user_name" property="userName"  javaType="SecretField"/>
    </resultMap>

<select id="xxx" resultMap ="resultMap">
        select *
        from 表名
        where user_name= #{userName,jdbcType=VARCHAR,javaType=SecretField}
     
    </select>

或者

    @Results(value = {
            @Result(property = "userName", column = "userName", javaType = String.class, typeHandler = SecretFieldTypeHandler.class)
    })
    SurveyCase detail(@Param("id") String id);


  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是基于 Spring BootMyBatis-Plus、Thymeleaf 和 Bootstrap 的留言板的实现步骤: 1. 创建 Spring Boot 项目 在 IDEA 中创建一个 Spring Boot 项目,选择 Web 和 Thymeleaf 作为依赖。 2. 添加 MyBatis-Plus 依赖 在 pom.xml 文件中添加 MyBatis-Plus 依赖: ```xml <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-boot-starter</artifactId> <version>3.4.0</version> </dependency> ``` 3. 创建留言板数据表 在 MySQL 中创建一个名为 message_board 的数据表,包含以下字段: ```sql CREATE TABLE `message_board` ( `id` bigint(20) NOT NULL AUTO_INCREMENT, `name` varchar(50) NOT NULL COMMENT '留言人姓名', `email` varchar(50) NOT NULL COMMENT '留言人邮箱', `content` varchar(255) NOT NULL COMMENT '留言内容', `create_time` datetime NOT NULL COMMENT '创建时间', PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='留言板'; ``` 4. 创建 MyBatis-Plus 实体类和 Mapper 使用 MyBatis-Plus 的代码生成器,生成 Message 实体类和 MessageMapper 接口。 5. 编写 Service 层 创建 MessageService 接口和 MessageServiceImpl 实现类,其中 MessageServiceImpl 实现类注入 MessageMapper,实现增删改查等方法。 6. 编写 Controller 层 创建 MessageController 类,其中注入 MessageService,实现留言板的展示、添加留言和删除留言等功能。 7. 编写 Thymeleaf 页面 在 templates 目录下创建 message.html 页面,使用 Thymeleaf 和 Bootstrap 实现留言板的展示和添加留言的表单。 8. 运行项目 使用 IDEA 运行项目,在浏览器中访问 http://localhost:8080/message 即可看到留言板页面。 以上就是基于 Spring BootMyBatis-Plus、Thymeleaf 和 Bootstrap 的留言板的实现步骤,你可以参考这些步骤来实现自己的留言板。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值