欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時間:2024年11月22日 08:45:14   作者:加油樂  
這篇文章主要為大家詳細介紹了JavaScript實現(xiàn)數(shù)據(jù)脫敏的三種解決方式,包括電話、姓名、郵箱、身份證等,有需要的小伙伴可以參考一下

一、前言

使用字符串操作技巧如正則表達式對手機號和身份證號進行星號替換,實現(xiàn)數(shù)據(jù)隱私保護。

二、解決方式

slice()實現(xiàn)

let str = '15656781234'
let enStr = str.slice(0,3) + '****' + str.slice(str.length - 4)
console.log(enStr) // 156****1234

substring()實現(xiàn)

let str = '15656781234'
let enStr = str.substring(0,3) + '****' + str.substring(str.length - 4)
console.log(enStr) // 156****1234

正則實現(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

三、簡單封裝及代碼解析

說明

處理電話號碼、身份證號碼、姓名、郵箱地址和銀行卡號等數(shù)據(jù)類型的脫敏需求。

參數(shù)說明

data: 需要脫敏的數(shù)據(jù),可以是字符串或數(shù)字,盡量處理成字符串,避免丟失精度。

flag: 指定數(shù)據(jù)類型,用于選擇不同的脫敏策略。支持的值包括:

  • 'tel': 電話號碼
  • 'identity': 身份證號碼
  • 'name': 姓名
  • 'email': 郵箱地址
  • 'bank': 銀行卡號

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

到此這篇關于JavaScript實現(xiàn)數(shù)據(jù)脫敏的三種解決方式的文章就介紹到這了,更多相關JavaScript數(shù)據(jù)脫敏內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

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

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

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

    javascript自啟動函數(shù)的問題探討

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

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

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

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

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

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

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

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

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

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

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

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

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

    JavaScript的變量聲明與聲明提前用法實例分析

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

    weixin-java-miniapp微信小程序登陸具體實現(xiàn)

    這篇文章主要介紹了weixin-java-miniapp微信小程序登陸具體實現(xiàn)的相關資料,包括用戶授權、獲取code、發(fā)送到后臺、后臺驗證并獲取openid和session_key、返回驗證結(jié)果等步驟,需要的朋友可以參考下
    2025-02-02

最新評論