JS實現(xiàn)手機(jī)號脫敏的方法詳解
1、脫敏的含義
脫敏(Data Masking)指的是通過特定的技術(shù)手段對敏感數(shù)據(jù)進(jìn)行處理,使其不再直接暴露給用戶或系統(tǒng),防止敏感信息泄露,通常在測試、開發(fā)、數(shù)據(jù)處理等場景中使用。脫敏后的數(shù)據(jù)應(yīng)該保留其格式和特征,但不應(yīng)包含敏感信息。
常見的脫敏方式
- 字符替換:將敏感信息的一部分替換為特殊字符(如
*、X)。 - 數(shù)據(jù)加密:通過
加密算法將敏感數(shù)據(jù)加密后存儲或傳輸。 - 數(shù)據(jù)脫標(biāo):刪除或用替代值替換敏感數(shù)據(jù)。
- 局部脫敏:僅對
敏感數(shù)據(jù)的部分進(jìn)行替換,而保留其他部分。
就是下面這種效果,這個在現(xiàn)在的生活中也是很常見的東西了

2、前端處理手機(jī)號脫敏的方式
2.1 字符串的replace搭配正則

核心點
- String.prototype.replace()
- 正則表達(dá)式
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
</head>
<body>
<input type="text" id="phone" value="13012345678">
<button id="btn">點擊</button>
<br>
脫敏后數(shù)據(jù):<span id="result"></span>
<script>
document.querySelector('#btn').onclick = function () {
let phone = document.querySelector('#phone').value
let newPhone = phone.replace(/(\d{3})\d{4}(\d{4})/, '$1****$2')
document.querySelector('#result').innerHTML = newPhone
}
</script>
</body>
</html>
在此處, (\d{3})\d{4}(\d{4}) 就是核心。這里的 $1 ,$2 只會匹配上以 () 包裹的東西 ,所以 $2 就是5678 , 不是1234。$1 指的就是第一個匹配上的大括號,$2 指的就是 第二個匹配上的大括號
$1 ==> (\d{ 3}) ==> 130
$2 ==> (\d{4}) ==> 5678
2.2 字符串的slice
核心點
核心點就是利用了 字符串截取的方法
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
</head>
<body>
<input type="text" id="phone" value="13012345678">
<button id="btn">點擊</button>
<br>
脫敏后數(shù)據(jù):<span id="result"></span>
<script>
document.querySelector('#btn').onclick = function () {
let phone = document.querySelector('#phone').value
// 2、第二種方法 slice
// slice(0,3) 截取前3位
// slice(-4) 11+(-4) = 7 ,從第八個字符截取,一直到最后
let newPhone = phone.slice(0, 3) + '****' + phone.slice(-4)
document.querySelector('#result').innerHTML = newPhone
}
// $1 ==> (\d{ 3}) ==> 130
// $2 ==> (\d{4}) ==> 5678
</script>
</body>
</html>
2.3 數(shù)組的splice
核心點
- 先轉(zhuǎn)成數(shù)組
- 利用數(shù)組的 splice 方法,先刪除四個,然后再插入 四個星號
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
</head>
<body>
<input type="text" id="phone" value="13012345678">
<button id="btn">點擊</button>
<br>
脫敏后數(shù)據(jù):<span id="result"></span>
<script>
document.querySelector('#btn').onclick = function () {
// 3、數(shù)組拼接方法
let phone = document.querySelector('#phone').value
let arr = phone.split('')
arr.splice(3, 4, '****')
let newPhone = arr.join('')
document.querySelector('#result').innerHTML = newPhone
}
// $1 ==> (\d{ 3}) ==> 130
// $2 ==> (\d{4}) ==> 5678
</script>
</body>
</html>
其實還有其他方法在此不列舉了,但還是第一種, 是最常見的方式
3、replace的特殊特?fù)Q模式

const str = "Hello dgg and world!";
const regex = /(dgg)/;
const result = str.match(regex);
console.log(result);
if (result) {
const beforeMatch = str.slice(0, result.index); // 匹配前的文本
const afterMatch = str.slice(result.index + result[0].length); // 匹配后的文本
console.log("匹配前的文本:", beforeMatch); // Hello,
console.log("匹配后的文本:", afterMatch); // !
console.log("匹配到的文本:", result[0]); // Hello, world!
}

這個result 返回的是一個數(shù)組 ,
- 數(shù)組第一項:這個正則匹配到的整個字符串
- 數(shù)組第二項:第一個捕獲的組
- 數(shù)組第三項:第二個捕獲的組
- 以此類推
- index:匹配開始的位置
- input 原始輸入字符串
到此這篇關(guān)于JS實現(xiàn)手機(jī)號脫敏的方法詳解的文章就介紹到這了,更多相關(guān)JS手機(jī)號脫敏內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
原生javascript制作的拼圖游戲?qū)崿F(xiàn)方法詳解
這篇文章主要介紹了原生javascript制作的拼圖游戲?qū)崿F(xiàn)方法,結(jié)合實例形式詳細(xì)分析了JavaScript制作拼圖游戲的相關(guān)步驟、原理、實現(xiàn)方法及相關(guān)操作注意事項,需要的朋友可以參考下2020-02-02
JavaScript運行過程中的“預(yù)編譯階段”和“執(zhí)行階段”
這篇文章主要介紹了JavaScript運行過程中的“預(yù)編譯階段”和“執(zhí)行階段”的相關(guān)資料,需要的朋友可以參考下2015-12-12
詳解js產(chǎn)生對象的3種基本方式(工廠模式,構(gòu)造函數(shù)模式,原型模式)
本篇文章主要介紹了js產(chǎn)生對象的3種基本方式(工廠模式,構(gòu)造函數(shù)模式,原型模式) ,具有一定的參考價值,有興趣的可以了解一下2017-01-01
javascript setTimeout()傳遞函數(shù)參數(shù)(包括傳遞對象參數(shù))
由于需要,我要用到setTimeout()并且在里邊的函數(shù)參數(shù)傳遞一個參數(shù),就像這樣setTimeout("fun(參數(shù))", 1000)。但是以我這種寫法,js會報錯,說‘參數(shù)’未定義。2010-04-04
uniapp使用uni-imei插件獲取手機(jī)的設(shè)備號
uniapp框架是一款開發(fā)跨平臺應(yīng)用的工具,它支持iOS、Android以及Web等多個平臺,在這些平臺中,uniapp可以訪問某些設(shè)備的硬件信息,這篇文章主要給大家介紹了關(guān)于uniapp使用uni-imei插件獲取手機(jī)設(shè)備號的相關(guān)資料,需要的朋友可以參考下2024-01-01
D3.js 實現(xiàn)帶伸縮時間軸拓?fù)鋱D的示例代碼
這篇文章主要介紹了D3.js 實現(xiàn)帶伸縮時間軸拓?fù)鋱D的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-01-01

