如何:使用 Request-Response 消息交换模式转换消息,并将其路由至服务终结点

目标

本部分演示如何使用 ESB Designer 域特定语言 (DSL) 创建可用于双向接口的请求响应行程。 你将创建一个路由名单来接收消息、转换消息、将消息提交到服务,并将服务响应消息返回到原始消息的提交者。

在本指南中,你将完成以下步骤:

  • 使用转换路线服务创建路线路线名单,该服务实现Microsoft BizTalk Server 地图。

  • 配置路线以将转换的消息路由到服务终结点。

  • 配置路线以将服务响应消息返回到原始发送方。

  • 使用“行程测试客户端”示例应用程序测试行程。

先决条件

本作指南主题中的过程需要完成 开发活动的先决条件

步骤

创建 ESB 行程 DSL 模型

  1. 在 Visual Studio 中,打开 C:\HowTos\Patterns\Patterns.sln。

  2. 在解决方案资源管理器中,右键单击 “行程库 ”项目,指向 “添加”,然后单击“ 新建路线”。

  3. 在“ 添加新项 ”对话框中的“ 名称 ”框中键入 RequestResponse,然后单击“ 添加”。

配置行程的属性

  1. 在 Visual Studio 中,单击 RequestResponse.itinerary的设计界面。 在 RequestResponse 属性窗口中,配置以下属性:

    1. “是否请求响应”下拉列表中,单击“True”

    2. “模型导出程序 ”下拉列表中,单击“ XML 行程导出程序”。

    3. “扩展程序设置” 部分中,单击 “行程 XML 文件 ”属性旁边的省略号按钮(...)。

    4. “选择 XML 文件 ”对话框中的 “文件名 ”框中,键入 C:\HowTos\Itineraries\RequestResponse,然后单击“ 保存”。

      注释

      此步骤使你可以将行程导出为 XML 到本地文件位置。 通过将行程导出到本地文件位置而不是行程数据库,可以使用 ESB 测试客户端应用程序测试行程。 稍后将完成本作说明主题中的此过程。

