PHP和Mysql登入功能可防止SQL注入

小云云
發布: 2023-03-20 14:02:01
原創
1562 人瀏覽過

最近在了解SQL注入,發現很多人登入功能都是同時使用使用者輸入的username和password,組合到一條sql語句裡面,查詢判斷有無結果來判定是否可登入。例如下面:


  1. #
    <?php  
    $username = $_POST[&#39;username&#39;];  
    $password = $_POST[&#39;password&#39;];  
    $sql = "select * from user where username=&#39;{$username}&#39; and password=&#39;{$password}&#39; ";  
    $this->db->query($sql);
    登入後複製

這樣很容易在username參數加入' or 1=1 -- 注入,雖然這只是範例,但現在很多使用框架,一不注意,最終組合成的語句也是類似這樣的。這裡不說輸入參數過濾、參數綁定,語法分析等常用方法去應對SQL注入,我們可以轉換判斷方法:

    ##
    <?php  
    $username = $_POST[&#39;username&#39;];  
    $password = $_POST[&#39;password&#39;];  
    $sql = "select * from user where username=&#39;{$username}&#39; ";  
    $data = $this->db->query($sql);  
      
    ......  
      
    if($data[&#39;password&#39;] == $password){  
        //密码OK  
    }else{  
        //密码错误  
    }
    登入後複製


這樣先查到數據,再用php本身來判斷是否符合密碼,是不是解決了問題了?

相關推薦:

推薦10個防止sql注入方法

以上是PHP和Mysql登入功能可防止SQL注入的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!