Vorgehensweise: Transformieren einer Nachricht und Routing der resultierenden Nachricht an einen Dateispeicherort mithilfe eines programmablaufbasierten Verteilers
Zielsetzung
In diesem Abschnitt wird veranschaulicht, wie Sie die ESB-Designer domänenspezifische Sprache (DSL) verwenden, um eine Reiseroute zu erstellen, die die Nachrichtentransformation durch Aufrufen einer BizTalk-Karte implementiert und dann die Nachrichten mithilfe des Dateiadapters microsoft BizTalk ESB Toolkit weitergibt.
In diesem Thema führen Sie die folgenden Schritte aus:
Erstellen Sie einen Routenplan mit einem Transformationsroutendienst, der eine BizTalk-Karte implementiert.
Konfigurieren Sie die Reiseroute, um die transformierte Nachricht an einen Dateispeicherort weiterzuleiten.
Testen Sie die Reiseroute mithilfe der Beispielanwendung routey Test Client.
Voraussetzungen
Die Prozeduren in diesem Thema erfordern den Abschluss der Voraussetzungen für die Entwicklungsaktivitäten.
Schritte
So erstellen Sie ein DSL-Modell für eine ESB-Reiseroute
Öffnen Sie in Visual Studio C:\HowTos\Patterns\Patterns.sln.
Klicken Sie in Projektmappen-Explorer mit der rechten Maustaste auf das Projekt ReiserouteLibrary, zeigen Sie auf Hinzufügen, und klicken Sie dann auf Neue Reiseroute.
Klicken Sie im Dialogfeld Neues Element hinzufügen im Bereich Vorlagen auf ReiserouteDsl .
Geben Sie im Feld Nameden Namen DataModelTransformation ein, und klicken Sie dann auf Hinzufügen.
So konfigurieren Sie die Eigenschaften der Reiseroute
Klicken Sie in Visual Studio auf die Entwurfsoberfläche von DataModelTransformation.itinerary. Konfigurieren Sie im dataModelTransformation-Eigenschaftenfenster die folgenden Eigenschaften:
Klicken Sie in der Dropdownliste Modellexporter auf XML-Reiseverlaufsexporter.
Klicken Sie im Abschnitt Extendereinstellungen neben der Xml-Dateieigenschaft Routey auf die Schaltfläche mit den Auslassungspunkten (...).
Geben Sie im Dialogfeld XML-Datei auswählen im Feld Dateinameden Namen C:\HowTos\Itineraries\DataModelTransformation ein, und klicken Sie dann auf Speichern.
Hinweis
Mit diesem Schritt können Sie die Reiseroute als XML an einen lokalen Dateispeicherort exportieren. Durch exportieren einer Reiseroute in einen lokalen Dateispeicherort und nicht in die Reiseplandatenbank, ermöglicht das Testen der Reiseroute mithilfe der ESB-Testclientanwendung. Sie schließen diesen Prozess weiter unten in diesem Thema ab.
So definieren Sie die Struktur der Reiseroute
Ziehen Sie aus der Toolbox ein On-Ramp-Modellelement auf die Entwurfsoberfläche. Konfigurieren Sie im OnRamp1-Eigenschaftenfenster die folgenden Eigenschaften:
Klicken Sie auf die Name-Eigenschaft , und geben Sie dann ReceiveNAOrder ein.
Klicken Sie in der Dropdownliste Extender auf On-Ramp ESB-Diensterweiterung.
Klicken Sie in der Dropdownliste BizTalk-Anwendung auf Microsoft.Practices.ESB.
Klicken Sie in der Dropdownliste Empfangsport auf OnRamp.Itinerary.
Ziehen Sie aus der Toolbox ein Itinerary Service-Modellelement auf die Entwurfsoberfläche, und platzieren Sie es dann rechts neben dem On-Ramp-Modellelement . Konfigurieren Sie im Eigenschaftenfenster ItineraryService1 die folgenden Eigenschaften:
Klicken Sie auf die Name-Eigenschaft , und geben Sie dann MapNAOrderToCNOrder ein.
Klicken Sie in der Dropdownliste Routey Service Extender auf Messaging Extender.
Hinweis
Diese Eigenschaft definiert, dass der Prozess in einer Pipeline (Messaging) stattfindet. Wenn der Prozess in einer Orchestrierung stattfindet, legen Sie alternativ die Eigenschaft Itinerary Service Extender auf Orchestration Extender fest.
Erweitern Sie in der Dropdownliste Container den Eintrag ReceiveNAOrder, und klicken Sie dann auf Empfangshandler.
Klicken Sie in der Dropdownliste Dienstname auf Microsoft.Practices.ESB.Services.Transform.
Klicken Sie mit der rechten Maustaste auf die Resolver-Auflistung des MapNAOrderToCNOrder-Modellelements , und klicken Sie dann auf Neuen Resolver hinzufügen. Konfigurieren Sie im Eigenschaftenfenster Resolver1 die folgenden Eigenschaften:
Klicken Sie auf die Name-Eigenschaft , und geben Sie dann StaticallySpecifyTheMap ein.
Klicken Sie in der Dropdownliste Resolverimplementierung auf Statische Resolvererweiterung.
Klicken Sie in der Dropdownliste Transformationstyp auf GlobalBank.ESB.DynamicResolution.Transforms.SubmitOrderRequestNA_To_SubmitOrderRequestCN.
Klicken Sie in der Dropdownliste Transportname auf DATEI.
Klicken Sie in der Toolbox auf Connector. Ziehen Sie eine Verbindung aus dem ReceiveNAOrder-Modellelement auf das MapNAOrderToCNOrder-Modellelement .
Ziehen Sie aus der Toolbox ein Off-Ramp-Modellelement auf die Entwurfsoberfläche, und platzieren Sie es dann rechts neben dem MapNAOrderToCNOrder-Modellelement . Konfigurieren Sie im offRamp1-Eigenschaftenfenster die folgenden Eigenschaften:
Klicken Sie auf die Name-Eigenschaft , und geben Sie sendCNOrder ein.
Klicken Sie in der Dropdownliste Extender auf Off-Ramp ESB Extender.
Klicken Sie in der Dropdownliste BizTalk-Anwendung auf GlobalBank.ESB.
Klicken Sie in der Dropdownliste Port senden auf DynamicResolutionOneWay.
Ziehen Sie aus der Toolbox ein Itinerary Service-Modellelement auf die Entwurfsoberfläche, und platzieren Sie es dann zwischen dem MapNAOrderToCNOrder-Modellelement und dem SendCNOrder-Modellelement . Konfigurieren Sie im Eigenschaftenfenster ItineraryService1 die folgenden Eigenschaften:
Klicken Sie auf die Name-Eigenschaft , und geben Sie sendPortFilter ein.
Klicken Sie in der Dropdownliste Reiseplanungsdienst-Extender auf Off-Ramp Extender.
Erweitern Sie in der Dropdownliste Off-Ramp den Eintrag SendCNOrder, und klicken Sie dann auf Sendehandler.
Klicken Sie mit der rechten Maustaste auf die Resolver-Auflistung des SendPortFilter-Modellelements , und klicken Sie dann auf Neuen Resolver hinzufügen. Konfigurieren Sie im Eigenschaftenfenster Resolver1 die folgenden Eigenschaften:
Klicken Sie auf die Name-Eigenschaft , und geben Sie dann ConfigureFolderSettings ein.
Klicken Sie in der Dropdownliste Transportname auf DATEI.
Klicken Sie auf die Eigenschaft Transportspeicherort , und geben Sie dann C:\HowTos\Out\%MessageID%.xmlein.
Hinweis
Jeder Off-Rampe ist ein Reiseplandienst zugeordnet. die Kombination aus den Eigenschaften des Reiseplandiensts und den Eigenschaften des off-ramp definieren das Abonnement des dynamischen Sendeports.
Klicken Sie in der Toolbox auf Connector. Ziehen Sie eine Verbindung aus dem MapNAOrderToCNOrder-Modellelement auf das SendPortFilter-Modellelement .
Klicken Sie in der Toolbox auf Connector. Ziehen Sie eine Verbindung vom SendPortFilter-Modellelement auf das SendCNOrder-Modellelement .
So exportieren Sie das Modell für die Verwendung mit dem Reiseplantestclient
Klicken Sie in Visual Studio mit der rechten Maustaste auf die Entwurfsoberfläche des DataModelTransformation-Reiseplans , und klicken Sie dann auf Modell exportieren.
Hinweis
Die XML-Version der Reiseroute wird in Visual Studio geöffnet.
Speichern Sie alle Projektartefakte.
Navigieren Sie in Windows Explorer zu C:\HowTos\Itineraries, und beachten Sie die Erstellung Ihrer Reiserouten-XML (DataModelTransformation.xml).
So testen Sie die Reiseroute
Öffnen Sie die Programmtestclient-Beispielanwendung mithilfe der Verknüpfung, die während der Voraussetzungen für die Entwicklungsaktivitäten (C:\HowTos\ESB.Itinerary.Test.exe – Verknüpfung) erstellt wurde.
Deaktivieren Sie im Programmplantestclient das Kontrollkästchen WCF-Dienst verwenden , und klicken Sie dann auf Route laden.
Navigieren Sie im Dialogfeld Reiseroutendatei öffnen zu C:\HowTos\Itineraries. Wählen Sie DataModelTransformation.xmlaus, und klicken Sie dann auf Öffnen , um die Reiseroute zu laden.
Klicken Sie auf OK , um die Meldung Route erfolgreich geladen zu löschen.
Klicken Sie im Reiseplantestclient auf die Schaltfläche mit den Auslassungspunkten (...) neben dem Feld Nachricht laden .
Navigieren Sie im Dialogfeld Zu ladende XML-Dokument auswählen zu C:\HowTos. Wählen Sie NAOrderDoc.xmlaus, und klicken Sie dann auf Öffnen , um die Testnachricht zu laden.
Klicken Sie auf die Schaltfläche Anforderung übermitteln . Klicken Sie nach Abschluss des Tests auf OK , um die angezeigte Bestätigung zu schließen.
Navigieren Sie in Windows Explorer zu C:\HowTos\Out. Vergewissern Sie sich, dass die Nachricht %MessageID%.xml in das Verzeichnis geschrieben wurde.
Weitere Ressourcen
Weitere Informationen finden Sie in den folgenden verwandten Themen: