利用ASP规划聊天室

2018-09-06 10:58

阅读:512

  经常在Internet上冲浪的网友恐怕很少有人没有去过聊天室胡乱神聊。你只要稍微留意一下就会发现这些聊天室大多是用CGI程序或者用JAVA开发的Applet维护的。开发过这类CGI或Applet的程序员都知道,这种开发工作是费时费力的。那么有没有一种更简单、省力的开发方式呢?答案是肯定的。
关于ASP的介绍有许多计算机杂志介绍过,在这里不在赘述。
一、聊天室的规划:
1、谈话内容储存方式的选择:在客户机上显示即时谈话的内容应以什么方式储存在服务器呢?ASP有两种选择,一种是以文本文件方式,一种是以数据库方式。但笔者感觉ASP对文本文件操作的指令远不如ADO(ActiveDataObject)提供的对数据库操作的指令多。所以利用ADO,ASP能对数据库灵活地操作,比如插入、删除、更新、查询等等。笔者选择Access数据库来储存谈话的内容。该数据库内容只保留一天(可根据LAN的实际情况确定时间长短)的谈话内容。
2、聊天室界面的设计:为了客户能够方便地浏览站点的内容,又能尽可能地显示聊天室的内容,笔者在一幅主页里设计了三帧。左边一帧显示的是站点的Index。右边一帧又分成上下两帧。上帧占70%,用来显示当前聊天室的内容;下帧占30%,用来提供一个文本输入框和供用户反馈的按钮。
3、进入聊天室的步骤:象大多数聊天室一样,首先应该提供给用户一个登录界面,由用户输入自己的名字或别名和自己随意给定的密码。如果输入的用户名与线的用户名相同,则提示用户重新选择用户名或重新输入密码,以保证在线的所有用户名都是唯一的。登陆成功后进入聊天室,内容显示帧显示“欢迎加入”的欢迎信息。用户就可以在文本输入区内输入谈话内容了。
二、设计过程和开发技巧:
1、设计ODBC系统数据源:如前所述,本开发采用ASP对ADO进行操作,因此必须先对数据源进行设置。在NT服务器的控制面板里双击ODBC图标,在系统DSN页添加系统DSN,选择MicrosoftAccessDriver,DataSourceName为‘fybchat,Database选择Chat目录下的chat.mdb.该数据库包括下面几个字段:name,content,password,chattime,chatdate,分别以来存储姓名、谈话内容、密码、谈话时间和谈话日期。
2、登录界面设计:登录界面为一html页,包含一些警告信息和一个Form。该Form以来获取帐号和密码,如下所示:

<formmethod=postaction=receivedata.asp>帐号:
<inputtype=textname=usname>密码:
<inputtype=passwordname=uspassword>
</center>


<inputtype=submitvalue=进入>
<inputtype=resetvalue=重填>
</center>
<inputtype=hiddenname=contentvalue=>
</form>

通过提交按钮来激发receivedata.asp。该ASP文件主要来保证在聊天室里没有两个用户是同帐号的。用户提交信息后,该文件打开chat.mdb检查是否已经有该帐号,如果有但密码不对就提醒用户重新输入密码,如果没有那么用户就顺利进入了聊天室。进入聊天室界面的功能由下列语句完成:

<FRAMESETROWS=70%,30%>
<FRAMESRC=forum.aspNAME=mainMARGINWIDTH=1
MARGINHEIGHT=1Noresize>
<FRAMESRC=frft.asp?kname=<%=name%>NAME=footnotes
MARGINWIDTH=1Noresize>
</FRAMESET>

注意这里有一个技巧,通过参数kname将用户的帐号隐藏在客户的浏览器里面了,这样一来,用户每次提交谈话内容的同时也把他的帐号提交了。
3、文本输入区的设计:文本输入区是由frft.asp产生的。如上所述,用户每次提交谈话内容的同时也把他的帐号提交了,用户提交谈话内容的动作是激活forum.asp。Forum.asp的作用是刷新聊天室的内容。Frft.asp内容如下

<!DOCTYPEHTMLPUBLIC-//IETF//DTDHTML//EN>
<html>
<head>
<metahttp-equiv=Content-Typecontent=text/html;charset=gb_2312-80>
<metaname=GENERATORcontent=MicrosoftFrontPage2.0>
<title>
</head>
<body>
<%kname=request.QueryString(kname)%>
<basetarget=main>
<formname=fm1method=POSTaction=forum.asp>
<palign=center><inputtype=textsize=90name=content><palign=center><inputtype=buttonname=B1value=提交/刷新>
<inputtype=resetname=B2value=重写>
<inputtype=hiddenname=knamevalue=>


评论


亲,登录后才可以留言!