如何对html任意选中区域脱敏(js原生实现)

一、思路

1.获取点击区域

2.判断当前所选区域是否跨标签

3.对跨标签的情况,需要遍历所有子节点, 从选中的开始标签到结束标签中的所有dom进行脱敏处理

二、代码

**
 * 脱敏按钮点击
 */
tm() {
    this.isStart = false;
    //获取选中区域
    let range = window.getSelection().getRangeAt(0);
    let startOffset = range.startOffset;
    let endOffset = range.endOffset;
    //选中区域的开始和结束节点不是同一个标签,则需要找到所有跨越的标签进行脱敏
    if (range.startContainer != range.endContainer) {
        //获取选中区域所属dom
        let obox = range.commonAncestorContainer;
        this.getAllChildNodes(range, obox);
    } else {
        //获取选中区域所属节点dom
        let parElem = document.getSelection().anchorNode.parentElement;
        parElem.innerHTML = this.mask(parElem.innerHTML, startOffset, endOffset);
    }
    this.addTm(1);
},

/**
 * 递归找到子节点就脱敏
 * @param range
 * @param obox
 */
getAllChildNodes(range, obox) {
    let nodes = obox.getElementsByTagName("*");
    for (let i = 0; i < nodes.length; i++) {
        let item = nodes[i];
        let itemNodes = item.getElementsByTagName("*");
        if (itemNodes && itemNodes.length > 0) {
            //不是子节点继续递归
            this.getAllChildNodes(range, item);
        } else {
            this.childTm(range, item);
        }
    }
},

/**
 * 脱敏子节点
 * @param range
 * @param item
 */
childTm(range, item) {
    let startOffset = range.startOffset;
    let endOffset = range.endOffset;
    //找到选中的开始子节点,标志开始脱敏
    if (item == range.startContainer || item == range.startContainer.parentNode) {
        this.isStart = true;
        item.innerHTML = this.mask(item.innerHTML, startOffset, item.innerHTML.length);
    //找到选中的结束子节点,标志结束脱敏
    } else if (item == range.endContainer || item == range.endContainer.parentNode) {
        this.isStart = false;
        item.innerHTML = this.mask(item.innerHTML, 0, endOffset);
    //开始脱敏后的中间节点需全部脱敏
    } else if (this.isStart) {
        item.innerHTML = this.mask(item.innerHTML, 0, item.innerHTML.length);
    }
},

 /**
 * 替换字符串中指定范围字符
 * @param str 要替换的字符串
 * @param begin 替换起始位置
 * @param end 替换结束位置
 * @returns {string|*}
 */
mask(str, begin, end) {
    let result = str;
    //循环替换所有的符号空格
    while (result.indexOf("&nbsp;") > -1) {
        result = result.replace("&nbsp;", " ");
    }
    //字符串中仅空格不进行替换
    if(result.match(/^[ ]*$/)) {
        return str;
    }
    for (let i = begin; i < end; i++) {
        //替换所有不是空格的字符
        if (result.charAt(i) != ' ') {
            result = result.substr(0, i) + '*' + result.substr(i + 1);
        }
    }
    return result;
},

/**
 * 向后台提交脱敏文件
 */
addTm(falg) {
    var _this = this;
    let tmhWj = document.getElementById('tmwj').innerHTML;
},

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在 Java 中,可以使用以下方法来实现对某些字段进行脱敏: 1. 创建一个脱敏类,包含脱敏所需的方法,如手机号脱敏、身份证号脱敏等。 2. 在需要脱敏的地方,调用该脱敏类中对应的方法进行脱敏。 例如,下面是一个简单的脱敏类的示例: ``` public class DesensitizationUtil { public static String desensitizeMobile(String mobile) { return mobile.replaceAll("(\\d{3})\\d{4}(\\d{4})", "$1****$2"); } public static String desensitizeIdCard(String idCard) { return idCard.replaceAll("(\\d{4})\\d{10}(\\w{4})", "$1**********$2"); } } ``` 然后,在需要脱敏的地方调用这些方法即可: ``` String mobile = "13812345678"; String desensitizedMobile = DesensitizationUtil.desensitizeMobile(mobile); // 输出:138****5678 String idCard = "420123198806251234"; String desensitizedIdCard = DesensitizationUtil.desensitizeIdCard(idCard); // 输出:4201**********1234 ``` 注意:这只是一个简单的示例,实际应用中可能需要更复杂的脱敏方法。 ### 回答2: 在Java中,可以通过一些方法实现对某些字段进行脱敏的操作。下面是一种常见的实现方式。 1. 首先,定义一个脱敏处理工具类,例如DesensitizationUtil,该类包含各种脱敏处理方法。 2. 对于需要脱敏的字段,可以根据不同的需求选择不同的脱敏方法。以下是一些常见的脱敏方法: - 姓名脱敏:对于姓名字段,可以将姓氏保留,将名字部分用星号或其他字符替代,例如把"张三"脱敏为"张*" - 身份证号脱敏:对于身份证号字段,可以保留前几位和后几位,中间部分用星号或其他字符替代,例如把"110101199001011234"脱敏为"110***********234" - 手机号脱敏:对于手机号字段,可以保留前3位和后4位,中间部分用星号或其他字符替代,例如把"13812345678"脱敏为"138****5678" - 邮箱脱敏:对于邮箱字段,可以保留邮箱用户名的前几个字符,后面用星号或其他字符替代,例如把"[email protected]"脱敏为"exa**********m" 3. 在具体的业务类中,将需要脱敏的字段通过调用脱敏工具类的方法进行处理,例如: ```java String name = "张三"; String desensitizedName = DesensitizationUtil.desensitizeName(name); System.out.println(desensitizedName); // 输出:张* String idCard = "110101199001011234"; String desensitizedIdCard = DesensitizationUtil.desensitizeIdCard(idCard); System.out.println(desensitizedIdCard); // 输出:110***********234 String phoneNumber = "13812345678"; String desensitizedPhoneNumber = DesensitizationUtil.desensitizePhoneNumber(phoneNumber); System.out.println(desensitizedPhoneNumber); // 输出:138****5678 String email = "[email protected]"; String desensitizedEmail = DesensitizationUtil.desensitizeEmail(email); System.out.println(desensitizedEmail); // 输出:exa**********m ``` 通过以上步骤,就可以方便地实现对某些字段的脱敏操作。这样可以有效保护敏感信息,避免隐私泄露的风险。 ### 回答3: Java可以通过一些方法实现对某些字段进行脱敏脱敏是一种隐私保护技术,在保护敏感数据信息的同时将其进行处理,以便在某些场景下限制敏感数据的可见性。 一种实现方式是利用字符串操作方法对字段进行脱敏。比如对于手机号码,可以将其中间的几位数字替换为特定的符号或者统一的数字。另外,可以使用正则表达式来匹配指定的字段并进行替换。 另一种方法是利用加密算法对字段进行加密处理。通过使用一定的加密方法,将敏感字段进行加密,并在需要使用时进行解密。这种方式可以保证数据的安全性,但对于某些需要明文数据的场景可能不适用。 还有一种方法是利用数据库存储过程对字段进行脱敏。通过在数据库中创建存储过程来对字段进行处理,可以实现对特定数据进行脱敏。这种方式可以在数据库层面进行数据保护,对于需要对数据库中所有数据进行脱敏的情况比较适用。 此外,可以使用开源库或框架来实现字段脱敏,如Apache Commons Lang库中的StringUtils类提供了丰富的字符串处理方法,也可以结合正则表达式进行字段匹配和替换。 总的来说,Java可以通过字符串操作、加密算法、数据库存储过程等多种方法实现对某些字段的脱敏。具体的实现方式需根据实际需求和场景进行选择。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值