How To Use Xi 3.0 Soap Adapter

Download as pdf or txt
Download as pdf or txt
You are on page 1of 21
At a glance
Powered by AI
The guide provides information on how to use the SAP NetWeaver XI 3.0 SOAP adapter.

The guide is about how to use the SOAP adapter in SAP NetWeaver '04 to integrate web services.

You can configure parameters on the module tab page to influence HTTP headers and add custom modules to the processing sequence.

How-to Guide SAP NetWeaver 04

How To Use the XI 3.0 SOAP Adapter


Version 1.00 March 2006 Applicable Releases: SAP NetWeaver 04 SAP Exchange Infrastructure 3.0

Copyright 2006 SAP AG. All rights reserved. No part of this publication may be reproduced or transmitted in any form or for any purpose without the express permission of SAP AG. The information contained herein may be changed without prior notice. Some software products marketed by SAP AG and its distributors contain proprietary software components of other software vendors. Microsoft, Windows, Outlook, and PowerPoint are registered trademarks of Microsoft Corporation. IBM, DB2, DB2 Universal Database, OS/2, Parallel Sysplex, MVS/ESA, AIX, S/390, AS/400, OS/390, OS/400, iSeries, pSeries, xSeries, zSeries, z/OS, AFP, Intelligent Miner, WebSphere, Netfinity, Tivoli, and Informix are trademarks or registered trademarks of IBM Corporation in the United States and/or other countries. Oracle is a registered trademark of Oracle Corporation. UNIX, X/Open, OSF/1, and Motif are registered trademarks of the Open Group. Citrix, ICA, Program Neighborhood, MetaFrame, WinFrame, VideoFrame, and MultiWin are trademarks or registered trademarks of Citrix Systems, Inc. HTML, XML, XHTML and W3C are trademarks or registered trademarks of W3C , World Wide Web Consortium, Massachusetts Institute of Technology. Java is a registered trademark of Sun Microsystems, Inc. JavaScript is a registered trademark of Sun Microsystems, Inc., used under license for technology invented and implemented by Netscape. MaxDB is a trademark of MySQL AB, Sweden. SAP, R/3, mySAP, mySAP.com, xApps, xApp, and other SAP products and services mentioned herein as well as their respective logos are trademarks or registered trademarks of SAP AG in Germany and in several other countries all over the world. All other product and service names mentioned are the trademarks of their respective companies. Data

contained in this document serves informational purposes only. National product specifications may vary. These materials are subject to change without notice. These materials are provided by SAP AG and its affiliated companies ("SAP Group") for informational purposes only, without representation or warranty of any kind, and SAP Group shall not be liable for errors or omissions with respect to the materials. The only warranties for SAP Group products and services are those that are set forth in the express warranty statements accompanying such products and services, if any. Nothing herein should be construed as constituting an additional warranty. These materials are provided as is without a warranty of any kind, either express or implied, including but not limited to, the implied warranties of merchantability, fitness for a particular purpose, or non-infringement. SAP shall not be liable for damages of any kind including without limitation direct, special, indirect, or consequential damages that may result from the use of these materials. SAP does not warrant the accuracy or completeness of the information, text, graphics, links or other items contained within these materials. SAP has no control over the information that you may access through the use of hot links contained in these materials and does not endorse your use of third party web pages nor provide any warranty whatsoever relating to third party web pages. SAP NetWeaver How-to Guides are intended to simplify the product implementation. While specific product features and procedures typically are explained in a practical business context, it is not implied that those features and procedures are the only approach in solving a specific business problem using SAP NetWeaver. Should you wish to receive additional information, clarification or support, please refer to SAP Consulting. Any software coding and/or code lines / strings (Code) included in this documentation are only examples and are not intended to be used in a productive system environment. The Code is only intended better explain and visualize the syntax and phrasing rules of certain coding. SAP does not warrant the correctness and completeness of the Code given herein, and SAP shall not be liable for errors or damages caused by the usage of the Code, except if such damages were caused by SAP intentionally or grossly negligent.

Table of Contents
1 2 3 Scenario........................................................................................................................2 Introduction..................................................................................................................2 The Step By Step Solution...........................................................................................3
3.1 The Receiver SOAP Adapter ............................................................................ 3

3.1.1 3.1.2 3.1.3


3.2

Uploading the WSDL ..................................................................................3 Creating a Message Interface Without WSDL ............................................6 Creating a SOAP Receiver Channel ............................................................7

The Sender SOAP Adapter ............................................................................. 10

