国产欧美二区三区-国产欧美高清-国产欧美国产精品第二区-国产欧美国产精品第一区-小说区 图片区-小说区 综合区 都市激情

當前位置: 首頁 > 站長資訊 > 正文頁面

Discuz教程:任務刷積分漏洞說明和修復方法

在完成任務時(home.php?mod=draw&do=view&id=xx),任務先前的狀態缺少判斷Fuu網站目錄_網站網址收錄與提交入口

完成任務的鏈接形如:home.php?mod=draw&do=view&id=xxFuu網站目錄_網站網址收錄與提交入口

這個地址最終在 source/class/class_task.php 中被處理Fuu網站目錄_網站網址收錄與提交入口

約第370行:Fuu網站目錄_網站網址收錄與提交入口

function draw($id) {Fuu網站目錄_網站網址收錄與提交入口

global $_G;Fuu網站目錄_網站網址收錄與提交入口

if(!($this->task = C::t('common_task')->fetch_by_uid($_G['uid'], $id))) {Fuu網站目錄_網站網址收錄與提交入口

showmessage('task_nonexistence');Fuu網站目錄_網站網址收錄與提交入口

} elseif($this->task['status'] != 0) {Fuu網站目錄_網站網址收錄與提交入口

showmessage('task_not_underway');Fuu網站目錄_網站網址收錄與提交入口

} elseif($this->task['tasklimits'] && $this->task['achievers'] >= $this->task['tasklimits']) {Fuu網站目錄_網站網址收錄與提交入口

return -1;Fuu網站目錄_網站網址收錄與提交入口

}Fuu網站目錄_網站網址收錄與提交入口

......Fuu網站目錄_網站網址收錄與提交入口

之后就是獲得任務獎勵了Fuu網站目錄_網站網址收錄與提交入口

總覺得上面這一段少了些什么判斷?我們對比下其他代碼Fuu網站目錄_網站網址收錄與提交入口

約第473行:Fuu網站目錄_網站網址收錄與提交入口

function giveup($id) {Fuu網站目錄_網站網址收錄與提交入口

global $_G;Fuu網站目錄_網站網址收錄與提交入口

if($_GET['formhash'] != FORMHASH) {Fuu網站目錄_網站網址收錄與提交入口

showmessage('undefined_action');Fuu網站目錄_網站網址收錄與提交入口

} elseif(!($this->task = C::t('common_task')->fetch_by_uid($_G['uid'], $id))) {Fuu網站目錄_網站網址收錄與提交入口

showmessage('task_nonexistence');Fuu網站目錄_網站網址收錄與提交入口

} elseif($this->task['status'] != '0') {Fuu網站目錄_網站網址收錄與提交入口

showmessage('task_not_underway');Fuu網站目錄_網站網址收錄與提交入口

}Fuu網站目錄_網站網址收錄與提交入口

這一段是放棄任務的判斷,我們看到如果 $this->task['status'] != '0',就是說任務沒有開始的時候,是不能放棄任務的。Fuu網站目錄_網站網址收錄與提交入口

但是,在上面那段獲取任務獎勵的代碼中,并沒有判斷任務是否開始,造成了無需領取任務,就可以無限次數獲取獎勵。Fuu網站目錄_網站網址收錄與提交入口

此漏洞還可以用于強行獲取由于用戶組不符,沒有權限領取的任務的獎勵。Fuu網站目錄_網站網址收錄與提交入口

漏洞詳細利用,請見漏洞證明。Fuu網站目錄_網站網址收錄與提交入口

漏洞證明:Fuu網站目錄_網站網址收錄與提交入口

1、新建一個任務,就選擇紅包類任務吧Fuu網站目錄_網站網址收錄與提交入口

2、此時千萬不要申請任務,而是進入任務詳細頁面(完成之后就不能刷了)Fuu網站目錄_網站網址收錄與提交入口

home.php?mod=task&do=view&id=2Fuu網站目錄_網站網址收錄與提交入口

這樣就能看到任務詳情了,任務的獎勵是 威望+1。Fuu網站目錄_網站網址收錄與提交入口

我們把地址改為領取任務獎勵Fuu網站目錄_網站網址收錄與提交入口

home.php?mod=task&do=draw&id=2Fuu網站目錄_網站網址收錄與提交入口

打開這個地址,獲得了 威望+1。Fuu網站目錄_網站網址收錄與提交入口

不斷刷新這個頁面,即可不斷獲得獎勵。Fuu網站目錄_網站網址收錄與提交入口

修復方案:Fuu網站目錄_網站網址收錄與提交入口

在 source/class/class_task.php 中的 draw 函數部分,加入任務是否領取的判斷Fuu網站目錄_網站網址收錄與提交入口

即加上Fuu網站目錄_網站網址收錄與提交入口

......Fuu網站目錄_網站網址收錄與提交入口

elseif($this->task['status'] != '0') {Fuu網站目錄_網站網址收錄與提交入口

showmessage('task_not_underway');Fuu網站目錄_網站網址收錄與提交入口

}Fuu網站目錄_網站網址收錄與提交入口

這樣,再次使用漏洞時,就會提示:不是進行中的任務Fuu網站目錄_網站網址收錄與提交入口

  

此文由 網站目錄_網站網址收錄與提交入口 編輯,未經允許不得轉載!:

相關文章