雖然Biztalk Server提供了眾多的內置功能,然而在一些情況下可能還需要調用程序集中的函數。因為在.Net程序集中,可以非常方便地調用Web Service、訪問數據庫;另一方面,有些函數是程序集中已經寫好的,為了增加軟件的復用,便於軟件版本的管理,使用現有的程序集也在情理之中。
本文通過一個簡單實例,介紹Biztalk應用中調用程序集的方法。這個實例完成的功能,在調用Web Services一文中實現過,只不過實現的方式用所差別,一個是調用Web Service,一個是調用.net程序集。
首先,我們創建一個MyFunction的項目,其中只包括一個的類文件class1,我們要在Biztalk中調用該類的CheckUserId靜態方法。class1的源程序如下:
using System; namespace MyFunction { public class UserManager { public UserManager() { } public static string CheckUserId(string strUserId) { if (strUserId == "fengfangfang") { return "Administrator"; } else { return "User"; } } } }
為程序集設置強名稱和發布.Net程序集到全局程序集緩存可參見將程序集安裝到全局程序集緩存(GAC)中一文。
然後,創建一個Biztalk Server工程CallFunction,添加一個UserInfo.xsd,其結點結構如下:
UserInfo
UserId
RoleName
快速升級UserId和RoleName兩個子字段元素,具體步驟可參見調用Web Services一文。
下面創建一個業務流程MainOrch.odx,在業務流程視圖中創建兩個消息InMsg和OutMsg,這兩個消息均使用CallFunction.UserInfo消息類型。在業務流程中創建一個接收操作ReceiveInMsg、一個發送操作SendOutMsg,在二者之間創建一個消息賦值操作AssignOutMsg,同時會產生一個構造消息操作,命名為ConstructOutMsg,構造的消息為OutMsg。設置ReceiveInMsg激活為True。
為工程CallFunction添加.Net引用,找到MyFunction.dll,添加到引用中。編寫AssignOutMsg的表達式如下:
OutMsg = InMsg;
OutMsg(CallFunction.PropertySchema.RoleName)= MyFunction.UserManager.CheckUserId(InMsg(CallFunction.PropertySchema.UserId));
創建一個接收端口InPort用於連接接收操作、一個發端端口OutPort用於連接發送操作。兩個端口均使用Microsoft.BizTalk.DefaultPipelines.XMLTransmit管道,接收地址為c:\in\*.xml,發送地址為c:\out\%SourceFileName%。
編譯並布署Biztalk Server工程CallFunction,啟動CallFunction.MainOrch業務流程,進行測試:
測試文件fengfangfang.xml
<ns0:UserInfo xmlns:ns0="http://CallFunction.UserInfo"> <UserId>fengfangfang</UserId> <RoleName></RoleName> </ns0:UserInfo>
輸出為
<ns0:UserInfo xmlns:ns0="http://CallFunction.UserInfo"> <UserId>fengfangfang</UserId> <RoleName>Administrator</RoleName> </ns0:UserInfo>
測試文件fengff.xml
<ns0:UserInfo xmlns:ns0="http://CallFunction.UserInfo"> <UserId>fengff</UserId> <RoleName></RoleName> </ns0:UserInfo>
輸出為
<ns0:UserInfo xmlns:ns0="http://CallFunction.UserInfo"> <UserId>fengff</UserId> <RoleName>User</RoleName> </ns0:UserInfo>