douren0558 2015-02-27 17:01
浏览 8
已采纳

(int)来评估$ _GET

Is it secure to use (int) to make sure you are receiving a integer on the URL?

For example: test.php?id=3

if ((int)$_GET['id'] == 0) {
    echo 'Invalid Entry';
}

So if somebody enters other than a number it will be invalid.

  • 写回答

2条回答 默认 最新

  • dongzhenjian5195 2015-02-27 17:09
    关注

    This should work for you:

    if (filter_var($_GET['id'], FILTER_VALIDATE_INT) === FALSE) {
        echo 'Invalid Entry';
    }
    

    Input / Output:

    0        -> Good
    "0"      -> Good
    5        -> Good
    "5"      -> Good
    1.4      -> Bad
    "1.4"    -> Bad
    "12text" -> Bad
    

    EDIT:

    If you don't want numbers <0 you can use this:

    if (filter_var($_GET['id'], FILTER_VALIDATE_INT) === FALSE || $_GET['id'] <= 0) {
        echo 'Invalid Entry';
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥30 自适应 LMS 算法实现 FIR 最佳维纳滤波器matlab方案
  • ¥15 lingo18勾选global solver求解使用的算法
  • ¥15 全部备份安卓app数据包括密码,可以复制到另一手机上运行
  • ¥15 Python3.5 相关代码写作
  • ¥20 测距传感器数据手册i2c
  • ¥15 RPA正常跑,cmd输入cookies跑不出来
  • ¥15 求帮我调试一下freefem代码
  • ¥15 matlab代码解决,怎么运行
  • ¥15 R语言Rstudio突然无法启动
  • ¥15 关于#matlab#的问题:提取2个图像的变量作为另外一个图像像元的移动量,计算新的位置创建新的图像并提取第二个图像的变量到新的图像