MyBatis自定义类型转换器实现加解密

需求场景:当数据库中保存的部分数据需要加密,页面需要正常显示时。这是就需要我们自定义类型转换器,在Mybatis执行SQL得到结果时,通过自定义类型转换器将CHAR或者VARCHAR2进行加解密处理,Java代码如下:

/**自定义typeHandler<br/>
* 1 插入数据库, 加密
* 2 查询,解密
* @author Administrator
*
*/
public class CryptTypeHandler implements TypeHandler<CryptType> {
public CryptType getResult(ResultSet rs, String columnName) throws SQLException {
String value="";
CryptType v=new CryptType(value);
value=rs.getString(columnName);
if(value!=null){
value=decrypt(value.toString());
v.setValue(value);
}
return v;
}
public CryptType getResult(ResultSet rs, int columnIndex) throws SQLException {
String value="";
CryptType v=new CryptType(value);
value =rs.getString(columnIndex);
if(value!=null){
v.setValue(value);
}
return v;
}
public CryptType getResult(CallableStatement cs, int columnIndex) throws SQLException {
String value="";
CryptType v=new CryptType();
value =cs.getString(columnIndex);
if(value!=null){
v.setValue(value);
}
return v;
}
public void setParameter(PreparedStatement ps, int i, CryptType parameter, JdbcType arg3) throws SQLException {
String value="";
if(parameter!=null && parameter.toString()!=null){
value=encrypt(parameter.toString());
}
ps.setString(i, value.toString());
}
/**插入数据库
* @param value
* @return
*/
private String encrypt(String value) {
value=CryptUtils.encrypt(value);
return value;
}
/** 从数据库读出
* @param value
* @return
*/
private String decrypt(String value){
value=CryptUtils.decrypt(value);
return value;
}
}

自定义类型

import java.io.Serializable;
/**
* 自定义类型
* 定义为该类型的实体属性会走CryptTypeHandler.java做加解密处理
*
* @author yy
*
*/
public class MyString implements Serializable, CharSequence, Comparable<String>{
private static final long serialVersionUID = 1L;
private String value;
public MyString (){
}
public CryptType(String value){
this.value=value;
}
public String getValue() {
return value;
}
public void setValue(String value) {
this.value = value;
}
public int compareTo(String arg0) {
// TODO Auto-generated method stub
return 0;
}
public char charAt(int arg0) {
// TODO Auto-generated method stub
return 0;
}
public int length() {
// TODO Auto-generated method stub
return 0;
}
public CharSequence subSequence(int arg0, int arg1) {
// TODO Auto-generated method stub
return null;
}
@Override
public String toString() {
return value;
}
} 

mybatis自定义类型配置

<!-- 自定义类型 -->
<typeHandlers>
<typeHandler javaType="com.***.MyString" handler="com.***.MyTypeHandler"/>
</typeHandlers>

实体中使用

public class LoanEnterprise{
private MyString name;
//注意:
//如果页面有查询条件也被加密时,mybatis sql中的条件判断会无法匹配,暂时的一种解决办法是在
public CryptType getName() {
if(name!=null && name.getValue().equals("")){
return null;
}else {
return name;
}
}
public void setName(CryptType name) {
this.name = name;
}
} 

以上所述是小编给大家介绍的MyBatis自定义类型转换器实现加解密,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对我们网站的支持!

(0)

相关推荐

  • Mybatis实现自定义类型转换器TypeHandler的方法

    先给大家简单介绍下mybatis MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及对结果集的检索封装.MyBatis可以使用简单的XML或注解用于配置和原始映射,将接口和Java的POJO(Plain Old Java Objects,普通的Java对象)映射成数据库中的记录. 此文其实是java操作Oracle类型XMLType总结二:使用Mybatis附带的一篇小结. Mybatis实现自定义的转换器,

  • MyBatis自定义类型转换器实现加解密

    需求场景:当数据库中保存的部分数据需要加密,页面需要正常显示时.这是就需要我们自定义类型转换器,在Mybatis执行SQL得到结果时,通过自定义类型转换器将CHAR或者VARCHAR2进行加解密处理,Java代码如下: /**自定义typeHandler<br/> * 1 插入数据库, 加密 * 2 查询,解密 * @author Administrator * */ public class CryptTypeHandler implements TypeHandler<CryptTy

  • Mybatis自定义类型转换器的使用技巧

    一般情况下,mybatis自带的类型转换器已经足够用了,但是需求永无止境,自定义类型转换器还是学一下吧,指不定哪天会用上. 举个没啥用的示例 javabean如下: public class User { private Integer id; private Message message; } public class Message { private Integer id; private String address; private String job; } 数据库User表如下:

  • mybatis自定义类型处理器TypehHandler示例详解

    前言 当大家使用mybatis作为持久层框架时,在存储和查询数据时,只需要在mapper.xml文件中配置好对应字段的JdbcType和JavaType,mybatis就可以帮我们转化对应的类型.这背后是有mybatis内置的类型转换器做转换(可见源码TypeHandlerRegistry).但是有时候,我们会对某些字段做特殊处理,比如加密和解密.状态转换.类型转换等.这个时候我们需要自定义类型转换器. 类架构 从上面的图中可以看出MyBatis中整个类型处理器实现架构,TypeHandler接

  • 使用webservice自定义注解处理参数加解密问题

    目录 webservice自定义注解处理参数加解密 代码实现 webservice注解汇总 @WebService @WebMethod @Oneway @WebParam @WebResult @HandlerChain webservice自定义注解处理参数加解密 前一段项目中用到了webservice,正好自己之前也了解过一点apache的cxf框架,所以就采用了cxf来实现webservice服务端,本身实现并没技术难点,但是项目为了保证安全性,采用了传输加密的过程,所以大部分请求参数需

  • springmvc实现自定义类型转换器示例

    springmvc除了自带的部分类型转换之外,还可以自定义类型转换器,按照以下步骤: 1.写一个类实现Converter接口 package com.hy.springmvc.entities; import org.springframework.core.convert.converter.Converter; import com.google.gson.Gson; public class DepartmentConvertor implements Converter<String,

  • SpringMVC实现自定义类型转换器

    我们在使用SpringMVC时,常常需要把表单中的参数映射到我们对象的属性中,我们可以在默认的spring-servlet.xml加上如下的配置即可做到普通数据类型的转换,如将String转换成Integer和Double等: <mvc:annotation-driven /> 或 复制代码 代码如下: <bean id="conversionService" class="org.springframework.format.support.Formatt

  • Struts2学习教程之自定义类型转换器的方法

    前言 为什么要在struts2中类型转换器? :struts2 只能够对java中的8种原态类型以及String.Date等常用类型提供自动转换. 但是这绝对不能满足我们的需求,如果我们想将页面的数据整合成一个javabean.到Action中去时Action得到的是一个对象,那么这个需求就需要我们使用类型转换器. 大部分时候,使用Struts2框架提供的内建的类型转换器和基于OGNL的类型转换器,就能满足大部分的类型转换需求:但是也存在一些特殊的情况下,可能需要将一个指定格式的字符串转换成一个

  • SpringMVC自定义类型转换器实现解析

    这篇文章主要介绍了SpringMVC自定义类型转换器实现解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 页面录入的字符串:2019/12/05可以映射到实体的日期属性上,但是如果是录入2019-12-05就会报错400 bad request,想要以2019-12-05日期格式的方式映射到实体的日期属性上,需要自定义类型转换器,主要步骤如下: 1. 自定义类实现Convertro<S,T>接口 2.Springmvc.xml中配置Conv

  • Springmvc自定义类型转换器实现步骤

    一.什么是springmvc类型转换器? 在我们的ssm框架中,前端传递过来的参数都是字符串,在controller层接收参数的时候springmvc能够帮我们将大部分字符串类型的参数自动转换为我们指定的参数,这就是springmvc为我们提供的类型转换器.但是springmvc提供的类型转换器只能够转换指定格式的参数,例如:我们参数中传递time=2020/08/18,在controller中我们就可以通过Date类型的参数接收它,springmvc能够自动将该日期字符串转换为日期对象.但是如

随机推荐