在 PCRE/PHP 中解码 Unicode 字母匹配难题
开发人员在 PHP 中使用 PCRE 验证名称时遇到困难,特别是非 ASCII Ă 或张等字符。他们的初始模式“/^([p{L}'- ]) $/”未能捕获这些字符,导致人们怀疑模式或输入处理可能是罪魁祸首。
To弄清楚问题,让我们检查一下模式。 p{L} 是任何 Unicode 字母的 Unicode 字符属性简写。但是,它需要 UTF-8 模式才能正常运行。默认情况下,PHP 在区分大小写的非 Unicode 模式下运行。
事实证明,开发人员忽略了在其模式中指定“u”修饰符。此修饰符启用 Unicode 支持,允许 p{L} 等字符属性按预期工作。
要解决此问题,请更新模式:
$namePattern = '/^[-\' \p{L}]+$/u';
通过添加“u”修饰符,该模式现在可以准确匹配 Unicode 字母字符,包括非 ASCII 字母表中的字符,确保成功验证包含 Ă 和 张 等字符的名称。
以上是为什么我的 PCRE 模式与 PHP 中的 Unicode 字母不匹配?的详细内容。更多信息请关注PHP中文网其他相关文章!