C#实现隐藏手机号、邮箱、姓名等敏感信息扩展方法
还是老惯例,直接上代码。
最终效果图:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 | public static class HideSensitiveInfoExtension { /// <summary> /// 隐藏敏感信息 /// </summary> /// <param name="info">信息实体</param> /// <param name="left">左边保留的字符数</param> /// <param name="right">右边保留的字符数</param> /// <param name="basedOnLeft">当长度异常时,是否显示左边 </param> /// <returns></returns> public static string HideSensitiveInfo( this string info, int left, int right, bool basedOnLeft = true ) { if (String.IsNullOrEmpty(info)) { return "" ; } StringBuilder sbText = new StringBuilder(); int hiddenCharCount = info.Length - left - right; if (hiddenCharCount > 0) { string prefix = info.Substring(0, left), suffix = info.Substring(info.Length - right); sbText.Append(prefix); for ( int i = 0; i < hiddenCharCount; i++) { sbText.Append( "*" ); } sbText.Append(suffix); } else { if (basedOnLeft) { if (info.Length > left && left > 0) { sbText.Append(info.Substring(0, left) + "****" ); } else { sbText.Append(info.Substring(0, 1) + "****" ); } } else { if (info.Length > right && right > 0) { sbText.Append( "****" + info.Substring(info.Length - right)); } else { sbText.Append( "****" + info.Substring(info.Length - 1)); } } } return sbText.ToString(); } /// <summary> /// 隐藏敏感信息 /// </summary> /// <param name="info">信息</param> /// <param name="sublen">信息总长与左子串(或右子串)的比例</param> /// <param name="basedOnLeft">当长度异常时,是否显示左边,默认true,默认显示左边</param> /// <code>true</code>显示左边,<code>false</code>显示右边 /// <returns></returns> public static string HideSensitiveInfo( this string info, int sublen = 3, bool basedOnLeft = true ) { if (String.IsNullOrEmpty(info)) { return "" ; } if (sublen <= 1) { sublen = 3; } int subLength = info.Length / sublen; if (subLength > 0 && info.Length > (subLength * 2)) { string prefix = info.Substring(0, subLength), suffix = info.Substring(info.Length - subLength); return prefix + "****" + suffix; } else { if (basedOnLeft) { string prefix = subLength > 0 ? info.Substring(0, subLength) : info.Substring(0, 1); return prefix + "****" ; } else { string suffix = subLength > 0 ? info.Substring(info.Length - subLength) : info.Substring(info.Length - 1); return "****" + suffix; } } } /// <summary> /// 隐藏邮件详情 /// </summary> /// <param name="email">邮件地址</param> /// <param name="left">邮件头保留字符个数,默认值设置为3</param> /// <returns></returns> public static string HideEmailDetails( this string email, int left = 3) { if (String.IsNullOrEmpty(email)) { return "" ; } if (System.Text.RegularExpressions.Regex.IsMatch(email, @"\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*" )) //如果是邮件地址 { int suffixLen = email.Length - email.LastIndexOf( '@' ); return HideSensitiveInfo(email, left, suffixLen, false ); } else { return HideSensitiveInfo(email); } } } |
作 者:大師兄丶
出 处:http://www.cnblogs.com/zhao-yi
Git 地 址:https://github.com/ZhaoYis
个人博客:http://www.zhaoyis.com.cn
关于作者:主要从事基于.Net Framework平台的项目开发。如有问题或建议,请多多赐教!
版权声明:本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文链接。
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角推荐一下。您的鼓励是作者坚持原创和持续写作的最大动力!
出 处:http://www.cnblogs.com/zhao-yi
Git 地 址:https://github.com/ZhaoYis
个人博客:http://www.zhaoyis.com.cn
关于作者:主要从事基于.Net Framework平台的项目开发。如有问题或建议,请多多赐教!
版权声明:本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文链接。
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角推荐一下。您的鼓励是作者坚持原创和持续写作的最大动力!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构