JavaScript實(shí)現(xiàn)數(shù)據(jù)脫敏的三種解決方式
一、前言
使用字符串操作技巧如正則表達(dá)式對(duì)手機(jī)號(hào)和身份證號(hào)進(jìn)行星號(hào)替換,實(shí)現(xiàn)數(shù)據(jù)隱私保護(hù)。
二、解決方式
slice()實(shí)現(xiàn)
let str = '15656781234' let enStr = str.slice(0,3) + '****' + str.slice(str.length - 4) console.log(enStr) // 156****1234
substring()實(shí)現(xiàn)
let str = '15656781234' let enStr = str.substring(0,3) + '****' + str.substring(str.length - 4) console.log(enStr) // 156****1234
正則實(shí)現(xiàn)
let str = '15656781234' // 第一種 let enStr = str.replace(/(\d{3})\d*(\d{4})/,"$1****$2"); console.log(enStr) // 156****1234 // 第二種 let enStr = str.replace(/^(.{8})(?:\d+)(.{4})$/, "$1******$2"); console.log(enStr) // 156****1234
三、簡(jiǎn)單封裝及代碼解析
說(shuō)明
處理電話號(hào)碼、身份證號(hào)碼、姓名、郵箱地址和銀行卡號(hào)等數(shù)據(jù)類(lèi)型的脫敏需求。
參數(shù)說(shuō)明
data: 需要脫敏的數(shù)據(jù),可以是字符串或數(shù)字,盡量處理成字符串,避免丟失精度。
flag: 指定數(shù)據(jù)類(lèi)型,用于選擇不同的脫敏策略。支持的值包括:
'tel'
: 電話號(hào)碼'identity'
: 身份證號(hào)碼'name'
: 姓名'email'
: 郵箱地址'bank'
: 銀行卡號(hào)
befor: 脫敏前段保留的字符數(shù)量,可以是字符串或數(shù)字。
after: 脫敏后段保留的字符數(shù)量,可以是字符串或數(shù)字。
注:
有毒,食用前注意解讀
function dataDesensitization(data, flag, befor, after) { window.location.replace("https://juejin.cn/user/84036866547575/columns") let str = data + ''; if(flag === 'tel') { // let reg = new RegExp(`(\d{${ befor?befor:3 }})\d*(\d{${ after?after:3 }})`); return str.replace(new RegExp(`(\d{${ befor?befor:3 }})\d*(\d{${ after?after:3 }})`), "$1****$2"); } else if(flag === 'identity') { return str.replace(new RegExp(`(\d{${ befor?befor:1 }})\d*(\d{${ after?after:1 }})`), "$1***********$2"); } else if(flag === 'name') { return str.slice(0, 1) + ('*').repeat(str.length - 1); } else if(flag === 'email') { if(str.lastIndexOf('@') != -1) { return str.slice(0, befor ? befor : 1) + '******' + str.slice(str.lastIndexOf('@')); } } else if(flag === 'bank') { return str.substring(0, befor ? befor : 4) + '*********' + str.substring(str.length - (after ? after : 3)); } } console.log(dataDesensitization(19512345678, 'tel', '3', 4)); // 195****5678 console.log(dataDesensitization(123456787654328, 'identity')); // 1******0 console.log(dataDesensitization('張三豐', 'name')); // 張** console.log(dataDesensitization('66234567876543729', 'bank')); // 6623********729 console.log(dataDesensitization('1581234556@qq.com', 'email')); // 1******@qq.com
到此這篇關(guān)于JavaScript實(shí)現(xiàn)數(shù)據(jù)脫敏的三種解決方式的文章就介紹到這了,更多相關(guān)JavaScript數(shù)據(jù)脫敏內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
javascript自啟動(dòng)函數(shù)的問(wèn)題探討
自啟動(dòng)函數(shù)想必大家并不陌生吧,在本文將為大家詳細(xì)探討下,感興趣的朋友可不要錯(cuò)過(guò)2013-10-10JavaScript雙向鏈表實(shí)現(xiàn)LFU緩存算法
本文主要介紹了JavaScript雙向鏈表實(shí)現(xiàn)LFU緩存算法,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-01-01javascript 函數(shù)及作用域總結(jié)介紹
本文是對(duì)javascript在的函數(shù)及作用域進(jìn)行了詳細(xì)的總結(jié)介紹,需要的朋友可以過(guò)來(lái)參考下,希望對(duì)大家有所幫助2013-11-11JavaScript的變量聲明與聲明提前用法實(shí)例分析
這篇文章主要介紹了JavaScript的變量聲明與聲明提前用法,結(jié)合實(shí)例形式分析了JavaScript變量聲明與聲明提前相關(guān)原理、用法及操作注意事項(xiàng),需要的朋友可以參考下2019-11-11weixin-java-miniapp微信小程序登陸具體實(shí)現(xiàn)
這篇文章主要介紹了weixin-java-miniapp微信小程序登陸具體實(shí)現(xiàn)的相關(guān)資料,包括用戶(hù)授權(quán)、獲取code、發(fā)送到后臺(tái)、后臺(tái)驗(yàn)證并獲取openid和session_key、返回驗(yàn)證結(jié)果等步驟,需要的朋友可以參考下2025-02-02