常用的数据脱敏(手机、邮箱、身份证号)

一、什么是数据脱敏

        先来看看什么是数据脱敏?数据脱敏也叫数据的去隐私化,在我们给定脱敏规则和策略的情况下,对敏感数据比如 手机号、银行卡号 等信息,进行转换或者修改的一种技术手段,防止敏感数据直接在不可靠的环境下使用。

二、需要脱敏的数据有哪些

  • 手机号

   脱敏规则:只显示手机号的前面3位和尾号后4位,中间号码显示为‘****’

   1.方法1:(正则表达式)

    public static void main(String[] args) {
        String phone = "18812345678";
        String result1 = phone.replaceAll("(\\d{3})\\d{4}(\\d{4})", "$1****$2");
        System.out.println("脱敏的手机号:" + result1);
    }

结果: 

   常用的数据脱敏(手机、邮箱、身份证号)_第1张图片

 2.方法2:(MySQL)

        这两条SQL语句都可实现

SELECT INSERT
	( mobile, 4, 4, '****' ) 
FROM
	t_user
	

结果:

常用的数据脱敏(手机、邮箱、身份证号)_第2张图片

  • 邮箱 

   脱敏规则:邮箱只显示第一个字符和'@'之后的字符,第一个字符之后’@‘之前的,显示为‘****’

    public static void main(String[] args) {
        String email = "[email protected]";
        String result = email.replaceAll("(^\\w)[^@]*(@.*$)", "$1****$2");
        System.out.println("脱敏的邮箱:" + result);
    }

常用的数据脱敏(手机、邮箱、身份证号)_第3张图片

  • 身份证号

脱敏规则:身份证号只显示前三位和后四位,其余显示为‘****’

    public static void main(String[] args) {
        String idCard = "30010019990101123X";
        String result = idCard.replaceAll("(?<=\\w{3})\\w(?=\\w{4})", "*");
        System.out.println("脱敏的身份证号:" + result);
    }

常用的数据脱敏(手机、邮箱、身份证号)_第4张图片

  • 银行卡号

 脱敏规则:银行卡号只显示前六位和后四位,其余显示为‘****’

    public static void main(String[] args) {
        String bankCard = "1234561234567895678";
        String result = bankCard.replaceAll("(\\d{6})\\d{9}(\\d{4})", "$1****$2");
        System.out.println("脱敏的银行卡号:" + result);
    }

常用的数据脱敏(手机、邮箱、身份证号)_第5张图片

ps: 别说交给前端去处理。 为了数据保密,既然要处理,肯定不能把未脱敏数据给到前端的。 

如果这篇文章对您有所帮助,或者有所启发的话,求一键三连:点赞、评论、收藏➕关注,您的支持是我坚持写作最大的动力。

你可能感兴趣的:(java,开发语言,intellij-idea,spring,boot,mybatis)