對(duì)限制ip的投票網(wǎng)站作弊方案,這個(gè)方法利用了投票網(wǎng)站監(jiān)測(cè)遠(yuǎn)程ip的一些漏洞來(lái)實(shí)現(xiàn),并沒(méi)有真正的偽造ip地址,http是建立的tcp之上的第七層,是不可能偽造真實(shí)ip地址的最近朋友需要一個(gè)投票軟件,我最近也就研究了一下這個(gè)投票網(wǎng)站,這個(gè)投票網(wǎng)站有驗(yàn)證碼,每個(gè)ip限制為一票,看起來(lái)是標(biāo)準(zhǔn)的投票網(wǎng)站。我先研究了一下驗(yàn)證碼:
這個(gè)投票網(wǎng)站的驗(yàn)證碼開(kāi)始很簡(jiǎn)單,標(biāo)準(zhǔn)位置的標(biāo)準(zhǔn)四個(gè)數(shù)字,很好識(shí)別。后來(lái)變態(tài)到位數(shù)不一定,而且還有字母,而且還位置上下不一定,這下驗(yàn)證碼的識(shí)別,不但是軟件很難識(shí)別,就連人工識(shí)別都困難。山窮水盡疑無(wú)路,柳暗花明又一村,請(qǐng)看下段分解!
在我不斷的分析和研究發(fā)現(xiàn)他的驗(yàn)證碼檢查有漏洞,發(fā)現(xiàn)了這個(gè)漏洞,這個(gè)驗(yàn)證碼已經(jīng)形同虛設(shè),無(wú)需識(shí)別,無(wú)需驗(yàn)證碼,直接就繞過(guò)去了,因?yàn)樗辉谕镀边x項(xiàng)頁(yè)設(shè)置檢查驗(yàn)證碼是否為空的 js代碼,js代碼是運(yùn)行在客戶端,這種驗(yàn)證的效果為零,一般js這種驗(yàn)證只是為了方便用戶來(lái)使用的,做為投票網(wǎng)站只使用這一種驗(yàn)證方式,在投票處理動(dòng)態(tài)頁(yè)面竟然不檢查驗(yàn)證碼是否為空,實(shí)在是不敢恭維,給網(wǎng)站的安全帶來(lái)極大的隱患。
對(duì)于驗(yàn)證碼的問(wèn)題,我已經(jīng)了解了破解方法,只要在投票的時(shí)候不直接訪問(wèn)驗(yàn)證碼文件,那么驗(yàn)證碼就是為空,既然他的動(dòng)態(tài)頁(yè)面不檢查驗(yàn)證碼是否為空,所以只要在post的時(shí)候驗(yàn)證碼參數(shù)為空就可以了。
那么還有一個(gè)問(wèn)題就是這個(gè)投票網(wǎng)站檢查ip,限制一個(gè)ip只允許投票一次,那么只有使用代理,或者通過(guò)不停的斷網(wǎng)和撥號(hào)才能實(shí)現(xiàn)。我實(shí)在想不到其他好辦法,后來(lái)這個(gè)朋友找到了一個(gè)可以極速在這個(gè)網(wǎng)站投票的程序,我對(duì)這個(gè)程序的ip解決方案很好奇就問(wèn)朋友要來(lái)想分析一下。
首先我是采取對(duì)這個(gè)投票軟件進(jìn)行抓包的方式來(lái)研究,準(zhǔn)備好了之后,打開(kāi)投票程序“刷!提示軟件沖突!”暈,不會(huì)吧,那我就關(guān)掉一些程序,都關(guān)完了只留一個(gè)抓包程序還提示沖突,呵呵,原來(lái)這個(gè)程序竟然還知道有人可能會(huì)分析他的軟件,竟然遍歷進(jìn)程名稱,檢查是否有可疑的程序,如果有程序?qū)λM(jìn)行分析或者抓包,他就拒絕運(yùn)行。呵呵,目前我知道他限制的軟件有易語(yǔ)言編程軟件,還有 wsockexpert_cn 抓包軟件。呵呵,關(guān)了易語(yǔ)言,把 wsockexpert_cn 名稱改一下,順利通過(guò)軟件的自身安全檢測(cè),運(yùn)行成功。
以下是我在使用過(guò)程中他投票是的數(shù)據(jù)包:
xml/html code復(fù)制內(nèi)容到剪貼板
post /vote/view.php?sid=33act=vote http/1.1
accept: */*
referer:
content-type: application/x-www-form-urlencoded
x-forwarded-for: 218.20.218.200
client_ip: 218.20.218.200
via: 218.20.218.200
remote_addr: 218.20.218.200
accept-language: zh-cn
accept-encoding: text
user-agent: mozilla/4.0 (compatible; msie 7.0; windows nt 6.0; slcc1; .net clr 2.0.50727; .net clr 3.0.04506)
host:
cookie: phpsessid=pldjnb6scereodjm5niqb9q990
content-length: 49
connection: close
-forwarded-for 發(fā)現(xiàn)了這個(gè)http頭參數(shù) 后面跟著ip,呵呵,這個(gè)參數(shù)肯定有來(lái)頭,原來(lái)我一直不知道,呵呵,趕緊百度一下。
下面是百度后的一篇說(shuō)明文章,說(shuō)得很好,大家看看。
偽造http頭中的x-forwarded-for字段來(lái)偽造ip百度了一下x-forwarded-for的原理,這東西出來(lái)好長(zhǎng)時(shí)間了.我還第一次聽(tīng)說(shuō)x-forwarded-for:簡(jiǎn)稱xff頭,它代表客戶端,也就是http的請(qǐng)求端真實(shí)的ip,只有在通過(guò)了http 代理或者負(fù)載均衡服務(wù)器時(shí)才會(huì)添加該項(xiàng)。
它不是rfc中定義的標(biāo)準(zhǔn)請(qǐng)求頭信息,在squid緩存代理服務(wù)器開(kāi)發(fā)文檔中可以找到該項(xiàng)的詳細(xì)介紹。
標(biāo)準(zhǔn)格式如下:
x-forwarded-for: client1, proxy1, proxy2
從標(biāo)準(zhǔn)格式可以看出,x-forwarded-for頭信息可以有多個(gè),中間用逗號(hào)分隔,第一項(xiàng)為真實(shí)的客戶端ip,剩下的就是曾經(jīng)經(jīng)過(guò)的代理或負(fù)載均衡的ip地址,經(jīng)過(guò)幾個(gè)就會(huì)出現(xiàn)幾個(gè)。
wiki 的x-forwarded-for解釋 分析:
既然是要偽造客戶端ip,那我們先看看一般是怎樣獲取客戶端ip地址的(以php為例).這段代碼是在百度搜索到的.大部分網(wǎng)站可能都用這段代碼。
xml/html code復(fù)制內(nèi)容到剪貼板
$user_ip = ($_server[http_via]) ? //是否使用了代理
$_server[http_x_forwarded_for] : $_server[remote_addr];
//獲取失敗則從remote_addr獲取
$user_ip = ($user_ip) ? $user_ip : $_server[remote_addr];
?>
首先判斷http_via頭是否存在,http_via頭代表是否使用了代理服務(wù)器.如果沒(méi)有那就從remote_addr字段獲取客戶端的ip地址,如果有那就從x-forwarded-for獲取客戶端ip我估計(jì)很多程序員都是從百度來(lái)的代碼吧.asp也類似.
然后我們來(lái)測(cè)試一下.
服務(wù)端代碼:
xml/html code復(fù)制內(nèi)容到剪貼板
//輸出http_x_forwarded_for
echo http_x_forwarded_for:.$_server[http_x_forwarded_for];
//輸出remote_addr echo remote_addr:. $_server[remote_addr];
?>
可以看到獲取到的客戶端ip地址是不一樣的.remote_addr為真實(shí)地址.
所以一個(gè)網(wǎng)站如果是從x-forwarded-for來(lái)判斷客戶端ip地址的話,那么我們就可以利用這個(gè)邏輯漏洞刷票。
更多信息請(qǐng)查看IT技術(shù)專欄