中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何理解對于ThinkPHP框架早期版本的一個SQL注入漏洞

發布時間:2021-09-29 10:12:43 來源:億速云 閱讀:129 作者:iii 欄目:開發技術

本篇內容介紹了“如何理解對于ThinkPHP框架早期版本的一個SQL注入漏洞”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!

使用查詢條件預處理可以防止SQL注入,沒錯,當使用如下代碼時可以起到效果:

$Model->where("id=%d and username='%s' and xx='%f'",array($id,$username,$xx))->select();

或者

$Model->where("id=%d and username='%s' and xx='%f'",$id,$username,$xx)->select();

但是,當你使用如下代碼時,卻沒有"防止SQL注入"的效果(但是官方文檔卻說可以防止SQL注入): 

$model->query('select * from user where id=%d and status=%s',$id,$status);

或者

$model->query('select * from user where id=%d and status=%s',array($id,$status));

原因分析:

ThinkPHP/Lib/Core/Model.class.php 文件里的parseSql函數沒有實現SQL過濾.
其原函數為: 

protected function parseSql($sql,$parse) {
// 分析表達式
if(true === $parse) {
  $options = $this->_parseOptions();
  $sql =  $this->db->parseSql($sql,$options);
}elseif(is_array($parse)){ // SQL預處理
  $sql = vsprintf($sql,$parse);
}else{
  $sql  =  strtr($sql,array('__TABLE__'=>$this->getTableName(),'__PREFIX__'=>C('DB_PREFIX')));
}
$this->db->setModel($this->name);
return $sql;
}

驗證漏洞(舉例):
請求地址:

http://localhost/Main?id=boo" or 1="1


http://localhost/Main?id=boo%22%20or%201=%221

action代碼: 

$model=M('Peipeidui');
$m=$model->query('select * from peipeidui where name="%s"',$_GET['id']);
dump($m);exit;

或者:

$model=M('Peipeidui');
$m=$model->query('select * from peipeidui where name="%s"',array($_GET['id']));
dump($m);exit;

結果:

表peipeidui所有數據被列出,SQL注入語句起效.
 
解決方法:

可將parseSql函數修改為: 

protected function parseSql($sql,$parse) {
// 分析表達式
if(true === $parse) {
  $options = $this->_parseOptions();
  $sql =  $this->db->parseSql($sql,$options);
}elseif(is_array($parse)){ // SQL預處理
  $parse = array_map(array($this->db,'escapeString'),$parse);//此行為新增代碼
  $sql = vsprintf($sql,$parse);
}else{
  $sql  =  strtr($sql,array('__TABLE__'=>$this->getTableName(),'__PREFIX__'=>C('DB_PREFIX')));
}
$this->db->setModel($this->name);
return $sql;
}

“如何理解對于ThinkPHP框架早期版本的一個SQL注入漏洞”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

肇源县| 宣武区| 晋城| 遂川县| 江口县| 耿马| 泸定县| 旬阳县| 策勒县| 班玛县| 阿拉善盟| 苗栗县| 延津县| 青州市| 邯郸市| 江川县| 萝北县| 九龙坡区| 绥化市| 洞头县| 青河县| 商河县| 乐山市| 武宣县| 金阳县| 泸州市| 贡觉县| 鲜城| 保山市| 内黄县| 隆昌县| 五莲县| 光泽县| 阳高县| 永昌县| 兰坪| 濮阳市| 石柱| 翁源县| 闽清县| 枣强县|