ホームページ > バックエンド開発 > PHPチュートリアル > php 5.3.5 preg_match BUG!解决方法

php 5.3.5 preg_match BUG!解决方法

WBOY
リリース: 2016-06-13 11:16:03
オリジナル
1061 人が閲覧しました

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 までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート