PHP $_POST 用户名卫生 - 这怎么不行
我已经用谷歌搜索并搜索了所有内容,但我无法找到答案。
为什么下面的 PHP 代码让加号通过:(
$aValid = array('-', '_', '.');
if (ctype_alnum(str_replace($aValid, '', $_POST['Rusername']))){
如果用户输入 1234+,它会继续有效???)。
我通常会找到一个旁路,但这真的有必要吗?
$aValid = array('-', '_', '.');
if (ctype_alnum(str_replace($aValid, '', (htmlentities ( trim ( $_POST['Rusername'] ) , ENT_NOQUOTES ))))){
echo "+ ok";
}else{
echo "+ not ok";
}
我想使用这种验证,并在需要时向 $aValid 添加特殊字符。
在插入 MySQL 之前,我会执行 mysql_real_escape_string 或准备好的语句。
任何想法为什么 + 符号可以用于第一段代码。在我看来确实不应该。
最新更新 - 我需要几个小时的低级调试 HTTP 标头才能弄清楚我的 A 端更改了 Content-Type,以便 + 符号在到达 PHP if 子句之前变成了空格(在我的白名单中允许)...
多么棒的经历——我希望它永远不会发生在你身上——:)
提醒自己:如果 jQuery 在这个验证过程中扮演了如此重要的角色,那么应该提及它......
I've googled and searched SO and everything, but I can't come to an answer.
Why is the PHP code below letting plus sign through:
$aValid = array('-', '_', '.');
if (ctype_alnum(str_replace($aValid, '', $_POST['Rusername']))){
(If user types 1234+ it goes on like it vas valid????).
I, normally, found a bypass, but is it really necessary;
$aValid = array('-', '_', '.');
if (ctype_alnum(str_replace($aValid, '', (htmlentities ( trim ( $_POST['Rusername'] ) , ENT_NOQUOTES ))))){
echo "+ ok";
}else{
echo "+ not ok";
}
I would like to use this kind of validation and just add special chars to $aValid when needed.
Before inserting to MySQL I would do mysql_real_escape_string or prepared statements.
Any ideas why the + sign is ok for first piece of code. In my opinion it really should't be.
Latest update - I needed few hours of low-level debugging HTTP headers to figure iz out that my A side changed the Content-Type so that the + sign became space before it got to PHP if clause (alowed in my whitelist)...
What an - I hope it will never happen to you - experience :)
Reminder to myself: jQuery should be mentioned if it was such a major player in this validation process...
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
您应该做的是检查过程的每个阶段,而不是将它们全部放入一行:
等等...基本调试。如果声明中有多个阶段,请检查每个单独的阶段。 ctype 可能工作得很好,但 str_replace 不知怎的让你失败了。
What you should do is inspect each stage of the process, rather than slamming them all into a single line:
etc... Basic debugging. If you've got multiple stages in a statement, then check each individual stage. ctype may be working perfectly fine, but the str_replace is failing you somehow.
不行...第一段代码返回 false..
如果您想删除
+
符号,则必须将其添加到$aValid
变量中It's not ok... the first piece of code return false..
If you want to remove the
+
sign you have to add it into the$aValid
variable