信息脱敏:对某些敏感信息通过脱敏规则进行数据的变形,实现敏感隐私数据的可靠保护.
以下工具类是对字符、姓名、邮箱、手机、固定电话,银行卡号、地址、公司开户银行联号、身份证号进行脱敏处理。
1、脱敏工具类:
package cn.hsa.utils;
import cn.hutool.core.util.StrUtil;
import org.apache.commons.lang3.StringUtils;
/**
* 信息脱敏工具类
**/
public class DataMaskingUtils {
/**
* 字符脱敏.
*
* @param str the str
* @param pre the pre 前几位
* @param suf the suf 后几位
* @return the string
*/
public static String strMasking(String str, int pre, int suf) {
if (StrUtil.isBlank(str)) {
return str;
}
if (pre <= 0 && suf <= 0) {
return str;
}
int len = str.length();
if (len > (pre + suf)) {
return StrUtil.subPre(str, pre) +
StrUtil.fill("", '*', len - pre - suf, false) +
StrUtil.subSufByLength(str, suf);
} else if (len > pre && pre > 0) {
return StrUtil.subPre(str, pre) +
StrUtil.fill("", '*', len - pre, false);
} else if (len > suf && suf > 0) {
return StrUtil.fill("", '*', len - suf, false) +
StrUtil.subSufByLength(str, suf);
} else {
return StrUtil.fill("", '*', len, false);
}
}
/**
* [中文姓名] 只显示第一个汉字,其他隐藏为星号<例子:李**>
*
* @param fullName 姓名
* @return
*/
public static String chineseName(String fullName) {
if (StringUtils.isBlank(fullName)) {
return "";
}
String name = StringUtils.left(fullName, 1);
return StringUtils.rightPad(name, StringUtils.length(fullName), "*");
}
/**
* [中文姓名] 只显示姓氏,其他隐藏为星号<例子:欧阳娜娜 : 欧阳**>
*
* @param familyName 姓氏
* @param givenName 名字
* @return
*/
public static String chineseName(String familyName, String givenName) {
if (StringUtils.isBlank(familyName) || StringUtils.isBlank(givenName)) {
return "";
}
if (familyName.length() > 1) {
String name = StringUtils.left(familyName, familyName.length());
return StringUtils.rightPad(name, StringUtils.length(familyName + givenName), "*");
}
return chineseName(familyName + givenName);
}
/**
* [身份证号] 显示最后四位,其他隐藏。共计18位或者15位。<例子:*************5762>
*
* @param id
* @return
*/
public static String idCardNum(String id) {
if (StringUtils.isBlank(id)) {
return "";
}
String num = StringUtils.right(id, 4);
return StringUtils.leftPad(num, StringUtils.length(id), "*");
}
/**
* [身份证号] 前六位,后四位,其他用星号隐藏每位1个星号<例子:451002********1647>
*
* @param carId
* @return
*/
public static String idCard(String carId) {
if (StringUtils.isBlank(carId)) {
return "";
}
return StringUtils.left(carId, 6).concat(StringUtils.removeStart(StringUtils.leftPad(StringUtils.right(carId, 4), StringUtils.length(carId), "*"), "******"));
}
/**
* [固定电话] 后四位,其他隐藏<例子:****1234>
*
* @param num
* @return
*/
public static String fixedPhone(String num) {
if (StringUtils.isBlank(num)) {
return "";
}
return StringUtils.leftPad(StringUtils.right(num, 4), StringUtils.length(num), "*");
}
/**
* [手机号码] 前三位,后四位,其他隐藏<例子:138******1234>
*
* @param num
* @return
*/
public static String mobilePhone(String num) {
if (StringUtils.isBlank(num)) {
return "";
}
return StringUtils.left(num, 3).concat(StringUtils.removeStart(StringUtils.leftPad(StringUtils.right(num, 4), StringUtils.length(num), "*"), "***"));
}
/**
* [地址] 只显示到地区,不显示详细地址;我们要对个人信息增强保护<例子:北京市海淀区****>
*
* @param address
* @param sensitiveSize 敏感信息长度
* @return
*/
public static String address(String address, int sensitiveSize) {
if (StringUtils.isBlank(address)) {
return "";
}
int length = StringUtils.length(address);
return StringUtils.rightPad(StringUtils.left(address, length - sensitiveSize), length, "*");
}
/**
* [电子邮箱] 邮箱前缀仅显示第一个字母,前缀其他隐藏,用星号代替,@及后面的地址显示<例子:g**@163.com>
*
* @param email
* @return
*/
public static String email(String email) {
if (StringUtils.isBlank(email)) {
return "";
}
int index = StringUtils.indexOf(email, "@");
if (index <= 1) {
return email;
}
return StringUtils.rightPad(StringUtils.left(email, 1), index, "*").concat(StringUtils.mid(email, index, StringUtils.length(email)));
}
/**
* [银行卡号] 前六位,后四位,其他用星号隐藏每位1个星号<例子:6222600**********1234>
*
* @param cardNum
* @return
*/
public static String bankCard(String cardNum) {
if (StringUtils.isBlank(cardNum)) {
return "";
}
return StringUtils.left(cardNum, 6).concat(StringUtils.removeStart(StringUtils.leftPad(StringUtils.right(cardNum, 4), StringUtils.length(cardNum), "*"), "******"));
}
/**
* [公司开户银行联号] 公司开户银行联行号,显示前两位,其他用星号隐藏,每位1个星号<例子:12********>
*
* @param code
* @return
*/
public static String cnapsCode(String code) {
if (StringUtils.isBlank(code)) {
return "";
}
return StringUtils.rightPad(StringUtils.left(code, 2), StringUtils.length(code), "*");
}
}
2、测试工具类:
package cn.hsa.utils;
/**
* @Description: 信息脱敏测试
*/
public class MaskingUtilsTest {
public static void main(String[] args) {
//中文名脱敏
String s1 = DataMaskingUtils.chineseName("欧阳娜娜"); //欧***
String s2 = DataMaskingUtils.chineseName("欧阳", "娜娜");//欧阳**
//字符脱敏
String s3 = DataMaskingUtils.strMasking("信息脱敏工具类测试字符脱敏", 4, 2);
String s4 = DataMaskingUtils.strMasking("字符脱敏", 5, 2);
String s5 = DataMaskingUtils.strMasking("字符脱敏", 2, 3);
String s6 = DataMaskingUtils.strMasking("字符脱敏", 3, 3);
//[身份证号] 脱敏 后四位其他隐藏
String s7 = DataMaskingUtils.idCardNum("430903199909093412");
//[身份证号]脱敏 前六位,后四位,其他用隐藏
String s8 = DataMaskingUtils.idCard("430903199909093412");
//[固定电话] 后四位,其他隐藏
String s9 = DataMaskingUtils.fixedPhone("13077098909");
//[手机号码] 前三位,后四位,其他隐藏<例子:138******1234>
String s10 = DataMaskingUtils.mobilePhone("13879081234");
//[地址] 只显示到地区,不显示详细地址
String s11 = DataMaskingUtils.address("北京市丰台区莲花池东路118号", 10);
//[电子邮箱] 邮箱前缀仅显示第一个字母
String s12 = DataMaskingUtils.email("zhangsan123@163.com");
//[银行卡号] 前六位,后四位,其他用星号隐藏每位1个星号
String s13 = DataMaskingUtils.bankCard("622260011111111111234");
//[公司开户银行联号] 公司开户银行联行号,显示前两位,其他用星号隐藏,每位1个星号
String s14 = DataMaskingUtils.cnapsCode("6222600111111111234");
}
}
3、测试结果: