程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> 基於 PHP 的聊天室(三)

基於 PHP 的聊天室(三)

編輯:關於PHP編程

現在我們有了需要通過$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記錄,然後創建一個新的記錄,新的頭信息,新的腳標。為了讓布局更清楚,我使用了表格。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved