隐藏手机号、邮箱等敏感信息

隐藏手机号、邮箱等敏感信息

Intro

做项目的时候,页面上有一些敏感信息,需要用“*”隐藏一些比较重要的信息,于是打算写一个通用的方法。

Let‘s do it !

Method 1:指定左右字符数量

Method 1.1 中间的*的个数和实际长度有关

 1     /// <summary>
 2     /// 隐藏敏感信息
 3     /// </summary>
 4     /// <param name="info">信息实体</param>
 5     /// <param name="left">左边保留的字符数</param>
 6     /// <param name="right">右边保留的字符数</param>
 7     /// <param name="basedOnLeft">当长度异常时,是否显示左边
 8     /// <code>true</code>显示左边,<code>false</code>显示右边
 9     /// </param>
10     /// <returns></returns>
11     public static string HideSensitiveInfo(string info, int left, int right, bool basedOnLeft=true)
12     {
13         if (String.IsNullOrEmpty(info))
14         {
15             return "";
16         }
17         StringBuilder sbText = new StringBuilder();
18         int hiddenCharCount = info.Length - left - right;
19         if (hiddenCharCount > 0)
20         {
21             string prefix = info.Substring(0, left), suffix = info.Substring(info.Length - right);
22             sbText.Append(prefix);
23             for (int i = 0; i < hiddenCharCount; i++)
24             {
25                 sbText.Append("*");
26             }
27             sbText.Append(suffix);
28         }
29         else
30         {
31             if (basedOnLeft)
32             {
33                 if (info.Length > left && left > 0)
34                 {
35                     sbText.Append(info.Substring(0, left) + "****");
36                 }
37                 else
38                 {
39                     sbText.Append(info.Substring(0, 1) + "****");
40                 }
41             }
42             else
43             {
44                 if (info.Length > right && right > 0)
45                 {
46                     sbText.Append("****" + info.Substring(info.Length - right));
47                 }
48                 else
49                 {
50                     sbText.Append("****" + info.Substring(info.Length - 1));
51                 }
52             }
53         }
54         return sbText.ToString();
55     }
 

Method 1.2 : 中间的*的个数固定

 1     /// <summary>
 2     /// 隐藏敏感信息
 3     /// </summary>
 4     /// <param name="info">信息实体</param>
 5     /// <param name="left">左边保留的字符数</param>
 6     /// <param name="right">右边保留的字符数</param>
 7     /// <param name="basedOnLeft">当长度异常时,是否显示左边
 8     /// <code>true</code>显示左边,<code>false</code>显示右边
 9     /// <returns></returns>
10     public static string HideSensitiveInfo1(string info, int left, int right, bool basedOnLeft = true)
11     {
12         if (String.IsNullOrEmpty(info))
13         {
14             return "";
15         }
16         StringBuilder sbText = new StringBuilder();
17         int hiddenCharCount = info.Length - left - right;
18         if (hiddenCharCount > 0)
19         {
20             string prefix = info.Substring(0, left), suffix = info.Substring(info.Length - right);
21             sbText.Append(prefix);
22             sbText.Append("****");
23             sbText.Append(suffix);
24         }
25         else
26         {
27             if (basedOnLeft)
28             {
29                 if (info.Length > left && left >0)
30                 {
31                     sbText.Append(info.Substring(0, left) + "****");
32                 }
33                 else
34                 {
35                     sbText.Append(info.Substring(0, 1) + "****");
36                 }
37             }
38             else
39             {
40                 if (info.Length > right && right>0)
41                 {
42                     sbText.Append("****" + info.Substring(info.Length - right));
43                 }
44                 else
45                 {
46                     sbText.Append("****" + info.Substring(info.Length - 1));
47                 }
48             }
49         }
50         return sbText.ToString();
51     }

