MOSS2007开发之旅——EventHandler

Known.MOSS.Exercise.rar

 

在实际项目中,我们经常会遇到这样一些需求,比如:删除文档库中一个文档时,要求发Mail通知相关人员;库存管理时,当入库时,添加某类产品和数量,库存也要相应增加某类产品和数量,当出库时,添加出库产品和数量,则库存应相应减少产品和数量。要实现这种需求,我们就要用到SP的EventHandler。

要使用EventHandler,需经历以下步骤:

  • 启动EventHandler支持
  • 编写EventHandler程序
  • 附加EventHandler程序

具体的操作步骤请参考高维鹏(Brian)SharePoint 2007图文开发教程(5)---体验Event Handler。这里我们看库存管理时怎么实现的,共享出来,大家可以举一反三。

案例描述

这里的库存管理例子,我们设计四个列表,产品类别(Category)、产品(Product)、入库产品(Import Product)、出库产品(Export Product)。产品类别包括Category Name和Remarks两个字段自定义字段;产品包括Product Name、Count和Remarks三个自定义字段。其实每个Item还有几个默认的字段如:Created(创建时间)、Created By(创建人)等等公用字段,这里我们将入库产品和出库产品的创建时间显示出来,大家可以在Action中修改当前View,我就截一个图给大家参考一下:

image

案例实现

我们创建四个EventHandler模板分别命名为Category、Product、ImportProduct、ExportProduct。模板默认创建4个文件ItemEventReceiver.cs、ItemEventReceiver.xml、ListEventReceiver.cs、ListEventReceiver.xml。其中ItemEventReceiver的签名是:

public class CategoryItemEventReceiver : SPItemEventReceiver
{
 public CategoryItemEventReceiver();
 public override void ItemAdded(SPItemEventProperties properties);
 public override void ItemAdding(SPItemEventProperties properties);
 public override void ItemAttachmentAdded(SPItemEventProperties properties);
 public override void ItemAttachmentAdding(SPItemEventProperties properties);
 public override void ItemAttachmentDeleted(SPItemEventProperties properties);
 public override void ItemAttachmentDeleting(SPItemEventProperties properties);
 public override void ItemCheckedIn(SPItemEventProperties properties);
 public override void ItemCheckedOut(SPItemEventProperties properties);
 public override void ItemCheckingIn(SPItemEventProperties properties);
 public override void ItemCheckingOut(SPItemEventProperties properties);
 public override void ItemDeleted(SPItemEventProperties properties);
 public override void ItemDeleting(SPItemEventProperties properties);
 public override void ItemFileConverted(SPItemEventProperties properties);
 public override void ItemFileMoved(SPItemEventProperties properties);
 public override void ItemFileMoving(SPItemEventProperties properties);
 public override void ItemUncheckedOut(SPItemEventProperties properties);
 public override void ItemUncheckingOut(SPItemEventProperties properties);
 public override void ItemUpdated(SPItemEventProperties properties);
 public override void ItemUpdating(SPItemEventProperties properties);
}

ListEventReceiver的签名是:

public class CategoryListEventReceiver : SPListEventReceiver
{
 public CategoryListEventReceiver();
 public override void FieldAdded(SPListEventProperties properties);
 public override void FieldAdding(SPListEventProperties properties);
 public override void FieldDeleted(SPListEventProperties properties);
 public override void FieldDeleting(SPListEventProperties properties);
 public override void FieldUpdated(SPListEventProperties properties);
 public override void FieldUpdating(SPListEventProperties properties);
}

看方法的命名都能看出来时什么意思,比如:当你添加一个产品时,你也要在库存中添加相应产品,则你应在ItemAdding中操作这段逻辑。如下代码:

public override void ItemAdding(SPItemEventProperties properties)
{
 using (SPWeb web = properties.OpenWeb())
 {
 SPList productList = web.Lists[Common.ProductListName];
 string productName = productList.Fields[Common.ProductFields.ProductName].StaticName;
 string contentType = productList.Fields[Common.ProductFields.ContentType].StaticName;
 string productNameValue = properties.AfterProperties[contentType].ToString();
 int importCount = Int32.Parse(properties.AfterProperties[Common.ProductFields.Count].ToString());
 SPQuery query = new SPQuery();
 query.Query = string.Format("<Where><Eq><FieldRef Name='{0}'/><Value Type='Text'>{1}</Value></Eq></Where>", productName, productNameValue);
 SPListItemCollection items = productList.GetItems(query);
 SPListItem item = null;
 if (items.Count > 0)
 {
 item = items[0];
 int productCount = Int32.Parse(item[Common.ProductFields.Count].ToString());
 item[Common.ProductFields.Count] = productCount + importCount;
 item.Update();
 }
 else
 {
 item = productList.Items.Add();
 item[Common.ProductFields.ContentType] = productNameValue;
 item[Common.ProductFields.ProductName] = productNameValue;
 item[Common.ProductFields.Count] = importCount;
 item.Update();
 }
 properties.AfterProperties[productName] = productNameValue;
 }
}

这里就不将代码一一贴出来了,我将所有代码打包提供下载,下面就看看运行效果:

我在Import Product列表中增加产品TV数量为3:

image

然后你单击Product列表,则产品TV也自动添加到Product列表中。

image

转载于:https://www.cnblogs.com/IsNull/archive/2010/06/14/1758052.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
内容介绍 项目结构: Controller层:使用Spring MVC来处理用户请求,负责将请求分发到相应的业务逻辑层,并将数据传递给视图层进行展示。Controller层通常包含控制器类,这些类通过注解如@Controller、@RequestMapping等标记,负责处理HTTP请求并返回响应。 Service层:Spring的核心部分,用于处理业务逻辑。Service层通过接口和实现类的方式,将业务逻辑与具体的实现细节分离。常见的注解有@Service和@Transactional,后者用于管理事务。 DAO层:使用MyBatis来实现数据持久化,DAO层与数据库直接交互,执行CRUD操作。MyBatis通过XML映射文件或注解的方式,将SQL语句与Java对象绑定,实现高效的数据访问。 Spring整合: Spring核心配置:包括Spring的IOC容器配置,管理Service和DAO层的Bean。配置文件通常包括applicationContext.xml或采用Java配置类。 事务管理:通过Spring的声明式事务管理,简化了事务的处理,确保数据一致性和完整性。 Spring MVC整合: 视图解析器:配置Spring MVC的视图解析器,将逻辑视图名解析为具体的JSP或其他类型的视图。 拦截器:通过配置Spring MVC的拦截器,处理请求的预处理和后处理,常用于权限验证、日志记录等功能。 MyBatis整合: 数据源配置:配置数据库连接池(如Druid或C3P0),确保应用可以高效地访问数据库。 SQL映射文件:使用MyBatis的XML文件或注解配置,将SQL语句与Java对象映射,支持复杂的查询、插入、更新和删除操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值