过滤器Sanizite用户输入浮点数逗号/点问题


filter sanizite user input float numbers comma/dot issue

试图弄清楚如何以合理的方式在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));