为什么这不起作用:
if(!($data['email'] = filter_var(INPUT_POST,'email',FILTER_SANITIZE_EMAIL)))
{
$errors['email'] = 'Invalid Email.';
}
这是有效的:
if(!($data['email'] = filter_input(INPUT_POST,'email',FILTER_SANITIZE_EMAIL)))
{
$errors['email'] = 'Invalid Email.';
}
此处的差异为filter_var
和filter_input
,当我点击提交时,filter_var
提交表单但未提交filter_input
。还在这里
filter_input(INPUT_POST,'email',FILTER_SANITIZE_EMAIL))
如果我写了例如some'@email.com
,为什么不删除'
。它是否正常工作?我有点困惑。
答案 0 :(得分:3)
如果您查看参数filter_var
和filter_input
函数,您会看到原因:
filter_var ($value_to_be_filtered, FILTER_TYPE, $options)
<强> VS 强>
filter_input($input_type , $variable_from_input, FILTER_TYPE, $options)
其中$input_type
是INPUT_GET
,INPUT_POST
,INPUT_COOKIE
,INPUT_SERVER
或INPUT_ENV
之一。