基於PHP的聊天室(二)

來源:互聯網
上載者:User
聊天室 < ?php

// 開啟檔案,並且將檔案長度截為0
$open_file = fopen("messages.html", "w");

// 寫入檔案的頭資訊
fputs($open_file, $header);

// 新的一行
// (使用stripSlashes,因為我們不想讓所有的逸出字元出現在訊息檔案中)
fputs($open_file, stripslashes($new_message));

// 舊的行
fputs($open_file, $old_messages);

// 腳標
fputs($open_file, $footer);

// 關閉檔案
fclose($open_file);

? >


  現在我們有了需要通過$REMOTE_ADDR變數來交叉引用的檔案,這樣我們可以區分出想要發貼的使用者是否已經被扁或沒有被扁。很簡單:

< ?php

for ($counter=0;$counter< sizeof($banned_array);$counter++) {
if ($banned_array[$counter] == $REMOTE_ADDR) {
print("< font color="red" face="arial" align="center" >".
"You have been banned from this chat< /font >");
exit;
}
}

? >

  exit命令將立即停止指令碼的執行。在開始對傳遞過來的變數執行處理之前,插入對被扁使用者的檢查,這樣被扁使用者就不能使用聊天室了。

  比較好的解決在某些情況下動態IP地址的問題的一個意見就是,檢查IP地址塊的所屬範圍。一個簡單的函數可以容易地實現它。

< ?php

function makeMask($ip) {
// remember to escape the . so PHP doesn't think it's 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("< font color="red" face="arial" align="center" >".
"You have been banned from this chat< /font >");
exit;
}
}

? >

  我們有了針對動態IP地址的保護措施。
  最後我們需要一種方法最先得到惹麻煩的IP。我的實現是將$name和$REMOTE_ADDR記錄到一個名為
iplist.html的檔案中。對於一個分離的,秘密的URL,我可以在瀏覽訊息的同時監控IP地址。這可以增加一些意外的好處,就是能夠發現假冒者--在這些地方最常犯的“罪”。

  iplist.html與messages.html的建立方法基本上一樣。首先將當前的值從iplist.html中取出來,我們剝離迴轉資訊,腳標和舊的IP記錄,然後建立一個新的記錄,新的頭資訊,新的腳標。為了讓布局更清楚,我使用了表格。

< ?php

$header = "< html >< body bgcolor="#000000" text="#ffffff" >< table border="0" > ";
$footer = "< /table >< /body >< /html >";
$new_ip = "< tr >< td >$name< /td >< td >$REMOTE_ADDR< /td >< /tr > ";

$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方面我是如何開始的並且現在我已經以它為職業了。
祝聊天快樂!

<全文完>


相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.