1.3. 引用netClassMessage_PromoteXSD项目
一. 本示例的用途
本示例演示如何在orchestration中使用.net class类型的消息。.net class类型消息进入到orchestration中始终保持同类型消息之间的转换,输出也是同一个消息类型。如何在.net class类型中定义序列化,定义升级属性、可分辨字段。
大致步骤如下:
l 从file适配器读取一个.net class类型的消息到orchestration。
l 在orchestration中把入站的.net class 赋给一个同类的消息,然后对新构造的消息就行一些处理,示例中仅做一个简单的修改属性的处理。
l 最后把处理好的.net class消息输出到一个文件夹。
本示例的完整代码下载(netClassMessage.rar)
二. 新建解决方案
新建一个空解决方案,名字为netClassMessage,解决方案作为下面所有项目的容器,其后建的各个项目都放在这个解决方案中。
在解决方案根目录下新建一个强名称密钥文件,biztalk项目生成的assembly需要部署到GAC,需要密钥文件。这里生成密钥文件netClassMessage.snk
如何生成密钥文件见biztalk随机文档:Getting Started > BizTalk Server 2006 Tutorials > Before You Begin the Tutorials >Step 4: Create a Strong Name Key File
三. 属性架构biztalk项目
本示例中使用的.net class类型消息包含了升级属性和可分辨字段,在xml消息中定义升级属性需要有一个属性架构,同样,.net class类型中升级属性也需要同样的属性架构。.net class类型消息是一个.net类,在.net类库项目中定义,而属性架构是biztalk中才有的概念,需要在biztalk项目定义,这样消息类和属性架构不可能在同一个项目中。.net class类型消息要使用到属性架构,所以.net class类型消息所在的.net class类库项目要引用属性架构所在的biztalk项目。
这一步建立属性架构所在的biztalk项目。
1. 新建属性架构的biztalk项目
在netClassMessage解决方案中新建一个biztalk项目,名称为netClassMessage_PromoteXSD。
设置项目属性,打开netClassMessage_PromoteXSD项目属性窗口
1.1. 指定密钥文件
在左边选“通用属性 ― assembly”,然后在右边的“strong name - Assembly key file”中指定密钥文件,指向上面生成的那个密钥文件netClassMessage.snk的路径。
1.2. 设置部署属性
在左边选“配置属性 ― deployment”,“server”设为开发用的本机机器名,“Application name”设为netClassMessage,“Redeploy”、“Install to Global Assembly Cache”、“Restart Host Instance”都设为true,为什么这么设置,请见“开发环境中biztalk项目设置注意事项”。
2. 新建属性架构
在netClassMessage_PromoteXSD项目中添加一个新项,在打开的“添加新项”窗口中,左边选“schema files”,在右边选“Property Schema”,架构名称设为PromotedProperties.xsd,确定。
在新建的PromotedProperties.xsd中把默认的“property1”名称改为PropertyName,保存。本示例就使用一个升级属性PropertyName。
四. .net class消息项目
这是个C#的类库项目,这个项目里将要定义.net class类型消息的类。
1. 新建类库项目
在netClassMessage解决方案中新建一个C#类库项目,名称为netClassMessage_netClass。
把前面生成的密钥文件netClassMessage.snk拷贝到这个项目的根目录下。因为这个.net class类型的消息要被biztalk使用,所以消息类所在的assembly也要被部署到GAC,这个类库dll也必须要有强名称密钥。
设置项目属性,打开netClassMessage_netClass项目属性窗口。
1.1. 指定密钥文件
在左边选“签名”,在右边“为程序集签名”前打勾,然后在下面选择密钥文件,指向项目根目录的那个netClassMessage.snk文件的路径。
1.2. 设置生成事件
在左边选“生成事件”,右边“生成后事件命令行”中输入以下代码:
CALL "%VS80COMNTOOLS%\vsvars32.bat" > NUL
GACUTIL /if "$(TargetPath)"
这两行代码是告诉编译器,把每次这个项目编译完后生成的dll加载到GAC中,如果GAC中已经有了同样的dll,则直接覆盖。这样保证每次编后后都能自动将最新版的dll加载到GAC,省去手工把dll加入到GAC的麻烦。
1.3. 引用netClassMessage_PromoteXSD项目
消息类中有升级属性,需要用到属性架构,所以在项目中要引用前面建立的属性架构的项目。
2. 新建.net class类型消息的类
在netClassMessage_netClass项目中添加一个新项,在打开的“添加新项”窗口中,选“类”,类名称设为netClass.cs,确定。
此类的代码如下:
using System; using Microsoft.XLANGs.BaseTypes; namespace netClassMessage_netClass { //表示此类是可以序列化的 [Serializable()] //此属性设置目标名称空间Target Namespace [System.Xml.Serialization.XmlRootAttribute(Namespace = "http://myURL")] //类名称相当于XSD中的根元素,上面设定的名称空间加上类名称就组成了消息类型 public class netClass { private string _ID; private string _name; private string _address; private string _propertyName; public netClass() { _ID = System.Guid.NewGuid().ToString(); } //DistinguishedField属性表示这个字段是可分辨字段 [DistinguishedField] public string ID { get { return _ID; } set { _ID = value; } } [DistinguishedField] public string Name { get { return _name; } set { _name = value; } } [DistinguishedField] public string Address { get { return _address; } set { _address = value; } } [DistinguishedField] //netClassMessage_PromoteXSD.PropertyName是在属性schema中定义的属性,此Property属性 //指示这个字段为promote字段,对应netClassMessage_PromoteXSD.PropertyName [Property(typeof(netClassMessage_PromoteXSD.PropertyName))] public string PropertyName { get { return _propertyName; } set { _propertyName = value; } } } } |
这个消息类的详细说明见“biztalk中使用.net class类型的消息(一) -- 相关知识介绍”。
五. Orchestration流程biztalk项目
上面定义了属性架构和.net class消息类,现在要开始设计业务流程,使用这个.net class消息。
1. 新建Orchestration流程biztalk项目
步骤跟属性架构项目一样,在netClassMessage解决方案中新建一个biztalk项目,名称为netClassMessageProcessProject。
设置项目属性,打开netClassMessageProcessProject项目属性窗口
1.1. 指定密钥文件
在左边选“通用属性 ― assembly”,然后在右边的“strong name - Assembly key file”中指定密钥文件,指向上面生成的那个密钥文件netClassMessage.snk的路径。
1.2. 设置部署属性
在左边选“配置属性 ― deployment”,“server”设为开发用的本机机器名,“Application name”设为netClassMessage,“Redeploy”、“Install to Global Assembly Cache”、“Restart Host Instance”都设为true,为什么这么设置,请见“开发环境中biztalk项目设置注意事项”。
2. 建立rchestration流程
在netClassMessageProcessProject项目中添加一个orchestration,名称为MessageProcess.odx。
2.1. 新建两条消息
新建一条消息,名称netClassMsg,消息类型选.net class,然后选“select from referenced”,在弹出“select artifact type”窗口中,左边选“netClassMessage_netClass”assembly,窗口右边会出现这个assembly所包含的.net classs,这里为“netClass”。完整的消息类型就是netClassMessage_netClass.netClass
再新建一条消息,名称为new_netClassMsg,消息类型跟上面那个消息一样。
第一条消息作netClassMsg为一个.net class类型消息进站后的接收形状接收到的消息,第二个消息为新建的一个.net class类型消息,然后把第一条消息的相关属性赋给第二条消息的相关属性,相当于把入站的消息就行了转换。最后把新消息直接输出。
2.2. 设计流程
设计流程,添加端口,接收发送形状,消息构造形状,如图:
l 端口ReceivePort
设置端口类型为ReceivePortType,单项one-way,端口通讯方向为“I’ll always receiving on message this port”,端口绑定设为“specify later”。
l 接收形状Receive_1
消息设为netClassMsg
l 消息赋值形状MessageAssignment_1
消息赋值形状中,输入以下代码:
//.net class消息只能通过new操作符构造。
new_netClassMsg = new netClassMessage_netClass.netClass();
//将入站的消息的相应属性赋给新消息
new_netClassMsg.Name = netClassMsg.Name;
new_netClassMsg.Address = netClassMsg.Address;
new_netClassMsg.PropertyName = "new Property";
l 发送形状Send_1
消息设为new_netClassMsg
l 端口SendPort
设置端口类型为SendPortType,单项one-way,端口通讯方向为“I’ll always sending on message this port”,端口绑定设为“specify later”。
3. 编译部署项目
编译整个解决方案,然后部署整个解决方案。
前面每个项目的属性都已经设置好,部署好后,两个biztalk项目的将被部署到biztalk的netClassMessage应用程序中,类库项目也会被部署到GAC中。
4. 设置物理端口
打开biztalk server adminstration,在Applictions中会发现多了个刚才部署的netClassMessage应用程序,配置这个应用程序。
对应ReceivePort逻辑接收端口新建一个接收端口,一个接收位置,适配器类型为File,路径指向解决方案中新建的目录“in”,接收管道选XMLReceive,一定要选XMLReceive,因为这个XML拆装器能解析.net class类型的消息(跟xml消息一样处理,在管道中.net class消息也是一个xml)。
对应SendPort逻辑端口新建一个发送端口,适配器类型为File,路径指向解决方案中新建的目录“out”,接收管道选XMLReceive或者PassThruTransmit都行。
配置完成,启动netClassMessage应用程序。
六. 测试示例
1. net class类型消息的序列化示例
本示例使用.net class类型的消息放置在解决方案的in目录下通过file适配器读入到orchestration。需要一个本例中.net class消息类型netClassMessage_netClass.netClass序列化后的消息文件。
如何根据.net class类型生成一个消息实例的序列化后的文件呢?
Dotnet framework SDK中提供了一个实用工具xsd.exe,可以把.net class消息类型转换成xsd架构类型。
本示例.net class消息类型的assembly为netClassMessage_netClass.dll命令大致如下:
XSD netClassMessage_netClass.dll
在同一目录下就会产生一个叫schema0.xsd的文件,就是这个.net class类型消息对应的xsd的架构,本示例生成的架构是这样的:
<?xml version="1.0" encoding="utf-8"?> <xs:schema xmlns:tns="http://myURL" elementFormDefault="qualified" targetNamespace="http://myURL" xmlns:xs="http://www.w3.org/2001/XMLSchema"> <xs:element name="netClass" nillable="true" type="tns:netClass" /> <xs:complexType name="netClass"> <xs:sequence> <xs:element minOccurs="0" maxOccurs="1" name="ID" type="xs:string" /> <xs:element minOccurs="0" maxOccurs="1" name="Name" type="xs:string" /> <xs:element minOccurs="0" maxOccurs="1" name="Address" type="xs:string" /> <xs:element minOccurs="0" maxOccurs="1" name="PropertyName" type="xs:string" /> </xs:sequence> </xs:complexType> </xs:schema> |
然后根据这个xsd文件就能在biztalk中自动生成一个xml实例,关于从xsd架构生成xml实例请见“biztalk中架构验证、实例生成和验证”
生成一个消息实例后,取名netClassMessage.xml,放到解决方案根目录备用。
消息文件如下:
<ns0:netClass xmlns:ns0="http://myURL">
<ns0:ID>ID_0</ns0:ID>
<ns0:Name>Name_0</ns0:Name>
<ns0:Address>Address_0</ns0:Address>
<ns0:PropertyName>PropertyName_0</ns0:PropertyName>
</ns0:netClass>
2. 测试
把上面生成的实例消息文件netClassMessage.xml拷贝到解决方案下的“in”目录,过一会看解决方案下的“out”目录,应该会多出一个类似“{FA0DCEA1
<?xml version="1.0"?>
<netClass xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns="http://myURL">
<ID>896afea7-e
<Name>Name_0</Name>
<Address>Address_0</Address>
<PropertyName>new Property</PropertyName>
</netClass>