亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

JavaScript實(shí)現(xiàn)數(shù)據(jù)脫敏的三種解決方式

 更新時(shí)間:2024年11月22日 08:45:14   作者:加油樂(lè)  
這篇文章主要為大家詳細(xì)介紹了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)文章

  • JS實(shí)現(xiàn)霓虹燈文字效果的方法

    JS實(shí)現(xiàn)霓虹燈文字效果的方法

    這篇文章主要介紹了JS實(shí)現(xiàn)霓虹燈文字效果的方法,涉及javascript遍歷字符串及頁(yè)面樣式的動(dòng)態(tài)操作技巧,效果非常炫目華麗,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-08-08
  • javascript自啟動(dòng)函數(shù)的問(wèn)題探討

    javascript自啟動(dòng)函數(shù)的問(wèn)題探討

    自啟動(dòng)函數(shù)想必大家并不陌生吧,在本文將為大家詳細(xì)探討下,感興趣的朋友可不要錯(cuò)過(guò)
    2013-10-10
  • JavaScript數(shù)組去重的多種方法(四種)

    JavaScript數(shù)組去重的多種方法(四種)

    數(shù)組去重,一般需求是給你一個(gè)數(shù)組,調(diào)用去重方法,返回?cái)?shù)值副本,副本中沒(méi)有重復(fù)元素。下面腳本之家小編給大家?guī)?lái)了js數(shù)組去重的多種方法,非常不錯(cuò),需要的朋友參考下
    2017-09-09
  • JavaScript雙向鏈表實(shí)現(xiàn)LFU緩存算法

    JavaScript雙向鏈表實(shí)現(xiàn)LFU緩存算法

    本文主要介紹了JavaScript雙向鏈表實(shí)現(xiàn)LFU緩存算法,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-01-01
  • Javascript數(shù)組常用方法你都知道嗎

    Javascript數(shù)組常用方法你都知道嗎

    這篇文章主要為大家詳細(xì)介紹了Javascript數(shù)組常用方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助
    2022-02-02
  • javascript 函數(shù)及作用域總結(jié)介紹

    javascript 函數(shù)及作用域總結(jié)介紹

    本文是對(duì)javascript在的函數(shù)及作用域進(jìn)行了詳細(xì)的總結(jié)介紹,需要的朋友可以過(guò)來(lái)參考下,希望對(duì)大家有所幫助
    2013-11-11
  • ts中的void和never類(lèi)型及區(qū)別

    ts中的void和never類(lèi)型及區(qū)別

    void類(lèi)型和never類(lèi)型都是ts新增的類(lèi)型,這兩者的共同點(diǎn)是都常見(jiàn)用于聲明函數(shù)的返回值的類(lèi)型,這里我們把它們兩放在一起介紹有助于大家區(qū)分,這篇文章主要介紹了ts中的void和never類(lèi)型及區(qū)別,需要的朋友可以參考下
    2023-05-05
  • 在HTML代碼中使用JavaScript代碼的例子

    在HTML代碼中使用JavaScript代碼的例子

    這篇文章主要介紹了在HTML代碼中使用JavaScript代碼的例子,本文是入門(mén)級(jí)示例,初學(xué)js的同學(xué)不要錯(cuò)過(guò),需要的朋友可以參考下
    2014-10-10
  • JavaScript的變量聲明與聲明提前用法實(shí)例分析

    JavaScript的變量聲明與聲明提前用法實(shí)例分析

    這篇文章主要介紹了JavaScript的變量聲明與聲明提前用法,結(jié)合實(shí)例形式分析了JavaScript變量聲明與聲明提前相關(guān)原理、用法及操作注意事項(xiàng),需要的朋友可以參考下
    2019-11-11
  • weixin-java-miniapp微信小程序登陸具體實(shí)現(xiàn)

    weixin-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

最新評(píng)論