** 使用 ** ** Websharp Service Locator **
** 简化分布式系统开发 **
什么是 Websharp Service Locator
对于多层的应用系统来说,我们通常把它们划分成客户端、应用服务层和数据库。在应用服务层,我们需要考虑至少两个方面的问题:
ü 如何实现业务逻辑
ü 如何向客户端提供服务。
我们可能使用多种技术来实现服务的提供: Webservice 、 .Net Remoting 、甚至 EJB 等。如此多的实现技术,带来的很大的灵活性,但同时也带来了问题,其中一个就是,有多少种服务端技术,就得有多少种相应的客户端访问技术。甚至,在某些分布式应用系统中,应用逻辑使用不同的技术开发,存在于不同的机器上,有的存在于客户机本机,有的使用 .Net Remoting 开发,存在于局域网内,有的使用因特网上的 Web Service ,有的时候,我们希望相同的业务逻辑能够支持不同的客户端。
在这种情况下,我们需要一个一致的服务访问编程模型,以统合不同的服务访问模式,简化系统的开发和部署。 Websharp Service Locator (以下简称 WSL )提供了这样一种能力,开发人员只需要定义服务访问接口,就可以使用一致的方式透明的访问这些服务,而不用理会这些服务之间的不同点。框架会自动生成访问远程服务需要的代理。
Websharp 是 sourceforge 上的一个新的开源项目,目标是提供一个 .Net 环境下的轻量级的应用系统框架,它包含了三个主要内容:一个 O/R Mapping 框架,一个 AOP 框架,以及一个 Service Locator 。 Service Locator 目前还只完成本地程序集定位器、 WebService 定位器和 .Net Remoting 定位器的初步开发,但是,我们已经可以使用它提供的框架功能来为我们的开发提供助力。 Websharp Service Locator 下面的目标是实现对 J2EE 的访问。可以从 http://www.sourceforge.net/projects/websharp/ 下载所有源代码。
Websharp Service Locator 的主要接口
WSL 是一个轻量级的框架,非常易于使用和扩展。如果想使用 WSL ,那么只有一个类需要打交道: ServiceLocator ,它的定义如下:
public abstract class ServiceLocator
{
public static object FindService( string serviceName,Type clientInterface)
}
如果你想用自己的定位器扩展这个框架,那么,只有一个接口需要扩展: IServiceLocator 。这个接口非常简单,只有一个方法:
public interface IServiceLocator
{
object FindService( string serviceName,Type clientInterface);
}
Websharp Service Locator 的配置文件
需要在三个地方配置 WSL 。
首先,在 configSections 节中,注册 WSL 配置文件处理类的 的相关信息,配置方法如下:
< configSections >
< section name ="Websharp.Enterprise"
type ="Websharp.Enterprise.EnterpriseConfigHandler,Websharp" />
configSections >
然后,在 Websharp.Enterprise 节中,注册不同的服务定位器。如果你自己扩展了这个框架,添加了新的服务定位器,也在这里注册。其中, locator 属性的格式是:“类全名 ,Assembly 名”。 服务定位器都是 Singleton 的。下面是目前 WSL 支持的服务定位器的注册的信息:
< Websharp.Enterprise >
< ServiceTypes >
< ServiceType name ="LocalAssembly"
locator ="Websharp.Enterprise.LocalAssemblyLocator,Websharp" />
< ServiceType name ="WebService"
locator ="Websharp.Enterprise.WebServiceLocator,Websharp" />
< ServiceType name ="DotNetRemoting"
locator ="Websharp.Enterprise.DotNetRemotingLocator,Websharp" />
ServiceTypes >
Websharp.Enterprise >
最后,在 Websharp.Enterprise 下的 Services 节中,注册每个服务。每个 Service 需要的属性取决于不同的 Locator 的实现,但是, name 、 service-type 和 deploy-model 是必须的。对于 deploy-model ,可以有两种属性值: Singleton 和 MultiInstance 。
下面是一个例子:
< Websharp.Enterprise >
< ServiceTypes >
< ServiceType name ="LocalAssembly"
locator ="Websharp.Enterprise.LocalAssemblyLocator,Websharp" />
< ServiceType name ="WebService"
locator ="Websharp.Enterprise.WebServiceLocator,Websharp" />
< ServiceType name ="DotNetRemoting"
locator ="Websharp.Enterprise.DotNetRemotingLocator,Websharp" />
ServiceTypes >
< Services >
< Service name ="HelloWorld" service-type ="LocalAssembly" deploy-model ="Singleton"
type ="EnterpriseClient.HelloWorld,EnterpriseClient" />
< Service name ="HelloWorldWebService" service-type ="WebService"
deploy-model ="Singleton"
url ="http://localhost/webservicetest/hello.asmx"
namespace ="http://www.websharp.org/webservices/" />
Services >
Websharp.Enterprise >
注:对于配置文件,在 Web 项目中,可以是 web.config 文件,对于 Windows 项目,可以自己为项目添加一个 app.config 配置文件。关于 .net 项目配置文件的更多内容,请参考 MSDN 的相关文档。
如何使用 Websharp Service Locator?
使用 WSL ,一般的方法是这样的:
1. 定义一个同你需要访问的服务一致的接口(当然,如果你的服务是实现某个接口的,可以直接使用该接口)。接口的方法名和参数必须同服务类的方法名和参数一致。如果你的方法名和服务的方法名不一致,那么,可以使用 ServiceMethodNameAttribute 来指明服务的方法名。
2. 在配置文件按中注册你需要访问的服务。
3. 调用 ServiceLocator 的 FindService 方法 .
4. 调用接口的方法。 .
下面是一些例子,这些例子使用 visual studio.net 2003 开发,同样可以从 sourceforge 下载。
LocalAssemblyLocator 的 Hello World 例子
按照以下步骤进行:
1. 创建一个名为 “EnterpriseClient” 的 windows console 项目 , 加入 Websharp.dll 的引用。
2. 添加一个类,名为 “HelloWorld” ,然后添加一个名为 “GetHello” 的方法,代码如下:
public class HelloWorld
{
public string GetHello( string hello)
{
return hello;
}
}
3. 添加一个名为 “IHelloWorld” 的接口,代码如下:
public interface IHelloWorld
{
string GetHello( string hello);
[ServiceMethodName("GetHello")]
string GetHello2( string hello);
}
4. 填写配置文件
xml version ="1.0" encoding ="utf-8" ?>
< configuration >
< configSections >
< section name ="Websharp.Enterprise"
type ="Websharp.Enterprise.EnterpriseConfigHandler,Websharp" />
configSections >
< Websharp.Enterprise >
< ServiceTypes >
< ServiceType <SPAN style="COLOR: r