试图弄清楚如何以合理的方式在php中使用过滤器
//Do sanization of user input
//$_POST['amount_ecb'] can be 77,7 or 77.7
$amount = filter_input(INPUT_POST, 'amount_ecb',
FILTER_SANITIZE_NUMBER_FLOAT, FILTER_FLAG_ALLOW_FRACTION);
如果发布值为 77.7,则正确设置金额,但如果用户使用逗号而不是点(例如 77,7)设置数字,则$amount
返回 77
我希望它在这两种情况下都返回 77.7。这可以用过滤器解决吗?
更新反馈(发布答案)后,我仍然有同样的问题:
使用时
$_POST['amount_ecb'] = str_replace(',', '.', $_POST['amount_ecb']);
以前
这是它返回的
$_POST 对象
array (size=5)
'amount_ecb' => string '77.7' (length=4)
'from_ecb' => string 'GBP' (length=3)
'to_ecb' => string 'SEK' (length=3)
'submit' => string 'Calculate currency' (length=18)
'result_decimals' => string '4' (length=1)
$amount
string '777' (length=3)
终于找到了解决这个问题的方法! (即使我认为这应该以某种方式内置到input_filter
中)。
如果有人偶然发现了同样的问题......
$amount_ecb = str_replace(',', '.', $_POST['amount_ecb']);
$amount = filter_var($amount_ecb,
FILTER_SANITIZE_NUMBER_FLOAT, FILTER_FLAG_ALLOW_FRACTION);
我将发布的值放入另一个变量($amount_ecb
),用点替换逗号,然后在$amount_ecb
上使用filter_var
- 根本不使用filter_input
。
/* find , and replace with . if any; */
$_GET['search'] = str_replace(',', '.', $_GET['search']);
/* finally filter data */
$amount = filter_var($_GET['search'], FILTER_SANITIZE_NUMBER_FLOAT, array(
'flags'=>FILTER_FLAG_ALLOW_FRACTION));