#!/usr/bin/perl -- use strict; use warnings; use SOAP::Lite; my $soap = SOAP::Lite -> uri('http://127.0.0.1/MyModule') -> proxy('http://127.0.0.1:1203') ;;;;;;;;; $soap->transport->add_handler("request_send", \&pp_dump ); $soap->transport->add_handler("response_done", \&pp_dump ); ); $soap->autotype(0)->readable(1); $soap->serializer->envprefix('S'); $soap->ns( "http://www.bluearc.com/BAService/LocalGroupProvider" , 'ns0' ); my $evsId = SOAP::Data->new( 'name' => 'evsId', 'value' => 'evsId', 'prefix' => 'ns0', 'type' => 'unsignedShort' ); $soap->call( 'getAllLocalGroups', $evsId ); sub pp_twig { use XML::Twig; open my($fh), '>', \my $str; no warnings 'newline'; #~ XML::Twig->new(qw! pretty_print record !)->xparse(@_)->print( $fh ); XML::Twig->new(qw! pretty_print record !)->parse(@_)->print( $fh ); $str =~ s/ xmlns/\n xmlns/g; return $str; } sub pp_dump { my $content = $_[0]->content(''); $_[0]->content( pp_twig($content) ); print $_[0]->as_string,"\n"; return; } __END__ POST http://127.0.0.1:1203 HTTP/1.1 Accept: text/xml Accept: multipart/* Accept: application/soap User-Agent: SOAP::Lite/Perl/1.11 Content-Length: 573 Content-Type: text/xml; charset=utf-8 SOAPAction: "http://www.bluearc.com/BAService/LocalGroupProvider#getAllLocalGroups" evsId