定义行程的结构

  1. 从工具箱中,将 On-Ramp 模型元素拖到设计图面。 在 OnRamp1 “属性”窗口中,配置以下属性:

    1. 单击 Name 属性,然后键入 ReceiveNAOrder

    2. “扩展程序 ”下拉列表中,单击“ On-Ramp ESB 扩展程序”。

    3. BizTalk 应用程序 下拉列表中,单击 Microsoft.Practices.ESB

    4. “接收端口 ”下拉列表中,单击 “OnRamp.Itinerary.Response”。

  2. 从工具箱中,将 “路线服务” 模型元素拖到设计图面,然后将其置于 On-Ramp 模型元素的右侧。 在 “ItineraryService1 属性”窗口中,配置以下属性:

    1. 单击 Name 属性,然后键入 MapNAOrderToCNOrder

    2. “行程服务扩展程序 ”下拉列表中,单击“ 消息传递扩展程序”。

      注释

      此属性定义进程将在管道(消息传送)中发生。 或者,如果进程将在业务流程中进行,请将 行程服务扩展程序 属性设置为 业务流程扩展程序

    3. “容器”下拉列表中,展开ReceiveNAOrder,然后单击“接收处理程序”

    4. “服务名称 ”下拉列表中,单击 Microsoft.Practices.ESB.Services.Transform

  3. 右键单击 MapNAOrderToCNOrder 模型元素的 Resolver 集合,然后单击“添加新的解析器”。 在 Resolver1 “属性”窗口中,配置以下属性:

    1. 单击 Name 属性,然后键入 StaticallySpecifyTheMap

    2. “解析程序实现 ”下拉列表中,单击 “静态解析程序扩展”。

    3. “转换类型”下拉列表中,单击 GlobalBank.ESB.DynamicResolution.Transforms.SubmitOrderRequestNA_To_SubmitOrderRequestCN

  4. 在工具箱中,单击“ 连接器”。 将连接从 ReceiveNAOrder 模型元素拖到 MapNAOrderToCNOrder 模型元素。

  5. 从工具箱中,将 “路线服务” 模型元素拖到设计图面,然后将其置于 MapNAOrderToCNOrder 模型元素的右侧。 在 “ItineraryService1 属性”窗口中,配置以下属性:

    1. 单击 Name 属性,然后键入 RouteToCNService

    2. “行程服务扩展程序 ”下拉列表中,单击“ 消息传递扩展程序”。

      注释

      此属性定义进程将在管道(消息传送)中发生。 或者,如果进程将在业务流程中进行,请将 行程服务扩展程序 属性设置为 业务流程扩展程序

    3. “容器”下拉列表中,展开ReceiveNAOrder,然后单击“接收处理程序”

    4. “服务名称 ”下拉列表中,单击 Microsoft.Practices.ESB.Services.Routing

  6. 右键单击 RouteToCNService 模型元素的 Resolver 集合,然后单击“添加新冲突解决程序”。 在 Resolver1 “属性”窗口中,配置以下属性:

    1. 单击 Name 属性,然后键入 StaticallySpecifyTheService

    2. “解析程序实现 ”下拉列表中,单击 “静态解析程序扩展”。

    3. “传输名称 ”下拉列表中,单击 WCF-BasicHttp

    4. 单击 “传输位置” 属性,然后键入 http://localhost/ESB.CanadianServices/SubmitPOService.asmx

    5. 单击 “目标命名空间 ”属性,然后键入 http://globalbank.esb.dynamicresolution.com/canadianservices

    6. 单击 Action 属性,然后键入 submitOrder

  7. 在工具箱中,单击“ 连接器”。 将 MapNAOrderToCNOrder 模型元素中的连接拖动到 RouteToCNService 模型元素。

  8. 从工具箱中,将 Off-Ramp 模型元素拖到设计图面,然后将其置于 RouteToCNService 模型元素的右侧。 在 OffRamp1 “属性”窗口中,配置以下属性:

    1. 单击 Name 属性,然后键入 InvokeCNService

    2. “扩展程序 ”下拉列表中,单击 Off-Ramp ESB 扩展程序

    3. BizTalk 应用程序 下拉列表中,单击 GlobalBank.ESB

    4. Send Port 下拉列表中,单击 DynamicResolutionSolicitResp

  9. 从工具箱中,将 “路线服务 ”模型元素拖到设计图面,然后将其放在 RouteToCNService 模型元素和 InvokeCNService 模型元素之间。 在 “ItineraryService1 属性”窗口中,配置以下属性:

    1. 单击 Name 属性,然后键入 SendPortFilter

    2. “行程服务扩展程序 ”下拉列表中,单击 Off-Ramp 扩展程序

    3. Off-Ramp 下拉列表中,展开 InvokeCNService,然后单击 发送处理程序

  10. 在工具箱中,单击“ 连接器”。 将 RouteToCNService 模型元素的连接拖到 SendPortFilter 模型元素。

  11. 在工具箱中,单击“ 连接器”。 将连接从 SendPortFilter 模型元素拖动到 InvokeCNService 模型元素。

  12. 右键单击设计图面,然后单击“ 验证”。

    注释

    行程验证,无需将出口匝道重新连接到入口匝道,即可将响应消息发回请求方。 通过使用双向通道,最终信息会自动返回给请求方。

导出模型以用于路线测试客户端

  1. 在 Visual Studio 中,右键单击 RequestResponse 路线的设计图面,然后单击“ 导出模型”。

    注释

    将在 Visual Studio 中打开行程的 XML 版本。

  2. 保存所有项目工件。

  3. 在 Windows 资源管理器中,浏览到 C:\HowTos\行程。 请注意创建行程 XML(RequestResponse.xml)。

测试行程

  1. 使用在 开发活动的先决条件 (C:\HowTos\ESB.Itinerary.Test.exe - 快捷方式)中创建的快捷方式打开行程测试客户端示例应用程序。

  2. 在“路线测试客户端”中,清除“ 使用 WCF 服务 ”复选框。

  3. “Web 服务选项 ”部分中,选中“ 双向服务 ”复选框,然后单击“ 加载路线”。

  4. “打开路线文件 ”对话框中,浏览到 C:\HowTos\行程。 选择 RequestResponse.xml,然后单击“ 打开 ”加载行程。

  5. 单击“ 确定 ”以清除“ 成功加载路线 ”消息。

  6. 在“行程测试客户端”中,单击 “加载消息 ”框旁边的省略号按钮(...)。

  7. “选择要加载的 XML 文档 ”对话框中,浏览到 C:\HowTos。 选择 NAOrderDoc.xml,然后单击“ 打开 ”以加载测试消息。

  8. 单击“ 提交请求 ”按钮。 测试完成后,单击“ 确定 ”以消除出现的确认。

  9. “结果 ”框中,请注意消息的根节点为 submitOrderResponse ,默认命名空间为 ... 加拿大服务

    注释

    如果在将响应发送到请求方之前响应需要其他转换,则必须使用包含 ESB 转发器组件的管道。 有关此功能的示例,请参阅 “安装和运行多个 Web 服务示例”。

其他资源

有关详细信息,请参阅下列相关主题: