question

Upvotes
Accepted
488 14 13 26

Extracting XML programmatically to communicate with TRKD API

Aside from using the Fiddler tool, can you show me a way of extracting XML request/response from the client's application?

rkd-apirkdxml
icon clock
10 |1500

Up to 2 attachments (including images) can be used with a maximum of 512.0 KiB each and 1.0 MiB total.

1 Answer

Upvotes
Accepted
791 10 8 14

Yes, you can do this programmatically.

Developers can print XML request/response of TRKD services in their applications just by adding a few code lines. Below you can find information on how to catch SOAP messages in .NET, Java and PHP. .NET

This simple code sample showing how to serialize TRKD XML request/response and output it wherever you want (console, xml file).

// Create request

// userName, password, appID should be initialized above

var request = new CreateServiceToken_Request_1

{

Username = userName,

Password = password,

ApplicationID = appID

}; // Serialize request

var serializer = new XmlSerializer(request.GetType()); // using

//var serializer = new XmlSerializer(typeof(CreateServiceToken_Request_1)); // System.Xml.Serialization;

// Print to console

var builder = new StringBuilder(); // using System.Text;

var writer = new StringWriter(builder); // using System.IO;

serializer.Serialize(writer, request);

writer.Close();

Console.WriteLine(builder.ToString());

// Print to XML

var xmlDocument = new XmlDocument(); // using System.Xml;

var writer = new StringWriter(); // using System.IO;

serializer.Serialize(writer, request);

xmlDocument.LoadXml(writer.ToString());

writer.Close();

XmlTextWriter xwriter = new XmlTextWriter("request.xml", null); // using System.Xml;

xwriter.Formatting = Formatting.Indented;

xmlDocument.Save(xwriter);

Java (GlassFish Metro)

The following code sample shows MessageDumpingFeature class usage. Metro has this feature to provide the access to the SOAP messages. Using MessageDumpingFeature it is possible to get the content of SOAP messages at run-time and process them with your own code any way you like.

import com.sun.xml.ws.assembler.MessageDumpingFeature;

...

// Instantiate the web service client

TokenManagement1 tokenService = new TokenManagement1();

// get port

ITokenManagement1 tokenPort = tokenService.getHttpsAndAnonymousITokenManagement1HttpsAndAnonymous( new AddressingFeature(true));

// create request

// serviceUserApplicationID, serviceUserPassword, serviceUserName should be initialized above

CreateServiceTokenRequest1 serviceTokenRequest = new CreateServiceTokenRequest1();

serviceTokenRequest.setApplicationID(serviceUserApplicationID); serviceTokenRequest.setPassword(serviceUserPassword);

serviceTokenRequest.setUsername(serviceUserName);

// Prepare to plug in the code that allows to read SOAP messages

MessageDumpingFeature auth = new MessageDumpingFeature();

WSBindingProvider wsbp = (WSBindingProvider) tokenPort;

// call Token Management service

CreateTokenResponse tokenResponse = tokenPort.createServiceToken1(serviceTokenRequest);

// print the request to console

System.out.println(mdf.nextMessage());

// print the response to console

System.out.println(mdf.nextMessage());

PHP

This code sample demonstrates SoapClient class usage.

The class contains 2 methods, which allow to extract SOAP XML request/response(__getLastRequest and __getLastResponse).

In order to enable your SoapClient to catch request and responses you need to set trace option to true in the options list that you pass to the constructor.

// create request

// make sure the credentials are initialized here

$createTokenRequest = array(

'ApplicationID' => '',

'Username' => '',

'Password' => '');

// create SoapClient object specifying a WSDL required

$client = new SoapClient("http://api.rkd.reuters.com/schemas/wsdl/TokenManagement/TokenManagement_1_HttpsAndAnonymous.wsdl",

array('soap_version' => SOAP_1_2,

'trace' => true)); // <-- here enable trace to log SOAP messages

// create request headrs array

$wsAddressingHeaders = array(new SoapHeader(

'http://www.w3.org/2005/08/addressing',

'To',

'https://api.rkd.reuters.com/api/2006/05/01/TokenManagement_1.svc/Anonymous'), new SoapHeader(

'http://www.w3.org/2005/08/addressing', 'Action', 'http://www.reuters.com/ns/2006/05/01/webservices/rkd/TokenManagement_1/CreateServiceToken_1'));

// call service and get response

$createTokenResponse = $client->__soapCall('CreateServiceToken_1',

array('parameters' => $createTokenRequest),

null, $wsAddressingHeaders);

// print request

// the htmlentities() function converts characters to HTML entities

echo htmlentities($client->__getLastRequest());

// print response

// the htmlentities() function converts characters to HTML entities

echo htmlentities($client->__getLastResponse());

icon clock
10 |1500

Up to 2 attachments (including images) can be used with a maximum of 512.0 KiB each and 1.0 MiB total.