演练 (AS2):通过 AS2 发送非 EDI 消息
本演练介绍创建一个通过 AS2 发送非 EDI 消息的解决方案的分步操作步骤。 在本演练中,PIDX 消息将通过 AS2 发送。 此解决方案将结合使用双向发送端口和 AS2Send 发送管道及 AS2Receive 接收管道。 您可以在单台计算机上创建并测试本演练中的完整解决方案。
必备条件
以下为执行本主题中的过程的前提条件:
必须以“BizTalk Server管理员”或“BizTalk Server B2B 操作员”组的成员身份登录。
运行演练的计算机必须安装了 Internet 信息服务 (IIS)。
如果运行此演练的计算机安装了 64 位版本的 Windows,则您必须确保 BizTalk 主机标记只能为 32 位。 还必须确保 IIS 已将“为应用程序池启用 32 应用程序设置”设置为 True。 有关详细信息,请参阅 教程 3:AS2 教程。
解决方案如何发送非 EDI/AS2 消息并返回同步 MDN
该解决方案将执行以下操作:
一个单向文件接收端口从 Contoso 接收 XML 消息。
注意
此列表中的事件可能不会按所示顺序发生。
该接收端口使用 XML 接收管道对消息进行检查。 该接收端口随后会将测试消息原样放入 MessageBox。
静态双向发送端口提取 XML 消息,并订阅该接收端口接收到的所有消息。
Fabrikam 的双向接收端口使用 Fabrikam 虚拟目录接收 AS2 消息。 接收管道会将来自 AS2 的消息解码并放入 MessageBox。
具有直通发送管道的静态单向发送端口接收 XML 消息。
单向发送端口将 XML 消息发送到本地文件夹。
与双向接收端口关联的发送端口返回同步 MDN。
与双向发送端口关联的接收端口接收 MDN 并将其放入 MessageBox。
带有直通发送管道的静态单向发送端口提取 MDN。
该单向发送端口将 MDN 发送至本地文件夹。
下图显示了解决方案的体系结构。
通过 AS2
此解决方案中的功能
本演练的功能具有以下特点:
本演练介绍的是 AS2 功能。 因此,AS2 处理所涉及的所有端口都使用 AS2Receive 或 AS2Send 管道。 AS2 处理未涉及到的端口使用 XMLReceive 或 PassThruTransmit 管道。
本演练使用 XML 测试消息。
注意
您必须提供一条 XML 测试消息和适用于该测试消息的架构。
状态报告未启用。
此解决方案不在不可否认数据库中配置签名、压缩、加密或消息存储。 有关配置这些属性的过程,请参阅 配置 AS2 属性。
配置和测试演练
该解决方案所需的过程包括:
使用所需的消息架构生成和部署 BizTalk 项目,使架构可供BizTalk Server在处理收到的消息时使用。
启用接收 AS2 消息时使用的 BTS ISAPI 筛选器。
按照接收位置中的配置,创建一个用于从 Contoso 接收 AS2 消息的 Fabrikam 虚拟目录。
指定 Fabrikam 虚拟目录不由 Windows SharePoint Services 托管。
创建一个用于接收将通过 AS2 传输类型发送的 XML 测试消息的单向 FILE 接收端口。 创建接收测试消息的本地文件夹。
创建一个静态要求响应 HTTP 发送端口,同时将发送管道配置为 AS2Send 管道,接收管道配置为 AS2Receive 管道。 该端口会将 AS2 消息发送到 Fabrikam,接收来自 Fabrikam 的 MDN 响应并将其放入消息框。
为 BizTalk Server 创建一个用于接收 AS2 消息和发送 MDN 响应的双向 HTTP 接收端口。 将接收管道配置为 AS2Receive 管道,将发送管道配置为 AS2Send 管道。 配置用于接收经 Fabrikam 虚拟目录发送的 AS2 消息的接收位置。
注意
测试解决方案在单台计算机上执行,因此用于从 Contoso 发送 AS2 消息的双向发送端口和作为 Fabrikam 接收 AS2 消息的双向接收端口都在同一计算机上。
创建一个带有直通发送管道的静态单向 FILE 发送端口以将消息 XML 负载发送至本地文件夹。 创建本地文件夹。
注意
如果没有用于订阅该消息负载的发送端口,它将会在 MessageBox 中挂起。
创建一个带有直通发送管道的单向 FILE 发送端口以将 MDN 路由至本地文件夹。 创建本地文件夹。
为 Fabrikam 和 Contoso 创建参与方(贸易合作伙伴)。
为每个交易方创建一个业务配置文件。
在 Fabrikam 和 Contoso 的业务配置文件之间创建一个 AS2 协议。 AS2 协议将包含用于发送 AS2 消息和接收同步 MDN 作为回报的属性。
使用 XML 测试消息测试此演练。
配置演练
本部分介绍配置演练的过程。
部署测试消息架构
在 Visual Studio 中,创建或打开 BizTalk 项目。
注意
本主题假定你已从你的应用程序添加了对包含 EDI 架构、管道和业务流程的 BizTalk EDI 应用程序的引用。 如果没有,请参阅添加对 BizTalk Server EDI 应用程序的引用。
右键单击项目,指向 “添加”,然后单击“ 现有项”。 若要使用 XML 文件测试您的解决方案,请转到包含用于 XML 测试消息的 XSD 架构的本地文件夹,然后选择相应 XSD 文件。 单击“添加”。
设置程序集密钥文件,然后生成并部署该程序集。
启用 BTS ISAPI 筛选器
单击“开始”,指向“所有程序”,指向“管理工具”,然后单击“Internet Information Services (IIS)管理器”。
提示
根据操作系统的不同,“管理工具”开始菜单选项可能不可用。 在这种情况下,单击“ 开始”,单击“ 运行”,然后输入
inetmgr
以打开“Internet Information Services (IIS) 管理器”。选择根 Web 服务器条目,在 “功能视图”中双击“ 处理程序映射 ”,然后在“操作”窗格中单击“ 添加脚本映射”。
注意
在 Web 服务器级别配置脚本映射将导致此映射应用于所有子网站。 如果要将映射限制为特定网站或虚拟文件夹,请选择目标网站或文件夹,而不是 Web 服务器。
在“添加脚本映射”对话框中的“请求路径”字段中输入
BtsHttpReceive.dll
。在“可执行文件”字段中,单击省略号 (...) 按钮,然后浏览到\Program Files (x86) \Microsoft BizTalk Server <VERSION>HttpReceive。 选择“BtsHttpReceive.dll”,然后单击“ 确定”。
在 字段中输入
BizTalk HTTP Receive
,然后单击“请求限制”。Name
在“ 请求限制 ”对话框中,选择“ 谓词 ”选项卡,然后选择 以下谓词之一。 输入
POST
作为谓词。在“ 访问 ”选项卡上,选择“ 脚本 ”,然后单击“ 确定”。
单击“ 确定” ,当系统提示允许 ISAPI 扩展时,单击“ 是”。
配置 Fabrikam 网页
在 IIS 管理器中,右键单击“ 应用程序池 ”,然后选择“ 添加应用程序池”。
在“添加应用程序池”对话框中,在“名称”中输入 BizTalkAppPool,然后在“.NET Framework版本”下拉列表中选择“.NET FrameworkV4.0.30210”。 单击 “确定” 。
注意
版本号可能因计算机上安装的 .NET Framework 4.5 版本而异。
选择“应用程序池”,在“功能视图”中选择“BizTalkAppPool”,然后单击“操作”窗格中的“高级设置”。
在 “高级设置” 对话框中,选择“ 标识 ”,然后单击省略号 (...) 按钮。
在 “应用程序池标识 ”对话框中,选择“ 自定义帐户 ”,然后单击“ 设置”。
输入作为管理员组成员的用户帐户的“用户名”和“密码”,在“确认密码”中输入密码,然后单击“确定”三次返回到 IIS 管理器。
在 IIS 管理器中,打开 “站点” 文件夹。 右键单击“ 默认网站” 节点,然后选择“ 添加应用程序”。
在“添加应用程序”对话框中,在“别名”中输入 Fabrikam,然后单击“选择”。
在 “选择应用程序池 ”对话框中,选择“ BizTalkAppPool ”,并单击“ 确定”。
单击省略号 (...) 按钮,然后浏览到物理路径的 \Program Files (x86) \Microsoft BizTalk Server <VERSION>HttpReceive。
单击 “测试设置” ,并验证“ 测试连接 ”对话框中是否未显示任何错误。 单击“关闭”,然后单击“确定”。
在 IIS 管理器中,选择 Fabrikam 虚拟目录,然后在 “功能视图”中双击“ 身份验证”。
在 “身份验证 ”页中,选择“ 匿名身份验证 ”,并验证 “状态” 是否为 “已启用”。 如果“状态”为“已禁用”,请单击“操作”窗格中的“启用”。
指定虚拟目录不由 Windows SharePoint Services 托管
如果计算机上安装了Windows SharePoint Services,请单击“开始”,指向“所有程序”,指向“管理工具”,然后单击“SharePoint 3.0 管理中心”。
注意
如果用于设置演练的同一计算机上还安装了 Windows SharePoint Server,则此过程是必需的。 在该情况下,您必须指定 IIS 虚拟目录不由 Windows SharePoint Server 托管。
在 “管理中心 ”页上的“ 管理中心”下,单击“ 应用程序管理”。
在 “应用程序管理 ”页上,单击“ 定义托管路径”。
在 “定义托管路径” 页的 “添加新路径”下的“ 路径 ”文本框中,输入
Fabrikam
。 在 “类型”下,单击“ 排除的路径”,然后单击“ 确定”。
创建接收端口以接收测试消息
在 Windows 资源管理器中,创建一个用于从 Contoso 接收 EDI 交换的本地文件夹。
在BizTalk Server管理控制台中,右键单击 BizTalk 应用程序 1 节点下的“接收端口”节点,指向“新建”,然后单击“单向接收端口”。
在“ 接收端口属性 ”对话框中,将接收端口命名为 RecvXMLFromCont。
在控制台树中单击“ 接收位置 ”,然后单击“ 新建”。
命名接收位置,为“类型”选择“文件”,然后单击“配置”。
对于 “接收文件夹”,输入在步骤 1 中创建的文件夹的名称。
在 “文件掩码”中,输入 *.xml,然后单击“ 确定”。
在“接收管道”中,选择“ XMLReceive”。
注意
如果使用 XML 以外的其他非 EDI 文件类型,请输入 PassThruTranmit。
依次单击“确定”和“确定”。
单击“ 接收位置” 节点,右键单击接收位置,然后单击“ 启用”。
创建发送端口以将 AS2 消息发送到 fabrikam
在 BizTalk Server 管理控制台中,右键单击 BizTalk Application 1 节点下的“发送端口”节点,指向“新建”,然后单击“静态 Solicit-Response 发送端口”。
注意
如果使用的是 BizTalk Application 1,则必须将 BizTalk Application 1 中的引用添加到 BizTalk EDI 应用程序,以便您的应用程序使用其项目。 有关详细信息,请参阅添加对 BizTalk Server EDI 应用程序的引用。
在“ 发送端口属性 ”对话框中,将发送端口命名为 SendToFab_RecvMDN。
在“传输”部分中,为“类型”选择“HTTP”,然后单击“配置”。
在“ HTTP 传输属性 ”对话框中,为 “目标 URL”输入 http://localhost/Fabrikam/BTSHttpReceive.dll。
清除 “启用分块编码”。 单击 “确定” 。
对于 “发送管道”,请选择“ AS2Send”。
对于 “接收管道”,请选择“ AS2Receive”。
在控制台树中,选择“ 筛选器”。 对于 “属性”,请输入 BTS。ReceivePortName;对于 “运算符”,请输入 ==;对于 “值 ”,请输入接收 EDI 交换 (
RecvXMLFromCont
) 的接收端口的名称。注意
如果要发送 PIDX 消息,可以创建一个筛选表达式,用于筛选 PIDX) (消息的类型。
如果要应用映射来转换 XML 文档,请单击控制台树中的“ 出站映射 ”。 输入出站映射的 “源文档 ”,选择“ 映射”,然后输入 “目标文档”。 单击“确定”。
单击“确定”。
在BizTalk Server管理控制台中单击“发送端口”节点,右键单击发送端口,然后单击“启动”。
创建用于接收 AS2 消息并返回确认的接收端口
在 BizTalk Server 管理控制台的 BizTalk 应用程序 1 节点下,右键单击“接收端口”,指向“新建”,然后单击“请求响应接收端口”。
将接收端口命名为 RecvAS2Msg,然后单击控制台树中的“ 接收位置 ”。
单击 “新建” 。
在“接收位置属性”对话框中,为接收位置命名,为“类型”选择“HTTP”,然后单击“配置”。
在“ HTTP 传输属性 ”对话框中,输入 /Fabrikam/BTSHttpReceive.dll 作为 虚拟目录和 ISAPI 扩展。 清除 “成功时返回关联句柄 ”,然后选择“ 挂起失败的请求”。 单击 “确定” 。
为“接收管道”选择“AS2Receive”,为“发送管道”选择“AS2Send”。 依次单击“确定”和“确定”。
单击“ 接收位置” 节点,右键单击接收位置,然后单击“ 启用”。
创建用于将测试 XML 负载发送到本地文件夹的发送端口
在 Windows 资源管理器中,创建一个用于接收 EDI 交换的本地文件夹。
在BizTalk Server管理控制台中,右键单击“发送端口”,指向“新建”,然后单击“静态 One-Way 发送端口”。
在“ 发送端口属性 ”对话框中,将发送端口命名为 SendXMLPayload。 为“类型”选择“文件”,然后单击“配置”。
在“ 文件传输属性” 对话框中,对于“ 目标文件夹”,输入为 EDI 有效负载创建的本地文件夹。
对于 “文件名”,请输入文件名。 如果使用 XML 文件作为测试消息,请输入 %MessageID%.xml。 单击 “确定” 。
接受 Send Pipeline 的默认 PassThruTransmit。
在控制台树中单击“ 筛选器 ”,并添加用于选取 EDI 有效负载的筛选器属性。 在第一行中,对于 “属性”,输入 BTS。ReceivePortName;对于 “运算符”,请输入 ==;对于 “值”,请输入接收 AS2 消息 (
RecvAS2Msg
) 的接收端口的名称;对于 “分组依据”,则接受 “And”。 第二行,对于 “属性”,输入 EdiIntAS.IsAS2PayloadMessage;对于 “运算符”,请输入 ==;对于 “值”,请输入 “True”。单击 “确定” 。
单击“ 发送端口” 节点,右键单击发送端口,然后单击“ 启动”。
创建用于将 MDN 发送到本地文件夹的发送端口
在 Windows 资源管理器中,创建一个用于接收 MDN 的本地文件夹。
在BizTalk Server管理控制台中,右键单击“发送端口”,指向“新建”,然后单击“静态 One-Way 发送端口”。
在 “发送端口属性 ”对话框中,将发送端口命名为 SendMDNToContoso。 为“类型”选择“文件”,然后单击“配置”。
在“ 文件传输属性 ”对话框中,对于“ 目标文件夹”,输入你创建的要将 MDN 发送到的本地文件夹。
对于 “文件名”,请输入 %MessageID%.msg。单击“ 确定”。
接受 Send Pipeline 的默认 PassThruTransmit。
单击控制台树中的 “筛选器 ”。 对于 “属性”,请输入 BTS。SPName;对于 “运算符”,请输入 ==;对于 “值”,请输入发送 AS2 消息 (
SendToFab_RecvMDN
) 的发送端口的名称;对于 “分组依据”,则接受 “And”。 在“ 属性”的第二行中,输入 EdiIntAS.IsAS2MdnResponseMessage。 对于 “运算符”,请输入 ==。 对于 “值”,请输入 True。单击 “确定” 。
单击“ 发送端口” 节点,右键单击发送端口,然后单击“ 启动”。
为 Fabrikam 创建参与方和业务配置文件
右键单击BizTalk Server管理控制台中的“参与方”节点,指向“新建”,然后单击“群”。
在“名称”文本框中输入参与方 的名称 ,然后单击“ 确定”。
注意
通过选择“本地 BizTalk 处理由参与方或支持从此群检查发送消息”框,可以指定所创建的参与方适用于同时托管BizTalk Server的同一组织。 基于此,在创建协议时将启用或禁用某些属性。 但是,对于本演练,可以将此检查框保留为选中状态。
右键单击群名称,指向 “新建”,然后单击“ 业务配置文件”。
在“配置文件属性”对话框的“常规”页上,在“名称”文本框中输入Fabrikam_Profile。
注意
创建群时,还会创建配置文件。 可以重命名并使用该配置文件,而不是创建新的配置文件。 若要重命名配置文件,请右键单击该配置文件,然后选择“ 属性”。 在“ 常规 ”页中,指定配置文件的名称。
为 Contoso 创建参与方和业务配置文件
右键单击BizTalk Server管理控制台中的“参与方”节点,指向“新建”,然后单击“群”。
在“名称”文本框中输入参与方 的名称 ,然后单击“ 确定”。
注意
通过选择“本地 BizTalk 处理由参与方或支持从此群检查发送消息”框,可以指定所创建的参与方适用于同时托管BizTalk Server的同一组织。 基于此,在创建协议时将启用或禁用某些属性。 但是,对于本演练,可以将此检查框保留为选中状态。
右键单击群名称,指向 “新建”,然后单击“ 业务配置文件”。
在“配置文件属性”对话框中的“常规”页上,在“名称”文本框中输入Contoso_Profile。
注意
创建群时,还会创建配置文件。 可以重命名并使用该配置文件,而不是创建新的配置文件。 若要重命名配置文件,请右键单击该配置文件,然后选择“ 属性”。 在“ 常规 ”页中,指定配置文件的名称。
在两个业务配置文件之间创建 AS2 协议
右键单击 “Contoso_Profile”,指向“ 新建”,然后单击“ 协议”。
在 “常规属性” 页的“ 名称 ”文本框中,输入协议的名称。
从 “协议 ”下拉列表中,选择“ AS2”。
在“ 第二个合作伙伴 ”部分中,从“ 名称 ”下拉列表中选择“ Fabrikam”。
在“ 第二个合作伙伴 ”部分的 “配置文件 ”下拉列表中,选择“ Fabrikam_Profile”。
你会注意到,“ 常规 ”选项卡旁边添加了两个新选项卡。每个选项卡都用于配置单向 AS2 协议。
在“Contoso-Fabrikam>”选项卡上执行以下任务。
在 “标识符 ”页上,输入 AS2-From 和 AS2-To 的值。 对于 “AS2-From”,请输入
Contoso
。 对于 “AS2- To”,请输入Fabrikam
。在 “确认 (MDN) ”页中,执行以下操作:
选中“将入站 MDN 处理到 MessageBox 中的路由/传递选项”检查框。
注意
若要测试本演练,需要检查将 入站 MDN 处理到 MessageBox 中的路由/传递选项 ,因为只有这样,返回的 MDN 才会放入 MessageBox 中。 这样,便可创建一个用于订阅 MDN 并将 MDN 发送至本地目录的发送端口,从而可以验证 AS2 传输。
选择“请求 MDN 检查”框。
确保清除“请求签名的 MDN 检查”框。
清除 “请求异步 MDN ”。
在 Disposition-Notification-To 中,输入任何值。 在 AS2 处理期间,不会使用该字段的值,但该字段中必须输入值。
在“ 发送端口 ”页上,关联将 EDI 交换发送到 Fabrikam 的双向发送端口。 在 “发送端口” 网格的“ 名称” 列下,单击一个空单元格,然后从下拉列表中选择 发送端口SendToFab_RecvMDN。
在 Fabrikam-Contoso> 选项卡上执行以下任务。
注意
在本演练中,我们在选项卡中指定所需的值,以便可以成功创建协议。 若要成功创建协议,这两个单向协议选项卡都必须具有为 AS2_From 和 AS2-To 定义的值。
- 在 “标识符 ”页上,输入 AS2-From 和 AS2-To 的值。 对于 “AS2-From”,请输入
Fabrikam
。 对于 “AS2- To”,请输入Contoso
。
- 在 “标识符 ”页上,输入 AS2-From 和 AS2-To 的值。 对于 “AS2-From”,请输入
单击“应用”。
单击 “确定” 。 新添加的协议列在“参与方和业务配置文件”窗格的“协议”部分。 默认情况下,启用新添加的协议。
测试演练
本部分提供有关如何测试演练的信息。
测试解决方案
在 Windows 资源管理器中,将 XML 测试文件粘贴至您创建的用于接收来自 Contoso 的测试消息的本地文件夹。
转到您创建的用于接收 XML 负载的本地文件夹。 确认该文件夹中含有一个 XML 文件。 打开该文件和原始测试消息,验证它们的内容是否相同。
转到您创建的用于接收生成的 MDN 的本地文件夹。 确认文件夹中含有一个文件;打开该文件并确认它是一个 MDN 文件。