日期:2009-03-27  浏览次数:20473 次

为了提供更好的服务,网站可以提供Notification机制以及时与自己的客户沟通。本文讨论Notification服务的一种实现方法。

自上而下,Notification服务可以分为三层:
- 具体Notification服务的实现层,负责实现具体通知内容的构建;
- Notification服务的管理层,负责获取Notification数据、分发到具体实现等;
- Notification服务的通讯层,负责网络发送,如Email、短消息等。

1. 通讯层
通讯层采用Factory模式,NotifyServiceManager的GetNotifyService(NotifyServiceEnum type)方法返回以下接口对象:
public interface INotifyService
{
int Send(string sender, string receiver, string subject, string content);
int BatchSend(string sender, string[] receivers, string subject, string content);
}
目前NotifyServiceEnum包括EMAIL_SERVICE和SMS_SERVICE两种。

2. 管理层
管理层提供以下三种功能:
- 获取数据:目前采用使用SQLXML的WebService支持一文中的方式访问数据库,返回DataSet的集合,每个DataSet包含一种需要通知的业务数据;
- 分发通知:采用类似Prototype模式的方式,一种通知业务对应一个实现ISendNotification的对象;
- 通知机制:可以采用定时间隔通知,或有数据时通知等方式。

2.1 获取数据
如下调用WebService:
myNotificationService.Notification service = new myNotificationService.Notification();
object[] rc = service.GetInstantNotification();

2.2 分发通知
对每类通知的每一行内容调用ISendNotification的Send方法:
for(int notifyType=0; notifyType<rc.Length-1; notifyType++)
{
DataRowCollection rows = (rc[notifyType] as DataSet).Tables[0].Rows;
for(int i=0; i<rows.Count; i++)
{
_sendNotifications[notifyType].Send(rows[i]);
}
}
其中ISendNotification定义如下:
public interface ISendNotification
{
void Send(DataRow row);
}
_sendNotifications为一ISendNotification类的数组,其元素是实现了ISendNotification接口的具体发送的实现。

2.3 通知机制
通知机制可以采用定时间隔的方式,相当于Poll方式;或者有数据通知的方式,相对于Push方式。理论上,Push方式效率高一些,但数据源是数据库时要采用Push模式需要额外编程。
小鸡射手目前采用的是Poll方式,并将在以后的Blog中讨论Push模式,即所谓的SQL Dependency的实现。

3. 具体业务
具体业务实现的核心工作是将System.Data.DataRow对象转化为string对象,可以采用Template的方式实现。

4.优缺点
本方法的主要优点是可扩充性,包括通讯方式的扩充和具体业务的扩充;
缺点是仅适合于较简单内容的通知,即通知内容需要放在System.Data.DataRow中表示。如果通知内容较为复杂,如通知由几个DataSet组成,那本方法不适用。如,小鸡射手是采用XSLT方式来处理有多个DataSet内容通知的,不过这样的通知内容只能发发Email啦,短消息是容不下的了,让我们共同等待MMS的普及吧,:-)