> 백엔드 개발 > PHP 튜토리얼 > php 5.3.5 preg_match BUG!解决方法

php 5.3.5 preg_match BUG!解决方法

WBOY
풀어 주다: 2016-06-13 11:16:03
원래의
1060명이 탐색했습니다.

php 5.3.5 preg_match BUG!!!
//环境 window+php3.35+apache2.2
今天在写 用正则验证用户名的时候,中文,英文都没有问题

可是 用这个字注册的时候就除了问题

echo preg_match("/[\'\"\ \ ]/","净");

//文件是utf-8的 也设置了header("Content-type:text/html;charset=utf-8");


正常情况下,应该输出0,对吧,可是竟然输出为1,大家可以试一下!

还有这个问题怎么解决呢!

php regexp reglur regular
------解决方案--------------------
有 BUG 并不奇怪!正因为如此,php 才建议你升级到 5.3.22 或 5.4.12

不过你说的BUG并不存在
正则规则串的 [] 中的是单字符列表,而全角的空格是多字符
你至少需要有 u 修饰符
echo preg_match("/[\'\"\ \ ]/u","净");

------解决方案--------------------
问题出在  [\'\"\ \ ] ,最后一个空白是一个多字节字符  %E3%80%80
而 净 字的编码为 %E5%87%80
这两个之间有 80 为重复的,所以会匹配到相同的字节
------解决方案--------------------
引用:
问题出在  [\'\"\ \ ] ,最后一个空白是一个多字节字符  %E3%80%80
而 净 字的编码为 %E5%87%80
这两个之间有 80 为重复的,所以会匹配到相同的字节


+1
不加unicode修正符就按字节匹配
所以%80 bingo!
------解决方案--------------------
引用:
百度了一下,u是贪婪模式,能解释一下为什么吗?

还有为什么别的中文字符没有出错,唯独这个"净"字呢?

你有错了!U 是贪婪模式开关
而 u 是 utf-8 修正模式。在此模式下,任何 utf-8 字符都当做一个字节处理
관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