所以,我知道我需要一个正则表达式来使用preg_match()
。
documentation for preg_match()
表示如果偏移量长于字符串长度,函数将返回false或false-ish。我将文档解释为意味着如果没有匹配则返回false。
我对正则表达式很糟糕,但在阅读了它们之后on this site我尝试编写一个能够完成我需要的功能。它不起作用。
我有以下代码段:
if (preg_match('/^[a-zA-Z0-9_]+/', $requested_table_name) === false) {
echo "Invalid String";
} else {
echo "You're golden, Ponyboy";
}
如果我理解正确的反斜杠开始和结束正则表达式,克拉会告诉表达式从字符串的开头开始。字符类表示匹配小写字母,大写字母,数字或下划线的字符,然后+
符号表示将该字符集与整个字符串匹配,而不仅仅是第一个字符字符串。
我必须弄错,因为我的程序输出表明无论输入如何,字符串都是有效的。
我的代码的问题是使用preg_match()
函数还是正则表达式的语法?在任何一种情况下,具体问题是什么,我该如何解决?
答案 0 :(得分:1)
您使用正则表达式在正确的路径上。您正尝试删除任何不需要的字符,因此请查看preg_replace。
有些评论提到像\w
这样的缩写词,与单个字母,数字或下划线相匹配。还有\W
(大写)匹配任何不是字母,数字或下划线的单个字符。
这将做你想做的事:$sanitized_input = preg_replace("/\W/", "", $input);
或者,如果不使用速记,请注意^
否定[class]
中的字符:$sanitized_input = preg_replace("/[^a-zA-Z0-9_]/", "", $input);
请务必检查preg_replace
返回的内容是否符合要求(例如,检查失败时null
)。
答案 1 :(得分:1)
你的正斜杠是分隔线。 ^
确实说start of string
。 [a-zA-Z0-9_]+
会列出您想要允许的字符,一次或多次。然而,经过一次或多次,你允许任何东西,例如A!
有效,因为它以A
开头。如果您锚定该表达式,您将确保只允许这些字符。
=== false
不正确,因为返回时间为0
,或1
,而不是false
。
演示(错误检查,尚未回答):
<?php
$string = 'asdf2341234_';
$return = preg_match('/^[a-zA-Z0-9_]+$/', $string);
if ($return === false){
echo 'is false';
} else {
echo 'not false';
}
var_dump($return);
所以你的正则表达式应该是......
if (!preg_match('/^\w+$/', $string)) {
echo "Invalid String" . $string . "\n";
} else {
echo "You're golden, Ponyboy" . $string . "\n";
}
...或
if (!preg_match('/^[a-zA-Z0-9_]+$/', $string)) {
echo "Invalid String" . $string . "\n";
} else {
echo "You're golden, Ponyboy" . $string . "\n";
}
...或
if (!preg_match('/^[a-z\d_]+$/i', $string)) {
echo "Invalid String" . $string . "\n";
} else {
echo "You're golden, Ponyboy" . $string . "\n";
}
您可以在regex101.com上测试正则表达式。它为您输入的所有内容提供了解释。