mybatis 拦截器--实现数据库数据脱敏
注解类 @CryptField — 可作用于类成员变量、方法、方法参数
@Documented
@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.FIELD, ElementType.PARAMETER, ElementType.METHOD})
public @interface CryptField {
String value() default "";
boolean encrypt() default true;
boolean decrypt() default true;
}
引入jar包
配置mybatis插件
xml
<!-- 配置SqlSessionFactory -->
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<!-- 数据源 -->
<property name="dataSource" ref="dataSource"/>
<property name="mapperLocations">
<array>
<value>classpath:mapper/*.xml</value>
</array>
</property>
<property name="plugins">
<array>
<bean id="cryptInterceptor" class="org.apache.ibatis.plugin.CryptInterceptor">
</bean>
</array>
</property>
</bean>
java config
@Bean(name = "sqlSessionFactory")
public SqlSessionFactory sqlSessionFactory() throws Exception {
SqlSessionFactoryBean factoryBean = new SqlSessionFactoryBean();
PathMatchingResourcePatternResolver resolver = new PathMatchingResourcePatternResolver();
factoryBean.setMapperLocations(resolver.getResources("classpath:/mapper/*.xml"));
factoryBean.setDataSource(dataSource);
List<Interceptor> interceptors = Lists.newArrayList();
CryptInterceptor cryptInterceptor = new CryptInterceptor();
interceptors.add(cryptInterceptor);
factoryBean.setPlugins(interceptors.toArray(new Interceptor[interceptors.size()]));
return factoryBean.getObject();
}
注解使用场景
表示返回值需要解密,适用对象包括String、List<String>、JavaBean、List<JavaBean>
@CryptField
List<AppInfo> select(String aaa);
类成员变量
表示类成员需要加解密,具体看使用场景、适用对象包括String、List<String>
方法参数
表示方法参数需要加密,适用对象包括String、List<String>、JavaBean、List<JavaBean>