作者:书友71424043 | 来源:互联网 | 2014-05-04 00:43
不同浏览器之间多年的竞争导致产生了很多工具帮助开发职员完成以前很难做到的任务。现在,只要一小段脚本,你就可以创立一个利用程序将数据绑定到用户控件,这样就可以通过一
不同浏览器之间多年的竞争导致产生了很多工具帮助开发职员完成以前很难做到的任务。现在,只要一小段脚本,你就可以创立一个利用程序将数据绑定到用户控件,这样就可以通过一个内嵌的代理类型的控件与服务器通信。
在 Internet Explorer(IE)中,这些东西包含 XML 数据岛和 XMLHTTP 对象,XML 数据岛用于将数据绑定到表单元素,XMLHTTP 对象用于在当前页面内不导航到其它页面的情况下创立对服务器的同步和异步调用。我将应用这两个易用的特征创立一个简略的聊天利用程序,该利用程序由一些充当 UI 的 ASP 页面,实现客户端功效的 Javascript,和 SQL Server 2000 中完成贸易逻辑的 T-SQL 所组成。
客户和服务器应用 XML 通信。在 Web 服务器接收到一个消息块之后,消息块会追加到 SQL Server 中的一个带有时间戳的 MESSAGES 表中。基于预先定义好的时间间隔,客户会从服务器恳求更新信息,包含自上一次从服务器恳求信息到现在为止追加到数据库中的消息列表和联机用户列表。
客户将通过 XMLHTTP 对象发送一个 到服务器。动作(action)要么是恳求刷新消息和用户列表,要么是发送一个新消息。这些动作保留在一个叫做 ACTIONS 的表中。服务器将响应相应的恳求或者接收一个新消息然后追加到 MESSAGES 表中。
当服务器响应一个消息的恳求的时候,会返回上次恳求之后的所有新消息的一个列表。为了跟踪客户的运动,我应用一个 ACTIVITY 表包含客户运动的日期时间(datetime),客户的标识保留在表 HANDLES 中,该表的名字很直观。
下面是建表的脚本:
CREATE TABLE [dbo].[ACTIONS] (
[action_id] [int] IDENTITY (1, 1) NOT NULL ,
[action_name] [varchar] (50) NULL ,
[action_descr] [varchar] (255) NULL
) ON [PRIMARY]
GO
CREATE TABLE [dbo].[ACTIVITY] (
[handle_id] [int] NULL ,
[action_time] [datetime] NULL
) ON [PRIMARY]
GO
CREATE TABLE [dbo].[HANDLES] (
[handle_id] [int] IDENTITY (1, 1) NOT NULL ,
[handle] [nvarchar] (63) NULL
) ON [PRIMARY]
GO
CREATE TABLE [dbo].[MESSAGES] (
[msg_id] [int] IDENTITY (1, 1) NOT NULL ,
[message] [nvarchar] (255) NULL ,
[action_id] [int] NULL ,
[action_time] [datetime] NOT NULL
) ON [PRIMARY]
所有的数据把持将通过存储过程完成。所有的数据接口将通过一个充当 Web 服务器和 SQL Server 2000 的联络员的泛型 COM 完成。COM 对象***露一个我要应用的方法RunSPReturnStream。该方法的第一个参数为存储过程的名字,第二个参数是参数数组的数组。参数数组是一个如下格局的简略数组:(paraName, paramType, paramLength, paramValue)。paramType是 ADO Parameter Type 枚举之一。一个 ASP 页面负责接收动作和创立响应,我把它叫做HandleAction.asp。
聊天页面将包含一个区域显示聊天消息;这个区域是一个包含在 DIV 的 TABLE。这个 TABLE 被绑定到一个xmlMessages XML 数据岛上。另外一个区域显示当前的用户;这个区域也是一个包含在 DIV 中的TABLE,它被绑定到一个xmlUsers XML数据岛上。另外还有一个 TEXTAREA 供用户输进消息。
--------------------------------------------------------------------------------
本文作者:Phillip Perkins是Ajilon Consulting的签约人。他的经验很丰富,从机器把持和客户/服务器到企业内部网利用。