Java常用的數(shù)據(jù)脫敏方法(手機(jī)、郵箱、身份證號(hào))
一、什么是數(shù)據(jù)脫敏
先來看看什么是數(shù)據(jù)脫敏?數(shù)據(jù)脫敏也叫數(shù)據(jù)的去隱私化,在我們給定脫敏規(guī)則和策略的情況下,對(duì)敏感數(shù)據(jù)比如 手機(jī)號(hào)、銀行卡號(hào) 等信息,進(jìn)行轉(zhuǎn)換或者修改的一種技術(shù)手段,防止敏感數(shù)據(jù)直接在不可靠的環(huán)境下使用。
二、需要脫敏的數(shù)據(jù)有哪些
手機(jī)號(hào)
脫敏規(guī)則:只顯示手機(jī)號(hào)的前面3位和尾號(hào)后4位,中間號(hào)碼顯示為‘****’
1.方法1:(正則表達(dá)式)
public static void main(String[] args) { String phone = "18812345678"; String result1 = phone.replaceAll("(\\d{3})\\d{4}(\\d{4})", "$1****$2"); System.out.println("脫敏的手機(jī)號(hào):" + result1); }
結(jié)果:
2.方法2:(MySQL)
這兩條SQL語(yǔ)句都可實(shí)現(xiàn)
SELECT INSERT ( mobile, 4, 4, '****' ) FROM t_user
結(jié)果:
郵箱
脫敏規(guī)則:郵箱只顯示第一個(gè)字符和'@'之后的字符,第一個(gè)字符之后’@‘之前的,顯示為‘****’
public static void main(String[] args) { String email = "123456789@qq.com"; String result = email.replaceAll("(^\\w)[^@]*(@.*$)", "$1****$2"); System.out.println("脫敏的郵箱:" + result); }
身份證號(hào)
脫敏規(guī)則:身份證號(hào)只顯示前三位和后四位,其余顯示為‘****’
public static void main(String[] args) { String idCard = "30010019990101123X"; String result = idCard.replaceAll("(?<=\\w{3})\\w(?=\\w{4})", "*"); System.out.println("脫敏的身份證號(hào):" + result); }
銀行卡號(hào)
脫敏規(guī)則:銀行卡號(hào)只顯示前六位和后四位,其余顯示為‘****’
public static void main(String[] args) { String bankCard = "1234561234567895678"; String result = bankCard.replaceAll("(\\d{6})\\d{9}(\\d{4})", "$1****$2"); System.out.println("脫敏的銀行卡號(hào):" + result); }
ps: 別說交給前端去處理。 為了數(shù)據(jù)保密,既然要處理,肯定不能把未脫敏數(shù)據(jù)給到前端的。
附:以下工具類是對(duì)字符、姓名、郵箱、手機(jī)、固定電話,銀行卡號(hào)、地址、公司開戶銀行聯(lián)號(hào)、身份證號(hào)進(jìn)行脫敏處理
1、脫敏工具類:
package cn.hsa.utils; import cn.hutool.core.util.StrUtil; import org.apache.commons.lang3.StringUtils; /** * 信息脫敏工具類 **/ public class DataMaskingUtils { /** * 字符脫敏. * * @param str the str * @param pre the pre 前幾位 * @param suf the suf 后幾位 * @return the string */ public static String strMasking(String str, int pre, int suf) { if (StrUtil.isBlank(str)) { return str; } if (pre <= 0 && suf <= 0) { return str; } int len = str.length(); if (len > (pre + suf)) { return StrUtil.subPre(str, pre) + StrUtil.fill("", '*', len - pre - suf, false) + StrUtil.subSufByLength(str, suf); } else if (len > pre && pre > 0) { return StrUtil.subPre(str, pre) + StrUtil.fill("", '*', len - pre, false); } else if (len > suf && suf > 0) { return StrUtil.fill("", '*', len - suf, false) + StrUtil.subSufByLength(str, suf); } else { return StrUtil.fill("", '*', len, false); } } /** * [中文姓名] 只顯示第一個(gè)漢字,其他隱藏為星號(hào)<例子:李**> * * @param fullName 姓名 * @return */ public static String chineseName(String fullName) { if (StringUtils.isBlank(fullName)) { return ""; } String name = StringUtils.left(fullName, 1); return StringUtils.rightPad(name, StringUtils.length(fullName), "*"); } /** * [中文姓名] 只顯示姓氏,其他隱藏為星號(hào)<例子:歐陽(yáng)娜娜 : 歐陽(yáng)**> * * @param familyName 姓氏 * @param givenName 名字 * @return */ public static String chineseName(String familyName, String givenName) { if (StringUtils.isBlank(familyName) || StringUtils.isBlank(givenName)) { return ""; } if (familyName.length() > 1) { String name = StringUtils.left(familyName, familyName.length()); return StringUtils.rightPad(name, StringUtils.length(familyName + givenName), "*"); } return chineseName(familyName + givenName); } /** * [身份證號(hào)] 顯示最后四位,其他隱藏。共計(jì)18位或者15位。<例子:*************5762> * * @param id * @return */ public static String idCardNum(String id) { if (StringUtils.isBlank(id)) { return ""; } String num = StringUtils.right(id, 4); return StringUtils.leftPad(num, StringUtils.length(id), "*"); } /** * [身份證號(hào)] 前六位,后四位,其他用星號(hào)隱藏每位1個(gè)星號(hào)<例子:451002********1647> * * @param carId * @return */ public static String idCard(String carId) { if (StringUtils.isBlank(carId)) { return ""; } return StringUtils.left(carId, 6).concat(StringUtils.removeStart(StringUtils.leftPad(StringUtils.right(carId, 4), StringUtils.length(carId), "*"), "******")); } /** * [固定電話] 后四位,其他隱藏<例子:****1234> * * @param num * @return */ public static String fixedPhone(String num) { if (StringUtils.isBlank(num)) { return ""; } return StringUtils.leftPad(StringUtils.right(num, 4), StringUtils.length(num), "*"); } /** * [手機(jī)號(hào)碼] 前三位,后四位,其他隱藏<例子:138******1234> * * @param num * @return */ public static String mobilePhone(String num) { if (StringUtils.isBlank(num)) { return ""; } return StringUtils.left(num, 3).concat(StringUtils.removeStart(StringUtils.leftPad(StringUtils.right(num, 4), StringUtils.length(num), "*"), "***")); } /** * [地址] 只顯示到地區(qū),不顯示詳細(xì)地址;我們要對(duì)個(gè)人信息增強(qiáng)保護(hù)<例子:北京市海淀區(qū)****> * * @param address * @param sensitiveSize 敏感信息長(zhǎng)度 * @return */ public static String address(String address, int sensitiveSize) { if (StringUtils.isBlank(address)) { return ""; } int length = StringUtils.length(address); return StringUtils.rightPad(StringUtils.left(address, length - sensitiveSize), length, "*"); } /** * [電子郵箱] 郵箱前綴僅顯示第一個(gè)字母,前綴其他隱藏,用星號(hào)代替,@及后面的地址顯示<例子:g**@163.com> * * @param email * @return */ public static String email(String email) { if (StringUtils.isBlank(email)) { return ""; } int index = StringUtils.indexOf(email, "@"); if (index <= 1) { return email; } return StringUtils.rightPad(StringUtils.left(email, 1), index, "*").concat(StringUtils.mid(email, index, StringUtils.length(email))); } /** * [銀行卡號(hào)] 前六位,后四位,其他用星號(hào)隱藏每位1個(gè)星號(hào)<例子:6222600**********1234> * * @param cardNum * @return */ public static String bankCard(String cardNum) { if (StringUtils.isBlank(cardNum)) { return ""; } return StringUtils.left(cardNum, 6).concat(StringUtils.removeStart(StringUtils.leftPad(StringUtils.right(cardNum, 4), StringUtils.length(cardNum), "*"), "******")); } /** * [公司開戶銀行聯(lián)號(hào)] 公司開戶銀行聯(lián)行號(hào),顯示前兩位,其他用星號(hào)隱藏,每位1個(gè)星號(hào)<例子:12********> * * @param code * @return */ public static String cnapsCode(String code) { if (StringUtils.isBlank(code)) { return ""; } return StringUtils.rightPad(StringUtils.left(code, 2), StringUtils.length(code), "*"); } }
2、測(cè)試工具類:
package cn.hsa.utils; /** * @Description: 信息脫敏測(cè)試 */ public class MaskingUtilsTest { public static void main(String[] args) { //中文名脫敏 String s1 = DataMaskingUtils.chineseName("歐陽(yáng)娜娜"); //歐*** String s2 = DataMaskingUtils.chineseName("歐陽(yáng)", "娜娜");//歐陽(yáng)** //字符脫敏 String s3 = DataMaskingUtils.strMasking("信息脫敏工具類測(cè)試字符脫敏", 4, 2); String s4 = DataMaskingUtils.strMasking("字符脫敏", 5, 2); String s5 = DataMaskingUtils.strMasking("字符脫敏", 2, 3); String s6 = DataMaskingUtils.strMasking("字符脫敏", 3, 3); //[身份證號(hào)] 脫敏 后四位其他隱藏 String s7 = DataMaskingUtils.idCardNum("430903199909093412"); //[身份證號(hào)]脫敏 前六位,后四位,其他用隱藏 String s8 = DataMaskingUtils.idCard("430903199909093412"); //[固定電話] 后四位,其他隱藏 String s9 = DataMaskingUtils.fixedPhone("13077098909"); //[手機(jī)號(hào)碼] 前三位,后四位,其他隱藏<例子:138******1234> String s10 = DataMaskingUtils.mobilePhone("13879081234"); //[地址] 只顯示到地區(qū),不顯示詳細(xì)地址 String s11 = DataMaskingUtils.address("北京市豐臺(tái)區(qū)蓮花池東路118號(hào)", 10); //[電子郵箱] 郵箱前綴僅顯示第一個(gè)字母 String s12 = DataMaskingUtils.email("zhangsan123@163.com"); //[銀行卡號(hào)] 前六位,后四位,其他用星號(hào)隱藏每位1個(gè)星號(hào) String s13 = DataMaskingUtils.bankCard("622260011111111111234"); //[公司開戶銀行聯(lián)號(hào)] 公司開戶銀行聯(lián)行號(hào),顯示前兩位,其他用星號(hào)隱藏,每位1個(gè)星號(hào) String s14 = DataMaskingUtils.cnapsCode("6222600111111111234"); } }
3、測(cè)試結(jié)果:
總結(jié)
到此這篇關(guān)于Java常用的數(shù)據(jù)脫敏方法(手機(jī)、郵箱、身份證號(hào))的文章就介紹到這了,更多相關(guān)Java數(shù)據(jù)脫敏內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
SpringDataJpa:JpaRepository增刪改查操作
這篇文章主要介紹了SpringDataJpa:JpaRepository增刪改查操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-08-08Springboot 全局時(shí)間格式化三種方式示例詳解
時(shí)間格式化在項(xiàng)目中使用頻率是非常高的,當(dāng)我們的 API? 接口返回結(jié)果,需要對(duì)其中某一個(gè) date? 字段屬性進(jìn)行特殊的格式化處理,通常會(huì)用到 SimpleDateFormat? 工具處理,這篇文章主要介紹了3 種 Springboot 全局時(shí)間格式化方式,需要的朋友可以參考下2024-01-01JavaMail實(shí)現(xiàn)郵件發(fā)送機(jī)制
這篇文章主要為大家詳細(xì)介紹了JavaMail實(shí)現(xiàn)郵件發(fā)送機(jī)制,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-08-08