栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

用于验证姓名的正则表达式?

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

用于验证姓名的正则表达式?

我会尝试自己给出一个正确的答案:

名称中唯一应允许的标点是句号,撇号和连字符。在角落案例列表中,我还没有看到其他案例。

关于数字,只有一个8的情况。我想我可以放心地拒绝。

关于字母,任何字母都是有效的。

我也想包括空间。

这将总结为这个正则表达式:

^[p{L} .'-]+$

这提出了一个问题,即撇号可以用作攻击媒介。它应该被编码。

因此,验证代码应如下所示(未经测试):

var name = nameParam.Trim();if (!Regex.IsMatch(name, "^[p{L} .-]+$"))     throw new ArgumentException("nameParam");name = name.Replace("'", "'");  //' does not work in IE

谁能想到一个名称不能通过该测试或可能通过的XSS或SQL注入的原因?


完整的测试解决方案

using System;using System.Text.Regularexpressions;namespace test{    class MainClass    {        public static void Main(string[] args)        { var names = new string[]{"Hello World",      "John",     "João",     "タロウ",     "やまだ",     "山田",     "先生",     "мыхаыл",     "Θεοκλεια",     "आकाङ्क्षा",     "علاء الدين",     "אַבְרָהָם",     "മലയാളം",     "상",     "D'Addario",     "John-Doe",     "P.A.M.",     "' --",     "<xss>",     """ }; foreach (var nameParam in names) {     Console.Write(nameParam+" ");     var name = nameParam.Trim();     if (!Regex.IsMatch(name, @"^[p{L}p{M}' .-]+$"))     {         Console.WriteLine("fail");         continue;     }     name = name.Replace("'", "&#39;");     Console.WriteLine(name); }        }    }}


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/394121.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号