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

 更新时间:2023年07月05日 10:50:45   作者:Javaの甘乃迪  
这篇文章主要给大家介绍了关于Java常用的数据脱敏(手机、邮箱、身份证号)的相关资料,信息脱敏对某些敏感信息通过脱敏规则进行数据的变形,实现敏感隐私数据的可靠保护,需要的朋友可以参考下

一、什么是数据脱敏

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

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

手机号

脱敏规则:只显示手机号的前面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);
    }

结果: 

2.方法2:(MySQL)

这两条SQL语句都可实现

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

结果:

邮箱 

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

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

身份证号

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

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

银行卡号

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

    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);
    }

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

附:以下工具类是对字符、姓名、邮箱、手机、固定电话,银行卡号、地址、公司开户银行联号、身份证号进行脱敏处理

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、测试结果:

总结

到此这篇关于Java常用的数据脱敏方法(手机、邮箱、身份证号)的文章就介绍到这了,更多相关Java数据脱敏内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • java 设计模型之单例模式详解

    java 设计模型之单例模式详解

    本文主要介绍了java 单例模式,单例对象(Singleton)是一种常用的设计模式。在Java应用中,单例对象能保证在一个JVM中,该对象只有一个实例存在,希望能帮助有需要的同学
    2016-07-07
  • 浅谈java的接口和C++虚类的相同和不同之处

    浅谈java的接口和C++虚类的相同和不同之处

    下面小编就为大家带来一篇浅谈java的接口和C++虚类的相同和不同之处。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧,祝大家游戏愉快哦
    2016-12-12
  • Java客户端通过HTTPS连接到Easysearch实现过程

    Java客户端通过HTTPS连接到Easysearch实现过程

    这篇文章主要为大家介绍了Java客户端通过HTTPS连接到Easysearch实现过程详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-11-11
  • java关于list集合做删除操作时的坑及解决

    java关于list集合做删除操作时的坑及解决

    这篇文章主要介绍了java关于list集合做删除操作时的坑及解决,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-11-11
  • java实现异步导出数据

    java实现异步导出数据

    这篇文章主要为大家详细介绍了java实现异步导出数据,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-11-11
  • 浅谈String类型等值比较引起的“==”、“equals()”和“hashCode”思考

    浅谈String类型等值比较引起的“==”、“equals()”和“hashCode”思考

    这篇文章主要介绍了浅谈String类型等值比较引起的“==”、“equals()”和“hashCode”思考。具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-09-09
  • SpringCloud Netflix Ribbon超详细讲解

    SpringCloud Netflix Ribbon超详细讲解

    这篇文章主要介绍了SpringCloud笔记HoxtonNetflix之Ribbon负载均衡,Ribbon是管理HTTP和TCP服务客户端的负载均衡器,Ribbon具有一系列带有名称的客户端(Named Client),对SpringCloud Ribbon负载均衡相关知识感兴趣的朋友一起看看吧
    2022-10-10
  • Mybatis以main方法形式调用dao层执行代码实例

    Mybatis以main方法形式调用dao层执行代码实例

    这篇文章主要介绍了Mybatis以main方法形式调用dao层执行代码实例,MyBatis 是一款优秀的持久层框架,MyBatis 免除了几乎所有的 JDBC 代码以及设置参数和获取结果集的工作,需要的朋友可以参考下
    2023-08-08
  • SpringBoot中拦截器和动态代理的区别详解

    SpringBoot中拦截器和动态代理的区别详解

    在 Spring Boot 中,拦截器和动态代理都是用来实现功能增强的,所以在很多时候,有人会认为拦截器的底层是通过动态代理实现的,所以本文就来盘点一下他们两的区别,以及拦截器的底层实现吧
    2023-09-09
  • SpringBoot使用AOP记录接口操作日志的方法

    SpringBoot使用AOP记录接口操作日志的方法

    日志记录量是很大的,所以只记录关键地方并按期归档,最好是存在如elasticsearch中,如果存在数据库中,分表是不错的选择,这篇文章主要介绍了SpringBoot使用AOP记录接口操作日志的方法,需要的朋友可以参考下
    2022-08-08

最新评论