java使用正则进行负责数据脱敏

在开发中,由于前期没有要求数据脱敏,突然又要求脱敏,前期的姓名和手机号都存储到同一个字符串中了,今天记录一下使用正则进行数据脱敏.

String regName = "([^转\\(入\\|出\\)现金券\\(来自|\\给\\)\\d*])";
        String regPhone = "[\\d]*";
        System.out.println("字符串处理前:"+str);
        Pattern compile = Pattern.compile(regName);
        Matcher matcher = compile.matcher(str);
        StringBuffer name = new StringBuffer();
        while (matcher.find()){
            String group = matcher.group();
            name.append(group);
        }
        System.out.println("找到的人名:"+name);
        System.out.println("人名脱敏后:"+DesensitizationUtils.desensitizedName(String.valueOf(name)));

        StringBuffer phone = new StringBuffer();
        Pattern compileForPhone = Pattern.compile(regPhone);
        Matcher matcherForPhone = compileForPhone.matcher(str);
        while (matcherForPhone.find()) {
            String group = matcherForPhone.group();
            phone.append(group);
        }
        System.out.println("找到的手机号:"+phone);
        System.out.println("手机号脱敏后:"+DesensitizationUtils.desensitizedPhoneNumber(String.valueOf(phone)));

        String res = str.replace(name,DesensitizationUtils.desensitizedName(String.valueOf(name)));
        String replace = res.replace(phone, DesensitizationUtils.desensitizedPhoneNumber(String.valueOf(phone)));
        System.out.println("脱敏后的结果 == "+replace);

脱敏工具类


import com.google.common.base.Strings;

import java.util.regex.Matcher;
import java.util.regex.Pattern;

/**
 * @description: 脱敏工具类
 * @return:
 * @author: ***
 * @time: 2022/6/22
 */
public class DesensitizationUtils {

    /**
     * @description: 名字脱敏
     * 脱敏规则: 隐藏中中间部分,比如:李某人 置换为 李*人 , 李某置换为 *某,司徒司翘置换为 司**翘
     * @return:
     * @author: ***
     * @time: 2022/6/22
     */
    public static String desensitizedName(String fullName){
        if (!Strings.isNullOrEmpty(fullName)) {
            int length = fullName.length();
            if(length == 2){
                return fullName.substring(0,1).concat("*");
            }else if(length == 3){
                return StringUtils.left(fullName,1).concat("*").concat(StringUtils.right(fullName,1));
            }else if(length > 3){
                return StringUtils.left(fullName,1).concat(generateAsterisk(fullName.substring(1,length-1).length())).concat(StringUtils.right(fullName,1));
            }else {
                return fullName;
            }
        }
        return fullName;
    }


    /**
     * @description: 手机号脱敏,脱敏规则: 保留前三后四, 比如15566026528置换为155****6528
     * @return:
     * @author: ***
     * @time: 2022/6/22
     */
    public static String desensitizedPhoneNumber(String phoneNumber){
        if(StringUtils.isNotEmpty(phoneNumber)){
            int length = phoneNumber.length();
            if(length == 11){
                return phoneNumber.replaceAll("(\\w{3})\\w*(\\w{4})", "$1****$2");
            }else if(length > 2){
                return StringUtils.left(phoneNumber,1).concat(generateAsterisk(phoneNumber.substring(1,length-2).length())).concat(StringUtils.right(phoneNumber,1));
            }else {
                return phoneNumber;
            }
        }
        return phoneNumber;
    }


    /**
     * @description: 身份证脱敏
     * 脱敏规则: 保留前六后三, 适用于15位和18位身份证号:
     * 原身份证号(15位):210122198401187,脱敏后的身份证号:210122******187
     * 原身份证号(18位):210122198401187672,脱敏后的身份证号:210122*********672
     * @return:
     * @author: ***
     * @time: 2022/6/22
     */
    public static String desensitizedIdNumber(String idNumber){
        if (!Strings.isNullOrEmpty(idNumber)) {
            int length = idNumber.length();
            if (length == 15){
                return idNumber.replaceAll("(\\w{6})\\w*(\\w{3})", "$1******$2");
            }else if (length == 18){
                return idNumber.replaceAll("(\\w{6})\\w*(\\w{3})", "$1*********$2");
            }else if(length > 9){
                return StringUtils.left(idNumber,6).concat(generateAsterisk(idNumber.substring(6,length-3).length())).concat(StringUtils.right(idNumber,3));
            }
        }
        return idNumber;
    }


    /**
     * @description: 电子邮箱脱敏,脱敏规则:电子邮箱隐藏@前面的3个字符
     * @return:
     * @author: ***
     * @time: 2022/6/22
     */
    public static String desensitizationEmail(String email) {
        if (StringUtils.isEmpty(email)) {
            return email;
        }
        String encrypt = email.replaceAll("(\\w+)\\w{3}@(\\w+)", "$1***@$2");
        if (email.equalsIgnoreCase(encrypt)) {
            encrypt = email.replaceAll("(\\w*)\\w{1}@(\\w+)", "$1*@$2");
        }
        return encrypt;
    }


