数据脱敏(推荐)
2023-12-13 12:55:01
一、什么是数据脱敏
先来看看什么是数据脱敏?数据脱敏也叫数据的去隐私化,在我们给定脱敏规则和策略的情况下,对敏感数据比如 手机号、银行卡号 等信息,进行转换或者修改的一种技术手段,防止敏感数据直接在不可靠的环境下使用。
二、需要脱敏的数据有哪些
手机号
脱敏规则:只显示手机号的前面3位和尾号后4位,中间号码显示为‘****’
1.方法1:(正则表达式)
public static void main(String[] args) {
String phone = "18812345678";
String result1 = phone.replaceAll("(\\d{3})\\d{4}(\\d{4})", "$1****$2");
System.out.println("脱敏的手机号:" + result1);
}
结果:
2.方法2:(MySQL)
这两条SQL语句都可实现
SELECT INSERT
( mobile, 4, 4, ‘****’ )
FROM
t_user
结果:
邮箱
脱敏规则:邮箱只显示第一个字符和’@'之后的字符,第一个字符之后’@‘之前的,显示为‘****’
public static void main(String[] args) {
String email = "123456789@qq.com";
String result = email.replaceAll("(^\\w)[^@]*(@.*$)", "$1****$2");
System.out.println("脱敏的邮箱:" + result);
}
身份证号
脱敏规则:身份证号只显示前三位和后四位,其余显示为‘****’
public static void main(String[] args) {
String idCard = "30010019990101123X";
String result = idCard.replaceAll("(?<=\\w{3})\\w(?=\\w{4})", "*");
System.out.println("脱敏的身份证号:" + result);
}
银行卡号
脱敏规则:银行卡号只显示前六位和后四位,其余显示为‘****’
public static void main(String[] args) {
String bankCard = "1234561234567895678";
String result = bankCard.replaceAll("(\\d{6})\\d{9}(\\d{4})", "$1****$2");
System.out.println("脱敏的银行卡号:" + result);
}
ps: 别说交给前端去处理。 为了数据保密,既然要处理,肯定不能把未脱敏数据给到前端的。
文章来源:https://blog.csdn.net/m0_56095048/article/details/134968682
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!