|
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有帐号?立即注册
x
你发奋努力,熟悉了安全方面的问题,然后又设计了一些程序,感觉还不错。聊天室 聊天的内容若何显示在屏幕上,一种是每隔一段工夫刷新一次页面,读入全体聊天
内容,然后显示,这里采取的是js的document.write的办法完成不刷新的聊天页面
!
1 主页面的生成,划定了CSS类型,显示接待词
function write2(){
if(this.u.document==null)return;
this.u.document.writeln("<html><head>");
this.u.document.writeln("<meta http-equiv=Content-Type content=text/ht
ml; charset=gb2312>");
this.u.document.writeln("<style type=text/css>");
this.u.document.writeln(".p9 { font-size: 11pt; line-height: 15pt}");
this.u.document.writeln("body { font-size: 11pt; line-height: 15pt}");
this.u.document.writeln("a:visited { font-size: 11pt;color: ext-decoration: none;}");
this.u.document.writeln("a:link { font-size: 11pt;color: -decoration: none}");
this.u.document.writeln("a:hover { font-size: 11pt;color:
this.u.document.writeln("</style>");
this.u.document.writeln("</head>");
this.u.document.writeln("<body);
//.................. 这里拔出生成在耳目数组的法式段
this.u.document.writeln("<script>");
this.u.document.writeln("<p class=p9 align=left>");
this.u.document.writeln("<p align=center>接待惠临PlayBoy聊天室,本聊天室
正在测试阶段,若有成绩请与<a href=mailto:pccastle@sina.com>咱们接洽</a>
</p>");
}
2 初始化进入信息,第一次进入聊天室
if($action == "enter")
{
/////////////////// 挪用显示主屏幕的js法式 ////////////////////
print("parent.write2();n");
//讲话内容,某某进入聊天室了
$message = "<a href=javascript:parent.cs('$name'); target=d>$name</a>来
到聊天室".$message." ".date("m月d日 H:i")."<script>parent.add('$name',
'$photo');parent.write1();</script><br>";
}
//更新讲话内容
while(file_exists($lockfile)){ $pppp++; }
//讲话的锁定
fclose(fopen($lockfile,"w"));
//读入讲话的总句数,也就是一切人一共发了几何言!咱们可以保留每个讲话,但
是如许会占用大批的磁盘空间,咱们采取了一种取模的办法,轮回利用文件来削减
文件操作!
$talkmessage = file($filename);
$number = chop($talkmessage[0]);
//讲话数增添一,然后保留
$talkhandle = fopen($filename,"w");
$number++;
fputs($talkhandle,$number);
fclose($talkhandle);
/去失落锁定
unlink($lockfile);
//对讲话总数对10取模,作为文件名保留讲话内容,也就是说第11句和第1句利用同
一个文件名,因为不成能同时有10句话没有更新,所以这是数在人不长短常多的情
况下很好!固然,思索到人多的情形,可以设成100.
$filehandle = fopen("messageonline".($number%10).".php","w");
fputs($filehandle,$message);
fclose($filehandle);
//显示进入信息
print("parent.u.document.writeln("$message");n");
//挪用自动刷新js法式,传递已显示的讲话数量
print("parent.flushwin($number)n");
//保留最初一次显示的讲话
$last = $number;
}
3 处置发送表单的恳求
//不处置空的讲话和超越必定数量的讲话
if( ($message != "")&&(strlen($message)<150))
{
//反省讲话者是不是在线,避免不测
$onlineperson = file("useronline.dbf");
$personsign=0;
for($i=0;$i<count($onlineperson);$i++)
{
$person = split($split,$onlineperson[$i],99);
if($person[0] == $name)
{
$personsign = 1;
$person[3] = date("U");
break;
}
}
//在线时的处置法式
if($personsign == 1)
{
//添加讲话工夫的局部
$message = $message." <font size=1>".date("m月d日 H:i")."</font><br>";
//锁定讲话总数文件
while(file_exists($lockfile)){ $pppp++; }
fclose(fopen($lockfile,"w"));
//读入讲话总数
$talkmessage = file($filename);
$number = chop($talkmessage[0]);
//总数加1,然后保留
$talkhandle = fopen($filename,"w");
$number++;
fputs($talkhandle,$number);
fclose($talkhandle);
unlink($lockfile);
//总数对10取模后以文件模式保留讲话内容
$filehandle = fopen("messageonline".($number%10).".php","w");
fputs($filehandle,$message);
fclose($filehandle);
}
}
//////////////////////////////////////////////////////////////////
如许,表单的处置已完成,上面的自动更新法式将会把新的讲话内容显示在屏幕
上
//////////////////////////////////////////////////////////////////
4 自动更新的主动轮回挪用办法
可使用<meta http-equiv="reflesh" content="3;url=messageflush.php?nam
e=<?print($name)?>&&pass=<?print($pass)&&last=<?print($last)?>的体例更
新!
我的法式之前就是利用这类办法主动更新的,然而我发明一个成绩,那就是当这个
更新法式呈现运转毛病时,他不会发生挪用下次更新的代码,形成后台更新法式停
止任务!所以我采取了js准时的办法来完成一样的功效!
var flushtimeID=null;
var flushRunning=false;
//前次更新标记
var flushflag = true;
function flushstop()
{
if(flushtimerRunning)clearTimeout(flushtimerID);
flushtimerRunning=false;
}
function flushstart()
{
flushstop();
//利用发送表单外面的前次显示的值
flushwin(this.d.document.inputform.last.value);
}
function flushwin(winnumber)
{
//假如前次更新准确,则挪用下次更新
if(flushflag == true)
{
url="messageflush.php?name=<? print($name); ?>&&pass=<? print($pass);
?>&&last="+winnumber;
flush.location=url
flushflag=false
}
//不然守候一个轮回
flushtimerID=setTimeout("flushstart()",2000);
flushtimerRunning=true;
}
这类办法包管了在主法式不逝世的情形下,后台更新法式会一向运转下去!
5 自动更新法式
<script Language='JavaScript'>
<?
//读入最大的讲话数量
$message = file($filename);
$number = chop($message[0]);
//从前次显示的下一个讲话入手下手到最大讲话停止,显示讲话内容
for($i=$last+1;$i<=$number;$i++)
{
//读入下一个讲话内容
$filename = "messageonline".($i%10).".php";
$message = file($filename);
$tempmessage = split($split,$message[0],99);
//显示讲话内容
print("parent.u.document.writeln("$message[0]");rn");
}
//更新发送表单最初一个讲话的数量
print("parent.d.document.inputform.last.value=$number;n");
//告诉主法式本次更新已完成
print("parent.flushflag=true;n");
?>
</script>
如许,每一个发送的讲话,经由主动更新法式处置保留到文件内,然后由一个轮回的主
动更新法式完成显示义务!!! 在相册系统的开发上,因为采用的是团队分工合作方式,更让我明白了在一个团队之中,团队成员之间的交流沟通的重要性,如果没有很好的沟通交流,成员之间的任务没有分配好。 |
|