日期:2010-12-14  浏览次数:20939 次

早在window2000发布时就已经产生了COM+,并集成在操作系统中,在

运行的时候是以服务的形式存在的。COM+增加了一系列的MTS(一种系统服务,

用于管理数据库中的持久性数据,也处理在事务中的持久性消息队列和文件系统

)服务:

1、事务服务:它确保了在分布式系统中的数据完整性。

2、安全服务:它的安全模型提供了处理安全性而不用编写任何代码的方法。

3、同步服务:提供了有管理地解决组件中并发问题的方法,但却不用编写代码

4、资源管理:(包括资源管理器和资源分配器)管理数据库连接、网络连接和

内存等。

5、JIT激活:即(Just In Time)是从MTS继承下来的一项服务,当客户调用时才

将该对象的一个实例保持为活跃状态并缓存在服务器内存中,使用完对象后,会

通知MTS环境可以释放该对象所占用的资源了,如数据库连接。

6、对象池:提供一个线程池来存放现成的对象,以供下次再用,是系统的一项

自动服务。当有应用程序访问COM+组件时,即为应用程序创建该组件的一个实例

并存放在对象池中,应用程序关闭后即销毁实例,可以自由配置组件使它的实例

在池中的状态,实现了实例的重用性,提高应用程序的性能和伸缩性。

7、基于角色的安全:这个容易理解,即验证角色,给予安全许可,给不同的用

户予不同的权限。

8、队列组件(MSMQ):提供异步消息队列,可以自动按其形式将数据转换成数

据包。

9、共享属性管理器(SPM):用来管理存储在内存中的对象状态信息,在一个服

务器进程内可以用来共享多个对象间的状态,并提供并发处理。

10、补偿资源管理器(CRM):用于在处理事务期间生成日志文件并可处理系统

崩溃。包括CRM工作器(是CRM的主要部分,通过CRM的基础设施提供的接口将事

务的相关信息写入日志,并在需要时检索日志文件)和CRM补偿器(用于在事务

完成后,将事务和生成的日志文件提交给执行事务的用户)。

11、并发:即允许一个应用程序中的多个进程同时运行,进程被分成各组上下文

(有相同需求的对象集合)包含在单元(一个进程内的一组上下文)中,一个进

程可包含多个上下文,都涉及到不同的需求的对象而且每个上下文都有一个唯一

的COM对象来提供COM+事务处理和JIT激活等服务。

 利用COM+提供的工具可以创建执行交易的多层应用程序,还可以处理线程分配

的问题。OK,介绍完COM+的功能下面再介绍COM+的类型。

        COM+有几种不同用途的类型:

1、应用程序代理:包含应用程序注册信息的文件,即当有客户访问远程计算机

的服务器程序时,运行在客户端的应用程序代理就会将服务器应用程序的信息写

入客户端器计算机中。

2、服务器应用程序:即在COM+应用程序本身的进程内执行COM+应用程序,同时

使用并发性来处理组件。

3、库应用程序:是在客户应用程序的进程内执行的,装载在客户应用程序进程

内的,使用基于任务的安全性,缺点是不支持远程访问和队列组件。

4、COM+预安装应用程序:到管理工具中的组件服务中的COM+应用程序文件夹中

查看就明白什么是COM+预安装应用程序了,它是在COM+安装过程中自动安装进组

件服务的应用程序,不能修改也不能删除。

   同时涉及到一个叫“程序集(Assembly )”的概念:它是CLR所有类型和其

它资源(如位图文件等)的集合。可通过管理工具下的“配置.NET框架”来查看

。包括有私有和共享的程序集。

私有程序集:它只能被放在与该程序集相同路径的应用程序访问。默认为私有,

必须放在使用它的应用程序的文件夹中。

共享程序集:指添加在GAC(Global Assembly Cache)中的程序集。GAC是专门

用来存放程序集中,使应用程序可以共享这些程序集,有一点必须注意,就是存

放在GAC中的程序集必须有一个唯一的名字,可以通过在.NET命令执行窗口中打

入sn -k assemblyname.snk 来生成一个唯一的名称,叫做强名称,生成强名称

后,会有一个公钥附加在此程序集上,用于阻止名字相似而被代替的危险。

  .NET中对程序集的安全性提供了两种机制:一种是前面提到的强名称,一种

是使用Signcode(可理解为数字签名)。Signcode.exe用来标记一个程序集,同时

嵌入一个数字签名到程序集中,可以让用户识别创建此程序集的开发者。

(注:在GAC中不能有两个相同名称的强名称,否则就不叫强名称了,但可以存储一个程序集的多个拷贝而且在GAC中的程序集只能被拥有一定权限的用户删除)

  关于程序集的版本号:每一个版本都有一个128位的版本号,表示为四部

分:Major(为主版本号,项目有变化时即改变).Minor(添加一个功能到项目时改

变).Build.Revision(后两个是自动更新的),这些版本信息可以通过在应用

程序中的AssemblyInfo.cs文件来查看。

  又是一堆的理论,下面介绍COM+的应用:

在.NET中使用COM+服务的组件就叫做.NET服务组件,跟一般的组件不同,区别在

于前者使用了COM+服务。使用.NET服务组件的目的也就是为了可以访问COM+服

务的一些基类如ServicedComponent和自动挛翊恚剩桑裕韵蟪睾桶踩?/P>

方面等。

在使用.NET服务组件之前都必须注册服务组件,有三种方式:

1、手动注册:通过RegSvcs.exe命令行工具来注册,如:Regsvcs

yourcomponent.dll 之后将产生一个yourcomponent.tlb类型库,包含了对象的

类型信息(注意在使用该命令前必须先注册一个yourcomponent的强名称)

2、编程注册:使用RegistrationHelper类,主要是利用在

IregistrationHelper接口中的方法。

3、动态注册:是指在执行应用程序过程中,检查安装组件的版本,如组件的正

确版本没安装,则在运行时自动安装需要的版本,即自动注册。(注:调用自动

注册的用户必须是Window2000 Administrative组的一个成员,因为动态注册无

法改变COM+ 目录,否则注册过程失败)

   OK,终于写完了,接着看实例:

----------------------------------------------------------------------------------------------------------

using System;
using System.EnterpriseServices; // 必须引入的名空间
using System.Reflection; // 必须引入的名空间
using System.Windows.Forms;

[assembly:ApplicationName("Calcomp")]
[assembly:AssemblyKeyFileAttribute("Calcomp.snk")] //必须先注册一个叫Calcomp.snk的强名称,同时注释掉在项目里AssemblyInfo.cs文件中的[assembly:AssemblyKeyFileAttribute("")],否则就重复定义。

namespace Calcomp
{
 
 public interface ICommission
 {
  void CommissionCal(string name,int salesamt);
 }
 public class Calcomp:ServicedComponent,ICommission // 继承ServicedComponent使之成为一个服务组件
 {
  public void CommissionCal(string name,int salesamt)
  {
   double comm;
   //String msgstring;
 &n