码迷,mamicode.com
首页 > 其他好文 > 详细

正则表达式\w并不完全等于[A-Za-z0-9]

时间:2017-07-31 18:51:38      阅读:125      评论:0      收藏:0      [点我收藏+]

标签:分网   min   href   注意   过滤   使用   大小写   恶作剧   介绍   

原文地址:http://blog.csdn.net/sinat_34719507/article/details/54430555

   一般大家在书本上还是网上资料正则表达式中\w都被介绍为匹配任何单词字符,包括字母和下划线,等效于[A-Za-z0-9]。
   今天偶然间发现会员注册中出现了一个恶作剧账号"аdmin",注意到那个а了没?那是一个俄文字母,在会员注册过滤中使用\w验证并不能防止。
   也就是说\w包括了英文字母以及俄文字母等,在会员注册这块我们肯定不希望类同的账号出现,要不然很容易造成会员间的误会。所以改为^[A-Za-z0-9\u4E00-\u9FA5-]{2,16}$验证,只允许数字、26个英文字母大小写、中文及其组合。
   通过网络检测发现,目前的大部分网站账号基本有此误检测的BUG,DZ的不论PHP还是net版均存在此问题。想象一下吧,一个网站已存存在一个英文会员账号“admin”,再出现一个俄文或俄文英文混合的账号,如“аdmin”,够混淆混乱吧?

正则表达式\w并不完全等于[A-Za-z0-9]

标签:分网   min   href   注意   过滤   使用   大小写   恶作剧   介绍   

原文地址:http://www.cnblogs.com/Vvvolcano/p/7264379.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!