Method 2 : “*”数量一定,设置为4个,按信息总长度的比例来取,默认左右各取1/3

 1     /// <summary>
 2     /// 隐藏敏感信息
 3     /// </summary>
 4     /// <param name="info">信息</param>
 5     /// <param name="sublen">信息总长与左子串(或右子串)的比例</param>
 6     /// <param name="basedOnLeft">当长度异常时,是否显示左边,默认true,默认显示左边
 7     /// <code>true</code>显示左边,<code>false</code>显示右边
 8     /// <returns></returns>
 9     public static string HideSensitiveInfo(string info,int sublen = 3,bool basedOnLeft = true)
10     {
11         if (String.IsNullOrEmpty(info))
12         {
13             return "";
14         }
15         if (sublen<=1)
16         {
17             sublen = 3;
18         }
19         int subLength = info.Length / sublen;
20         if (subLength > 0 && info.Length > (subLength*2) )
21         {
22             string prefix = info.Substring(0, subLength), suffix = info.Substring(info.Length - subLength);
23             return prefix + "****" + suffix;
24         }
25         else
26         {
27             if (basedOnLeft)
28             {
29                 string prefix = subLength > 0 ? info.Substring(0, subLength) : info.Substring(0, 1);
30                 return prefix + "****";
31             }
32             else
33             {
34                 string suffix = subLength > 0 ? info.Substring(info.Length-subLength) : info.Substring(info.Length-1);
35                 return "****"+suffix;
36             }
37         }
38     }

扩展

手机号 1

 1     /// <summary>
 2     /// 隐藏手机号详情
 3     /// </summary>
 4     /// <param name="phone">手机号</param>
 5     /// <param name="left">左边保留字符数</param>
 6     /// <param name="right">右边保留字符数</param>
 7     /// <returns></returns>
 8     public static string HideTelDetails(string phone, int left = 3, int right = 4)
 9     {
10         return HideSensitiveInfo(phone, left, right);
11     }

测试结果如下:

手机号 2

 1     /// <summary>
 2     /// 隐藏手机号详情
 3     /// </summary>
 4     /// <param name="phone">手机号</param>
 5     /// <param name="left">左边保留字符数</param>
 6     /// <param name="right">右边保留字符数</param>
 7     /// <returns></returns>
 8     public static string HideTelDetails(string phone, int left = 3, int right = 4)
 9     {
10         return HideSensitiveInfo1(phone, left, right);
11     }

测试结果如下:

邮件地址

 1     /// <summary>
 2     /// 隐藏右键详情
 3     /// </summary>
 4     /// <param name="email">邮件地址</param>
 5     /// <param name="left">邮件头保留字符个数,默认值设置为3</param>
 6     /// <returns></returns>
 7     public static string HideEmailDetails(string email, int left = 3)
 8     {
 9         if (String.IsNullOrEmpty(email))
10         {
11             return "";
12         }
13         if (System.Text.RegularExpressions.Regex.IsMatch(email, @"\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*"))//如果是邮件地址
14         {
15             int suffixLen =email.Length - email.LastIndexOf(‘@‘);
16             return HideSensitiveInfo(email, left, suffixLen,false);
17         }
18         else
19         {
20             return HideSensitiveInfo(email);
21         }
22     }

测试结果如下:

时间: 2024-11-06 20:54:14

隐藏手机号、邮箱等敏感信息的相关文章

nagios_自定义宏变量隐藏发送邮件账号的敏感信息

需求: Nagios在邮件告警的时候使用sendemail来发送邮件. 默认web管理界面下Configuration -->  Object Type: Commands --> notify-host-by-email  notify-service-by-email 会显示 发送邮件账户的登录密码 通过:nagios的宏变量来隐藏掉显示出来的密码(自定义宏变量) vi /usr/local/nagios/etc/resource.cfg 加上 [email protected] $USE

Apache隐藏版本号及其它敏感信息

默认显示 修改后显示 1. 隐藏Apache信息 1.1 主配置中启用httpd-default.conf文件: conf/httpd.Conf找到httpd-default.conf,删除前面的注释"#",改成如下 Include conf/extra/httpd-default.conf 1.2 修改httpd-default.conf文件:conf/extra/httpd-default.conf找到 ServerTokens Full 改成 ServerTokens Prod

