dongyin2390 2008-11-22 05:35
浏览 32

filter_var是否足以清理基于PHP的MySQL查询的整数输入?

I've never liked wrapping the

mysql_real_escape_string 

function around input I expect to be integer for inclusion in a MySQL query. Recently I came across the

filter_var 

function. Nice!

I'm currently using the code:

if (isset($idUserIN) 
    && filter_var($idUserIN, FILTER_VALIDATE_INT) 
    && 0 < filter_var($idUserIN, FILTER_SANITIZE_NUMBER_INT)
    ) {
      $idUser = filter_var($idUserIN, FILTER_SANITIZE_NUMBER_INT);
      $sql = 'SELECT * FROM TABLE_NAME WHERE idUser = '.$idUser;
} else {
  // handle invalid data
}

Does this leave any holes open?

('> 0' chosen rather than '>= 0' as its a table auto_increment field, so 0 would not be a normal value)

  • 写回答

3条回答 默认 最新

  • dongzizhi9903 2008-11-22 05:43
    关注

    A much simpler and easier-to-read method that I use is this:

    $sql = 'SELECT * FROM TABLE_NAME WHERE idUser = ' . intval($idUser);
    

    It attempts to convert $idUser to an integer and on failure returns 0 which none of my tables have as real id's. (So I know the input was invalid if it evaluates to 0.)

    To answer your actual question, no that won't leave any holes open. I suggest getting rid of the repetitive code though:

    $idUserIN_filtered = filter_var($idUserIN, FILTER_VALIDATE_INT);
    
    if (isset($idUserIN) 
        && $idUserIN_filtered 
        && 0 < $idUserIN_filtered
        ) {
          $sql = 'SELECT * FROM TABLE_NAME WHERE idUser = '.$idUser_filtered;
    } else {
      // handle invalid data
    }
    
    评论

报告相同问题?

悬赏问题

  • ¥15 Mac系统vs code使用phpstudy如何配置debug来调试php
  • ¥15 目前主流的音乐软件,像网易云音乐,QQ音乐他们的前端和后台部分是用的什么技术实现的?求解!
  • ¥60 pb数据库修改与连接
  • ¥15 spss统计中二分类变量和有序变量的相关性分析可以用kendall相关分析吗?
  • ¥15 拟通过pc下指令到安卓系统,如果追求响应速度,尽可能无延迟,是不是用安卓模拟器会优于实体的安卓手机?如果是,可以快多少毫秒?
  • ¥20 神经网络Sequential name=sequential, built=False
  • ¥16 Qphython 用xlrd读取excel报错
  • ¥15 单片机学习顺序问题!!
  • ¥15 ikuai客户端多拨vpn,重启总是有个别重拨不上
  • ¥20 关于#anlogic#sdram#的问题,如何解决?(关键词-performance)