    /**
     * @description: 地址脱敏,脱敏规则:从第4位开始隐藏,隐藏8位
     * @return:
     * @author: ***
     * @time: 2022/6/22
     */
    public static String desensitizedAddress(String address){
        if (!Strings.isNullOrEmpty(address)) {
            int length = address.length();
            if(length > 4 && length <= 12){
                return StringUtils.left(address, 3).concat(generateAsterisk(address.substring(3).length()));
            }else if(length > 12){
                return StringUtils.left(address,3).concat("********").concat(address.substring(11));
            }else {
                return address;
            }
        }
        return address;
    }


    /**
     * @description: 银行账号脱敏, 脱敏规则:银行账号保留前六后四
     * @return:
     * @author: ***
     * @time: 2022/6/23
     */
    public static String desensitizedAddressBankCardNum(String acctNo) {
        if (StringUtils.isNotEmpty(acctNo)) {
            String regex = "(\\w{6})(.*)(\\w{4})";
            Matcher m = Pattern.compile(regex).matcher(acctNo);
            if (m.find()) {
                String rep = m.group(2);
                StringBuilder sb = new StringBuilder();
                for (int i = 0; i < rep.length(); i++) {
                    sb.append("*");
                }
                acctNo = acctNo.replaceAll(rep, sb.toString());
            }
        }
        return acctNo;
    }


    /**
     * @description: 返回指定长度*字符串
     * @return:
     * @author: ***
     * @time: 2022/6/22
     */
    private static String generateAsterisk(int length){
        String result = "";
        for (int i = 0; i < length; i++) {
            result += "*";
        }
        return result;
    }
}


  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 脱敏是保护用户隐私的重要手段之一。使用Java对用户敏感数据进行脱敏处理可以使用以下方法: 1. 字符串脱敏:将敏感字符串的一部分字符替换为特殊字符,如“*”。 2. 哈希脱敏使用哈希算法对敏感字符串进行散列处理,将其映射为一串固定长度的字符串,以避免数据泄露。 3. 加密脱敏使用加密算法对敏感字符串进行加密处理,以保护数据安全。 选择合适的脱敏方法取决于数据的类型和敏感程度,以及对数据安全和可用性的要求。 ### 回答2: 敏感数据脱敏是一种安全措施,旨在保护用户的个人隐私。Java作为一种强大的编程语言,可以提供多种方法来实现敏感数据的脱敏处理。 首先,我们可以使用Java中的字符串操作函数来对敏感数据进行脱敏处理。比如,我们可以使用String类中的substring方法只保留敏感数据的部分信息,如只保留前几个字符,例如只保留手机号码的前三位和后四位。同时,我们还可以使用String类中的replace方法将部分敏感数据替换为符号或特定字符,如将身份证号中的中间数字替换为*号。 其次,Java还提供了正则表达式功能,可以对敏感数据进行更精确的脱敏处理。我们可以使用正则表达式来匹配和提取敏感数据的特定模式,然后对匹配到的数据进行替换或隐藏处理,如将信用卡号的前12位替换为*号。 此外,Java还支持加密算法,可以对敏感数据进行加密存储。我们可以使用Java中的密码算法库,如MD5、SHA等,对敏感数据进行加密处理,将数据转化为不可逆的密文存储。 最后,通过合理的代码设计和权限控制,我们可以将敏感数据存储在安全的数据库中,并限制只有特定用户或角色才能访问和处理敏感数据。 总之,使用Java对用户敏感数据进行脱敏处理可以采用字符串操作、正则表达式、加密算法等多种方法,以确保用户隐私的安全性。同时,我们还需注意设置适当的权限控制和数据存储等安全措施,以保护敏感数据的保密性和完整性。 ### 回答3: 对于敏感数据的脱敏处理,使用Java编程语言可以采取以下几个步骤: 1. 引入相关的数据脱敏工具类或库:为了方便进行脱敏处理,可以引入一些已经开发好的数据脱敏工具类或库,例如Apache StringUtils等。 2. 选择合适的脱敏策略:根据敏感数据的具体类型和要求,选择合适的脱敏策略。常见的脱敏策略包括替换、加密、截取等。例如,对于姓名可以选择只保留姓氏或者用星号代替;对于电话号码可以选择保留前几位和后几位,中间用星号代替。 3. 编写脱敏处理代码:根据选择的脱敏策略,编写相应的脱敏处理代码。可以使用字符串的截取、替换等方法,将敏感数据按照脱敏策略进行处理。例如,使用StringUtils类的replace方法将电话号码的中间几位替换为星号。 4. 对敏感数据进行测试:编写测试用例,对处理后的敏感数据进行测试,确保脱敏处理结果符合预期。可以使用JUnit等单元测试框架进行测试,保证代码的正确性和稳定性。 5. 封装脱敏处理方法:根据需求,可以将脱敏处理代码封装成一个方法,方便在需要的地方调用。可以设置该方法的参数,使得用户可以自定义脱敏策略,并提供默认的处理策略。 采用Java编程语言对用户敏感数据进行脱敏处理可以有效保护用户隐私,防止敏感数据泄露。通过合理选择脱敏策略和编写相应的脱敏处理代码,可以确保脱敏后的数据仍然具有一定的可用性和完整性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值