apache 隐藏版本信息隐藏敏感信息

如果我们想隐藏apache的版本信息,或者隐藏apache的敏感信息需要我们在编译之前对以下文件进行修改:(我们以apache的2.2.27版本为列) vim /usr/local/tools/httpd-2.2.27/include/ap_release.h #define AP_SERVER_BASEPRODUCT "Apache"                   改成  Microsoft-IIS 下面标红的是指的apache的版本信息,我们可以做相对应的修改#define

DotNet隐藏敏感信息操作方法

在项目中,有时候一些信息不便完全显示,只需要显示部分信息.现在提供一些隐藏敏感信息的操作方法,主要为对信息的截取操作: 1.指定左右字符数量,中间的*的个数和实际长度有关:         /// <summary>         /// 隐藏敏感信息         /// </summary>         /// <param name="info">信息实体</param>         /// <param name

Web应用程序的敏感信息-隐藏目录和文件

Web应用程序的敏感信息-隐藏目录和文件 0x1.场景 Web应用程序根文件夹中可能存在大量隐藏信息:源代码版本系统文件夹和文件(.git,.gitignore,.svn),项目配置文件(.npmrc,package.json,.htaccess),自定义配置文件使用config.json,config.yml,config.xml等常见扩展以及许多其他扩展. 资源可以分为几个常见类别: 源代码版本控制系统 IDE(集成开发环境)配置文件 项目和/或技术特定的配置和设置文件 1.1.GIT Gi

使用jni技术进行android应用签名信息核查及敏感信息保护

最近业余时间写了一款应用<摇啊摇>,安智.安卓.360等几个应用商店已经陆续审核通过并上线.从有想法到最终将产品做出来并发布,断断续续花了近二个半月的业余时间,总体来讲还算顺利,虽然期间也遇到几个小技术难点,最后解决的还算满意.今天说下其中一个小技术难点,现在想想这个小技术难点也很平常,但还是分享出来,希望对有相同疑惑的同学有帮助. 因为java语言自身特性的原因,导致android程序很容易被反编译,虽然可以采用代码混淆的方式,但是如果用了第三方库,混淆脚步编写不好,代码混淆后又会出现程序运

1. 敏感信息泄露

软件敏感信息 * 操作系统版本 可用namp扫描得知 * 中间件的类型.版本 http返回头 404报错页面 使用工具(如whatweb) * Web程序(cms类型及版本.敏感文件) 可用whatweb.cms_identify Web敏感信息 * phpinfo()信息泄漏 http://[ip]/test.php和http://[ip]/phpinfo.php * 测试页面泄漏在外网 test.cgi.phpinfo.php.info.php等 * 编辑器备份文件泄漏在外网 http://

Django项目敏感信息保存

在我们做完django项目后,向生产环境部署时,为了避免一些敏感信息被有心人利用,我们应该将其保护起来,比如说在settings配置中的一些密码等内容存在操作系统内,通过调用来使用,比如下面这种做法: 拿Django中的SECRET_KEY来说吧,其余如同数据库密码.邮箱密码等秘密内容都可以使用这种方式将其贮存在操作系统中.我使用的是python语言,这里要使用到python的os内置模块: os模块:官方定义:This module provides a portable way of usi

logstash 对配置文件conf敏感信息,密码等加密

logstash的配置文件conf经常会涉及敏感信息,比如ES,mysql的账户密码等,以下使用logstash导入mysql为例子,加密隐藏mysql的密码. 在向keystore中添加key及其secret值之后,你可以在配置敏感设置时使用key代替secret值. 引用key的语法与环境变量的语法相同:${KEY},KEY是key的名称. 例如,假设keystore包含一个名为ES_PWD的key,其值为yourelasticsearchpassword: 在配置文件中使用:output