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);
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