3.2.1 Creating a SOAP Sender Channel .............................................................10 3.2.2 Creating a WSDL from an Interface Definition ........................................12 3.2.3 Testing the Scenario Using a SOAP Client ...............................................13 Advanced Features.....................................................................................................15
4.1 4.2 4.3 4.4 4.5 4.6 SOAP Header Fields ....................................................................................... 15 SOAP with Attachments .................................................................................. 15 Web Service Security ...................................................................................... 15 Providing XI Message Header Fields Inside the SOAP Message ................... 15 Parameter Settings on the Module Tab Page ................................................. 17 Adding Customer Modules in the SOAP Adapter............................................ 17 Public Web Services ....................................................................................... 18 Useful Notes .................................................................................................... 18

Additional Information ..............................................................................................18


5.1 5.2

-1-

1 Scenario
You want to set up the SOAP adapter for sending messages to a Web service or providing a Web service for receiving messages.

2 Introduction
Web services are a standard format for exchanging data. The standard is based on XML and consists of a SOAP envelope with a header and a body. The structure of the message and the information about the connection parameters are stored in a special XML file. The structure of this file is described with the Web service definition language (WSDL). This file is usually generated by the Web service provider (receiver of the message) and can be uploaded by the Web service consumer (sender of the message). The XI system allows you to create a WSDL file from an interface description and upload a WSDL file. The message exchange is performed by the SOAP adapter, which can transform a SOAP message to an XI message and back. When working with the SOAP adapter you do not need to worry about the SOAP envelope, as the SOAP adapter adds this envelope for outbound messages and removes it for inbound messages. The SOAP body is identical to the payload of the XI message. Therefore, the payload of the XI message must be a valid XML.

-2-

3 The Step By Step Solution


First, we will look at the basic settings of the SOAP adapter and see how to work with a WSDL file for exchanging the message structure. After that we will look at special topics of the SOAP adapter. The examples in this guide are from different scenarios and are not intended to be a step by step solution. Therefore, we will not describe configuration steps or mapping steps here.

3.1

The Receiver SOAP Adapter

The receiver SOAP adapter connects XI with an external Web service. To call the Web service, you need to define a message interface that represents the structure of the request and response of the Web service. You can create this message interface easily with the help of a WSDL file that represents the Web service. If this is not possible, you must create the message interface based on data types that you define yourself.
3.1.1 Uploading the WSDL

Since the WSDL describes the message interface, you upload the WSDL into the Integration Repository. Go to your Software Component Version and open the required Namespace. Create an External Definition:

In the external definition object, choose Category wsdl and click Import external definitions:

-3-

After importing the WSDL file, you can view the included messages on the Messages tab page:

The namespaces of the messages are part of the WSDL description and can differ from the namespace of the external definition object. Now you can create a message interface corresponding to the message types from the external definition. You need the message interface for routing the message to the Web service.

-4-

In the message interface object, select the message types of the external definition object by using the input help:

-5-

After assigning the output and input message, save and activate your work. Now you can use the message interface for routing and mapping.
3.1.2 Creating a Message Interface Without WSDL

For some scenarios it is not possible to provide a WSDL file. In this case you need to create a message interface according to the message structure of the server. The best way to achieve this is by using an example SOAP message for the request and the response message.

Since the SOAP adapter creates the SOAP envelope you have to extract the SOAP body. Usually, Web services ignore declarative attributes (xsi:type), therefore you can delete them. The namespace declaration of the root tag must be applied. The XI message payload should be the following message:

-6-

Create a data type, message type, and message interface according to this structure. In the message type, apply the correct name and namespace of the message:

3.1.3

Creating a SOAP Receiver Channel

To call the Web service, you create a communication channel with type SOAP and direction receiver in the Integration Directory. The obligatory parameters in the configuration are Target URL and SOAP action. You get the values you have to enter here from the WSDL file. You find the target URL at the tag soap:address and the SOAP action at the tag soap:operation:

-7-

If more than one message type is described in the WSDL, several SOAP actions might also be defined. Check for the correct operation name. If no SOAP action is defined in the WSDL, you can leave the parameter in the receiver channel empty. For the receiver SOAP adapter you need at least the following parameters:

-8-

If your Web service requires logon data, select the Configure User Authentication checkbox and fill in the corresponding fields:

If the Web service is outside your system landscape and you need to address a proxy server, select the Configure Proxy checkbox and fill in the corresponding fields:

-9-

The other parameters are described below.

3.2

The Sender SOAP Adapter

Let us assume that we have already created a message interface that we will use for the SOAP communication. We will start with the definition of the communication channel and then generate a WSDL file. The WSDL file can be used for testing with a test tool but also to generate Web service clients.
3.2.1 Creating a SOAP Sender Channel

