用户敏感信息掩码工具

实际开发中,用户/客户敏感数据(如手机号、姓名、身份证号码等)打印输出的时候,为了保护用户隐私,通常需要将其转换为掩码”*“处理,下面分享一个掩码工具类,希望能给大家提供参考。

工具类

/**
 * 
 */
package com.aiait.es.util;

import org.apache.commons.lang3.StringUtils;

/**
 * @author Zhenyu,Chen
 *
 */
public class MaskUtil {

	/**
     * 手机号显示首3末4位,中间用*号隐藏代替,如:188****5593
     *
     * @param mobile
     * @return
     */
    public static String maskMobile(String mobile) {
        if(StringUtils.isBlank(mobile) || mobile.length() <= 8) {
            return mobile;
        }
 
        return wordMask(mobile, 3, 4, "*");
    }
 
    /**
     * 电话号码显示区号及末4位,中间用*号隐藏代替,如:055****6666
     *
     * @param telephone
     * @return
     */
    public static String maskTelephone(String telephone) {
        if(StringUtils.isBlank(telephone)) {
            return telephone;
        }
        String result;
        if (telephone.length() > 8) {
            if (telephone.contains("-")) {
                String[] temp = telephone.split("-");
                result = temp[0] + "****" + temp[1].substring(temp[1].length() - 4, temp[1].length());
            } else {
                result = telephone.substring(0, 3) + "****" + telephone.substring(telephone.length() - 4, telephone.length());
            }
        } else {
            result = "****" + telephone.substring(telephone.length() - 4, telephone.length());
        }
 
        return result;
    }
 
    /**
     * 身份证号显示首6末4位,中间用4个*号隐藏代替,如:340121****3754
     *
     * @param idCard
     * @return
     */
    public static String maskIDCard(String idCard) {
        if(StringUtils.isBlank(idCard)) {
            return idCard;
        }
 
        return wordMask(idCard, 3, 4, "*");
    }
 
    /**
     * 银行卡显示首6末4位,中间用4个*号隐藏代替,如:622202****4123
     *
     * @param cardNo
     * @return
     */
    public static String maskBankCard(String cardNo) {
        if(StringUtils.isBlank(cardNo) || cardNo.length() < 10) {
            return cardNo;
        }
 
        return wordMask(cardNo, 6, 4, "*");
    }
 
    /**
     * 邮箱像是前两位及最后一位字符,及@后邮箱域名信息,如:ch****y@163.com
     *
     * @param email
     * @return
     */
    public static String maskEmail(String email) {
        if(StringUtils.isBlank(email)) {
            return email;
        }
        String[] temp = email.split("@");
 
        return wordMask(temp[0], 2, 1, "*") + "@" + temp[1];
    }
 
    /**
     * 汉字掩码
     * 
     * 0-1字,如:用(用)
     * 2字,如:用于(*于)
     * 3-4字,如:用于掩(用*掩)、用于掩码(用**码)
     * 5-6字,如:用于掩码测(用于*码测)、用于掩码测试(用于**测试)
     * 大于6字,如:用于掩码测试的字符串(用于掩****字符串)
     * 
     * @param name
     * @return
     */
    public static String maskName(String name) {
    	int lenth = StringUtils.length(name);
        switch (lenth) {
		case 0:
		case 1:
			return name;
		case 2:
			return "*" + name.substring(1, 2);
		case 3:
		case 4:
			return wordMask(name, 1, 1, "*");
		case 5:
		case 6:
			return wordMask(name, 2, 2, "*");
		default:
			return wordMask(name, 3, 3, "*");
		}
    }
 
    /**
     * 全隐藏,如: ***
     *
     * @param str
     * @return
     */
    public static String maskAll(String str) {
        if(StringUtils.isBlank(str)) {
            return str;
        }
        return "******";
    }
 
    /**
     * 对字符串进行脱敏处理 --
     *
     * @param word 被脱敏的字符
     * @param startLength 被保留的开始长度 前余n位
     * @param endLength 被保留的结束长度 后余n位
     * @param pad 填充字符
     * */
    public static String wordMask(String word,int startLength ,int endLength,String pad)    {
 
        if (startLength + endLength > word.length()) {
            return StringUtils.leftPad("", word.length() - 1, pad);
        }
 
        String startStr = word.substring(0, startLength);
 
        String endStr = word.substring(word.length() - endLength, word.length());
 
        return startStr + StringUtils.leftPad("", word.length() - startLength - endLength, pad) + endStr;
 
    }
 
    public static void main(String[] args) {
    	System.out.println(maskMobile("18888885593"));//188****5593
    	System.out.println(maskTelephone("05516666666"));//055****6666
    	System.out.println(maskIDCard("340121200006063754"));//340***********3754
    	System.out.println(maskEmail("chenzhenyu@163.com"));//ch*******u@163.com
        System.out.println(maskName("用于掩码测试的字符串"));//用于掩****字符串
        System.out.println(maskName("用于掩码测试的字符"));//用于掩***的字符
        System.out.println(maskName("用于掩码测试的字"));//用于掩**试的字
        System.out.println(maskName("用于掩码测试的"));//用于掩*测试的
        System.out.println(maskName("用于掩码测试"));//用于**测试
        System.out.println(maskName("用于掩码测"));//用于*码测
        System.out.println(maskName("用于掩码"));//用**码
        System.out.println(maskName("用于掩"));//用*掩
        System.out.println(maskName("用于"));//*于
        System.out.println(maskName("用"));//用
        System.out.println(maskName(""));//
        System.out.println(maskAll("全部掩码"));//******
    }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值