JS實現(xiàn)手機號脫敏、郵箱脫敏、身份證號脫敏、姓名脫敏等常見脫敏代碼示例

一:為什么要脫敏?
在前端項目開發(fā)中,數(shù)據(jù)的展示與渲染是非常關鍵的一步。通常我們會從后端接口直接拿到數(shù)據(jù),但是在某些情況下渲染一些隱私信息,比如身份證號,手機號等。這些我們就需要進行脫敏處理,比如前三后四的格式,又或者其它格式。這樣有利于布局和保密。接下來,就讓我們看一下常見的脫敏種類吧!
二:如何實現(xiàn)脫敏?
在實現(xiàn)脫敏上,我們主要使用的是正則表達式和字符串的 replace 替換這兩個技術。字符表達式是用來匹配我們要去進行替換的數(shù)據(jù)。replace 則是根據(jù)各種不同的需求替換成不同的字符。
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中,我們可以使用一些基本的脫敏處理方法。以上這些就是比較常見的方法,各位小伙伴可以根據(jù)自己的需求使用哦。當然還有各種不同的情景,不過相信各位小伙伴可以通過上面的代碼寫出更適配你所需要的邏輯。

附前端js讓手機號脫敏的其他幾種方法
標題手機號脫敏方法有幾種
// 方法一:使用substring()方法
let phoneNumberOne='19909091221';
let desensitizationOne=phoneNumberOne.substring(0,3)+' **** '+phoneNumberOne.substring(7);
// 方法二:使用substring()方法
let phoneNumberTwo='19909091221';
let desensitizationTwo=phoneNumberTwo.substr(0,3)+' **** '+phoneNumberTwo.substr(7);
// 方法三:使用正則表達式方法
let phoneNumberThree='19909091221';
let regular=/(\d{3})\d*(\d{4})/
let desensitizationThree=phoneNumberThree.replace(regular,'$1****$2');
//總結一下區(qū)別:
// substring第一個參數(shù)是開始下標,第二個是結束下標。
// substr第一個參數(shù)是開始下標,第二個是截取幾位。
到此這篇關于JS實現(xiàn)手機號脫敏、郵箱脫敏、身份證號脫敏、姓名脫敏等常見脫敏的文章就介紹到這了,更多相關JS常見脫敏手機號郵箱等內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
微信小程序loading組件顯示載入動畫用法示例【附源碼下載】
這篇文章主要介紹了微信小程序loading組件顯示載入動畫用法,結合實例形式分析了loading組件顯示載入動畫的相關事件操作與屬性設置技巧,并附帶源碼供讀者下載參考,需要的朋友可以參考下2017-12-12
BootStrap的select2既可以查詢又可以輸入的實現(xiàn)代碼
這篇文章主要介紹了bootstrap的select2既可以查詢又可以輸入的實現(xiàn)代碼,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2017-02-02
javascript實現(xiàn)點擊產(chǎn)生隨機圖形
這篇文章主要為大家詳細介紹了javascript實現(xiàn)點擊產(chǎn)生隨機圖形,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-01-01
TypeScript中l(wèi)et和var的區(qū)別介紹
這篇文章主要介紹了TypeScript?let與var的區(qū)別,主要從作用域等這幾個方面做詳細介紹,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-07-07