When you create a SOAP sender channel you have to define the namespace and the name of a message interface. Since no input help is provided, you copy and paste the values from your Integration Repository. Select the Quality of Service according to your interface type. If you are using a synchronous interface, select Best Effort. Otherwise, select Exactly Once or Exactly Once in Order.

If you select Best Effort, the Web service client will receive a response message in the SOAP body. Otherwise, the Web service client will not receive a response message if no error occurs. For the sender SOAP adapter you need at least the following parameters:

- 10 -

The other parameters are described below. After activating the SOAP adapter channel, you can send SOAP messages to the following address: http://<host>:<j2ee-port>/XISOAPAdapter/MessageServlet? channel=<party>:<service>:<channel> If the SOAP adapter channel belongs to a service without party, the address is as follows:

- 11 -

http://<host>:<j2ee-port>/XISOAPAdapter/MessageServlet? channel=:<service>:<channel>

3.2.2

Creating a WSDL from an Interface Definition

You can create a WSDL with the help of a wizard. In the Integration Directory, choose Tools -> Define Web Service to enter the wizard. Skip the first page by choosing Continue. On the second page, enter the URL mentioned above. Do not use the Propose URL button, as this URL would not point to the SOAP adapter sender channel.

Go to the next page by choosing Continue. Select the message interface you want to use for the WSDL. Make sure that you choose an outbound interface.

Go to the next page by choosing Continue. On this page you need to enter dummy values for the obligatory parameters. They are not needed when the SOAP adapter handles the request of the Web service client.

- 12 -

Choose Finish. On the next page you can see the WSDL that has been created. Choose Save and specify a folder and a file name to store it on your local PC. The file extension must be wsdl.

You can adjust the target URL to the structure mentioned above by using an editor.

The sender SOAP adapter does not require a SOAP action, but you always have to apply logon data when using the SOAP adapter. In the central adapter engine you can use a service user such as xiappluser; in a non-central adapter engine or a PCK you must use one of the user names assigned to security role xi_adapter_soap_message for component XISOAPAdapter.
3.2.3 Testing the Scenario Using a SOAP Client

Before you can test your scenario, you need to make all necessary configuration steps for the receiver and interface determination and activate the scenario. If you use Altova XML Spy you can upload the WSDL file you have created from the Integration Directory. Since XML Spy takes the proxy settings from the Internet browser that is installed on your PC, make sure that the proxy server is bypassed for internal calls if your Integration Engine is installed in the same network as your PC. In the XML Spy menu, choose SOAP -> Create new SOAP request. In the dialog window, select your wsdl file. In the next dialog window, choose the SOAP operation (there should only be one). XML Spy now creates a proposal for the SOAP request, which you can edit. You can enter valid parameters instead of the term String.

- 13 -

In the menu, choose SOAP -> Send request to server. For your first call, you have to enter your user and password to log on to the Adapter Framework. Enter the logon data for a service user such as xiappluser. If the request is successful you will receive a SOAP response, which is empty in an asynchronous scenario:

If the request is not successful, you will receive an error message:

Depending on the error code, you may get a more detailed description in the SOAP response.

- 14 -

If the error code is 0, check the URL and the proxy settings in your Internet browser. To check whether you can reach the SOAP adapter, type in the URL in your browser window.

4 Advanced Features
4.1 SOAP Header Fields
The SOAP adapter creates the SOAP envelope. You cannot influence this procedure. If you need to apply special tags inside the SOAP header, the only option is to create the whole SOAP envelope during mapping, and in the case of a synchronous call, to remove the SOAP envelope in the mapping. In the SOAP adapter channel, select Do Not Use SOAP Envelope. By using this parameter, you can use the SOAP adapter to send or receive nonSOAP messages. In this case the sender SOAP adapter requires an additional parameter nosoap=true in the URL. For example: http://<host>:<j2ee-port>/XISOAPAdapter/MessageServlet? channel=<party>:<service>:<channel>&nosoap=true

4.2

SOAP with Attachments

If you select Keep Headers in the SOAP adapter, the SOAP adapter transforms a SOAP message with attachments to an XI message with attachments and the other way around. Attachments can only be handled by Java and ABAP proxies, the SOAP adapter, the Mail adapter and the sender File adapter. If you need an attachment in another scenario such as IDoc to SOAP, then you have to create the attachment in your own adapter module that you apply on the Module tab page of the channel definition. For more information, see the How-To Guide How to Create Modules for the J2EE Adapter Engine .

4.3

Web Service Security

As of SP15 the sender SOAP adapter can check whether a SOAP adapter call is made using HTTP (default), HTTPS, or HTTPS with client authentication. The receiver SOAP adapter provides HTTP and HTTPS and, as of SP13, it provides HTTPS with client authentication. You must exchange the required certificates for the HTTPS connection with the help of the Key Storage service in the J2EE Visual Administrator.

