基於PHP的聊天室(三)
來源:limodou
作者:Mike Hall
譯者:limodou
現在我們有了需要通過$REMOTE_ADDR變量來交叉引用的文件,這樣我們可以區分出想要發貼的用戶是否已經被扁或沒有被扁。很簡單:
< ?php
for ($counter=0;$counter< sizeof($banned_array);$counter++) {
if ($banned_array[$counter] == $REMOTE_ADDR) {
print("".
"You have been banned from this chat");
exit;
}
}
? >
exit命令將立即停止腳本的執行。在開始對傳遞過來的變量執行處理之前,插入對被扁用戶的檢查,這樣被扁用戶就不能使用聊天室了。
比較好的解決在某些情況下動態IP地址的問題的一個意見就是,檢查IP地址塊的所屬范圍。一個簡單的函數可以容易地實現它。
< ?php
function makeMask($ip) {
// remember to escape the . so PHP doesnt think its a concatenation
$ip_array = explode(".", $ip);
$ip_mask = "$ip_array[0].$ip_array[1].$ip_array[2]";
return $ip_mask;
}
? >
然後我們把循環中的if替換成
< ?php
for ($counter=0;$counter< sizeof($banned_array);$counter++) {
if (makeMask($REMOTE_ADDR) == makeMask($banned_array[$counter])) {
print("".
"You have been banned from this chat");
exit;
}
}
? >
我們有了針對動態IP地址的保護措施。
最後我們需要一種方法最先得到惹麻煩的IP。我的實現是將$name和$REMOTE_ADDR記錄到一個名為
iplist.html的文件中。對於一個分離的,秘密的URL,我可以在浏覽消息的同時監控IP地址。這可以增加一些意外的好處,就是能夠發現假冒者--在這些地方最常犯的“罪”。
iplist.html與messages.html的創建方法基本上一樣。首先將當前的值從iplist.html中取出來,我們剝離掉頭信息,腳標和舊的IP記錄,然後創建一個新的記錄,新的頭信息,新的腳標。為了讓布局更清楚,我使用了表格。
< ?php
$header = " ";
$footer = "";
$new_ip = "$name$REMOTE_ADDR ";
$ip_array = file("iplist.html");
for ($counter = 1; $counter < 20; $counter++)
$old_ips.= $ip_array[$counter];
? >
簡單地把內容寫入磁盤與對message文件所做的一樣,這樣我們就有了一個web聊天室。比Java有更好的跨越平台的兼容性,並且除了一個web浏覽器什麼都不需要了--我聽說甚至Dreamcast就是這樣工作的!
有一些東西你可能想試著自已做一下,包括合並一些常用代碼片段為函數,編寫一個可以自動增加惹麻煩的人到被扁列表中的腳本和編寫一個regex表達式,可以掃描消息正文中的URL和e-mail,並將之自動轉換成鏈接(象Outlook Express 和ICQ做的那樣)。
試一試,體會一下樂趣,得到一些經驗。這就是在PHP方面我是如何開始的並且現在我已經以它為職業了。
祝聊天快樂!