java中给手机号、身份证号等敏感信息脱敏
sql方式:
方法一:
以手机号示例:
ub:表别名 前三后四格式

REPLACE (ub.phone, SUBSTR( ub.phone, 4, 4 ), '****' ) AS phone,
方法二:
此方法不用固定数字长度格式
身份证号脱敏,前六后四格式;
pe:表别名

CONCAT(LEFT(pe.id_card,6), '****' ,RIGHT(pe.id_card,4)) AS id_card,
手机号脱敏,前三后四格式;

CONCAT(LEFT(ub.phone,3), '****' ,RIGHT(ub.phone,4)) AS phone
my batis puls方式:
先使用分页构造器查询出数据,然后循环去进行脱敏(适合数据量小的时候使用,当数据量大时查询速度较慢)
LambdaQueryWrapper<实体类> wrapper = new LambdaQueryWrapper<实体类>()
Page<实体类> page = usrPayItemService.page(new Page(req.getPage(), req.getPageSize()), wrapper);
PageRsp<实体类> pageRsp = new PageRsp<>(page.getRecords(), page.getTotal());
脱敏工具类:
package com.sports.core.utils;
public class EncryptionUtils {
/**
* 手机号码前三后四脱敏
* 脱敏规则:保留前三后四
*/
public static String mobileEncrypt(String mobile) {
if (StringUtils.isEmpty(mobile) || (mobile.length() != 11)) {
return mobile;
}
return mobile.replaceAll("(\\w{3})\\w*(\\w{4})", "$1****$2");
}
/**
* 功能描述:姓名脱敏
* 脱敏规则:只显示第一个汉字
*/
public static String nameEncrypt(String fullName) {
if (StringUtils.isNotBlank(fullName)) {
String name = StringUtils.left(fullName, 1);
return StringUtils.rightPad(name, StringUtils.length(fullName), "*");
}
return fullName;
}
/**
* 功能描述:身份证号脱敏
* 脱敏规则:保留前六后三
*/
public static String idNumberEncrypt(String idNumber) {
if (StringUtils.isNotBlank(idNumber)) {
return StringUtils.left(idNumber, 6).concat(StringUtils.removeStart(StringUtils.leftPad(StringUtils.right(idNumber, 3), StringUtils.length(idNumber), "*"), "******"));
}
return idNumber;
}
/**
* 功能描述:地址脱敏
* 脱敏规则:从第四位开始隐藏,隐藏至最后两位
*/
public static String addressEncrypt(String address) {
if (StringUtils.isNotBlank(address)) {
return StringUtils.left(address, 3).concat(StringUtils.removeStart(StringUtils.leftPad(StringUtils.right(address, address.length() - 11), StringUtils.length(address), "*"), "***"));
}
return address;
}
}
脱敏方法:
for (UsrBaseDO pageRecord : pageRecords) {
String encryptPhone = EncryptionUtils.mobileEncrypt(pageRecord.getPhone());
pageRecord.setPhone(encryptPhone);
}

浙公网安备 33010602011771号