4.4

Providing XI Message Header Fields Inside the SOAP Message

The SOAP adapter enables you to exchange fields of the XI message header such as sender system or message ID. There are different options for providing these header fields: If you want to use functionality, you have to select Keep Headers in the adapter configuration of the Integration Directory. To provide the header fields, you have the following options: 1. If you select Keep Headers, the XI message header fields are stored in the SOAP header. 2. If you select Use Encoded Headers, the receiver SOAP adapter adds the special parameter X-XMB_WS_ENCODED to the HTTP header and stores the XI

- 15 -

message header information here. The sender SOAP adapter checks for this parameter and creates the XI message header with the information provided here. 3. If you select Use Encoded Headers and Use Query String, the receiver SOAP adapter adds the XI message header information to the query string of the URL. The sender SOAP adapter creates the XI message header according to the information provided in the query string. If you use this parameter in the receiver channel, your target URL must end with a ? or a &. The following parameters are used: MessageClass Message class: ApplicationMessage ApplicationResponse SystemAck ApplicationAck SystemError ApplicationError Synchronous Asynchronous Message ID as GUID with format: xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx Reference to message ID, as GUID with format: xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx As string with maximum length of 60 Time stamp (displayed as ISO8601 UTC datetime YYYY-MM-DDThh:mm:ssZ) Name of the sender party (displayed as agency:scheme:name) Service of the sender Name of the receiver party (displayed as agency:scheme:name) Service of the receiver Specified as nsuri ^lcname BestEffort ExactlyOnce ExactlyOnceInOrder For ExactlyOnceInOrder

ProcessingMode MessageId RefToMessageId

ConversationId TimeSent Sender.Party Sender.Service Receiver.Party Receiver.Service Interface QualityOfService

QueueId

Here is an example of a string provided by the SOAP adapter in the HTTP message header or in the URL, when you apply the corresponding parameters: version=3.0&MessageClass=ApplicationMessage&ProcessingMode=synchr onous&MessageId=13490851-9aae-11d8-9e93f28d0a12631c&TimeSent=2004-0430T13%3A55%3A44Z&Sender.Party=016%3Apattern_33%3AAEG_837654&Sende r.Service=SRM1&Receiver.Party=12_55%3A017%3ABASF&Receiver.Service =SALES&Interface=http%3A%2F%2Fsap.com%2Fexample%2Fsrm%5ESRM1

- 16 -

In the sender SOAP adapter, you can use only some of the parameters, but the first parameter must always be the version. For example, you send from the Web service client to the following URL: http://<host>:<j2ee-port>/XISOAPAdapter/MessageServlet? channel=<party>:<service>:<channel>&version=3.0&Interface=http%3A %2F%2Fsap.com%2Ftest%5ETest This will overwrite the default interface and namespace of the sender channel.

4.5

Parameter Settings on the Module Tab Page

To influence HTTP headers you can use the following parameters in the module configuration according to the standard module of the SOAP adapter localejbs/sap.com/com.sap.aii.af.soapadapter/XISOAPAdapterBean:

Module Configuration Parameter XMBWS.XMLEncoding XMBWS.TransferEncoding XMBWS.Encoding XMBWS.AcceptEncoding

HTTP Header Entry Content-Type charset Content-Transfer-Encoding Content-Encoding Accept-Encoding

Example iso-8859-1 base64 gzip compress, gzip

The receiver SOAP adapter uses these parameters for the request message; the sender SOAP adapter uses these parameters for the response message.

4.6

Adding Customer Modules in the SOAP Adapter

The receiver SOAP adapter allows processing of the request and the response message of a synchronous call. You can add your own adapter modules in the Processing Sequence on the Module tab page of your SOAP adapter communication channel. Put

- 17 -

the module for processing the request before the standard module; put the module for processing the response after the standard module.

For more information about developing adapter modules, see the How-To Guide How to Create Modules for the J2EE Adapter Engine. If you want to use adapter modules for the sender SOAP adapter as well, you must be aware that the transformation of the SOAP message to an XI message takes place after the user adapter module is called, which means that you have to deal with the SOAP message and not the XI message. Therefore, you cannot use the standard modules such as PayloadSwapBean. As of SP 17 localejbs/ will no longer be added to the module name when you enter a new adapter.

5 Additional Information
5.1 Public Web Services
The Web service scenarios are taken from http://www.xmethods.net/ On this page you will find a number of public Web services, which you can use for testing.

5.2

Useful Notes

SAP Note 856597 FAQ: XI 3.0 SOAP Adapter

- 18 -

www.sdn.sap.com/irj/sdn/howtoguides

You might also like