本文介绍: 在前端项目开发中,数据的展示与渲染是非常关键的一步。通常我们会从后端接口直接拿到数据,但是在某些情况下渲染一些隐私信息,比如身份证号,手机号等。这些我们就需要进行脱敏处理,比如前三后四的格式,又或者其它格式。这样有利于布局和保密。接下来,就让我们看一下常见的脱敏种类吧!
一:为什么要脱敏?
在前端项目开发中,数据的展示与渲染是非常关键的一步。通常我们会从后端接口直接拿到数据,但是在某些情况下渲染一些隐私信息,比如身份证号,手机号等。这些我们就需要进行脱敏处理,比如前三后四的格式,又或者其它格式。这样有利于布局和保密。接下来,就让我们看一下常见的脱敏种类吧!
二:如何实现脱敏?
在实现脱敏上,我们主要使用的是正则表达式和字符串的 replace 替换这两个技术。字符表达式是用来匹配我们要去进行替换的数据。replace 则是根据各种不同的需求替换成不同的字符。
1.手机号脱敏(前三后四)
// 手机号做脱敏处理
function phoneHide(phone) {
let reg = /^(1[3-9][0-9])d{4}(d{4}$)/; // 定义手机号正则表达式
phone = phone.replace(reg, '$1****$2');
return phone; // 185****6696
}
2.邮箱脱敏
function emailHide(email) {
var avg;
var splitted;
var email1;
var email2;
splitted = email.split('@');
email1 = splitted[0];
avg = email1.length / 2;
email1 = email1.substring(0, email1.length - avg);
email2 = splitted[1];
return email1 + '***@' + email2; // 输出为81226***@qq.com
}
3.身份证号脱敏
function cardHide(card) {
const reg = /^(.{6})(?:d+)(.{4})$/; // 匹配身份证号前6位和后4位的正则表达式
const maskedIdCard = card.replace(reg, '$1******$2'); // 身份证号脱敏,将中间8位替换为“*”
return maskedIdCard; // 输出:371782******5896
}
4.姓名脱敏
function nameHide(name) {
if (name.length == 2) {
name = name.substring(0, 1) + '*'; // 截取name 字符串截取第一个字符,
return name; // 张三显示为张*
} else if (name.length == 3) {
name = name.substring(0, 1) + '*' + name.substring(2, 3); // 截取第一个和第三个字符
return name; // 李思思显示为李*思
} else if (name.length > 3) {
name = name.substring(0, 1) + '*' + '*' + name.substring(3, name.length); // 截取第一个和大于第4个字符
return name; // 王五哈哈显示为王**哈
}
}
三:结尾
脱敏处理是信息安全的重要手段,它可以有效保护敏感信息不被暴露。在JavaScript中,我们可以使用一些基本的脱敏处理方法。以上这些就是比较常见的方法,各位小伙伴可以根据自己的需求使用哦。当然还有各种不同的情景,不过相信各位小伙伴可以通过上面的代码写出更适配你所需要的逻辑。
原文地址:https://blog.csdn.net/c18559787293/article/details/134304827
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.7code.cn/show_48170.html
如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱:suwngjj01@126.com进行投诉反馈,一经查实,立即删除!
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。