欢迎光临
我们一直在努力

基于PHP的聊天室(二)-PHP教程,PHP基础

建站超值云服务器,限时71元/月

< ?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 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("< 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方面我是如何开始的并且现在我已经以它为职业了。

祝聊天快乐!

<全文完>

赞(0)
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com 特别注意:本站所有转载文章言论不代表本站观点! 本站所提供的图片等素材,版权归原作者所有,如需使用,请与原作者联系。未经允许不得转载:IDC资讯中心 » 基于PHP的聊天室(二)-PHP教程,PHP基础
分享到: 更多 (0)