TcpMon监听SOAP消息

public class BookClient
{
    public static void main(String args[])
    {
        String serviceURL = "http://localhost:9527/testxfire/services/BookService";
        Service serviceModel = new ObjectServiceFactory().create(BookService.class,null,"http://xfire.codehaus.org/BookService",null);
        
        XFireProxyFactory serviceFactory = new XFireProxyFactory();
        try
        {
            BookService service = (BookService) serviceFactory.create(serviceModel, serviceURL);
            Client client = Client.getInstance(service);
            client.addOutHandler(new OutHeaderHandler());
            // disable timeout
            client.setProperty(CommonsHttpMessageSender.HTTP_TIMEOUT, "0");
            
            Book[] books = service.getBooks();
            Map booksMap = service.getBooksMap();
            System.out.print("Received map with "+booksMap.size()+" book(s) \n");
            System.out.println("BOOKS:");
            
            for (int i = 0; i < books.length; i++)
            {
                System.out.println(books[i].getTitle());
            }
        }
        catch (MalformedURLException e)
        {
            e.printStackTrace();
        }  
    }
}

    以上代码是XFire1.2.6中的一个example.

 

    如果想查看发送和接收到的SOAP消息,可以使用TcpMon来监听

 

    step 1. 下载TcpMon,解压,运行 tcpmon-1.0-bin\build\tcpmon.bat  (需要配置JAVA_HOME)

    step 2.  在TcpMon的Admin界面进行监听设置。

                2.1 Listen Port :9527 。 设置TcpMon监听的端口 。

                2.2 Target Host : localhost 。设置目标主机

                      Target Port : 8080。 设置目标主机上的端口。

    step 3. 使用上面的代码调用,就会实现 localhost:9527 - > localhost:8080

                类似于Fiddler的功能。 

    

    请求报文:

POST /testxfire/services/BookService HTTP/1.1
SOAPAction: ""
Content-Type: text/xml; charset=UTF-8
User-Agent: Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.0; XFire Client +http://xfire.codehaus.org)
Host: 127.0.0.1:9527
Expect: 100-continue
Content-Length: 362

<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"><soap:Header><version xmlns="http://xfire.codehaus.org/Book">1.0</version></soap:Header><soap:Body><ns1:getBooks xmlns:ns1="http://xfire.codehaus.org/BookService" /></soap:Body></soap:Envelope>POST /testxfire/services/BookService HTTP/1.1
SOAPAction: ""
Content-Type: text/xml; charset=UTF-8
User-Agent: Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.0; XFire Client +http://xfire.codehaus.org)
Host: localhost:9527
Expect: 100-continue
Content-Length: 365

<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"><soap:Header><version xmlns="http://xfire.codehaus.org/Book">1.0</version></soap:Header><soap:Body><ns1:getBooksMap xmlns:ns1="http://xfire.codehaus.org/BookService" /></soap:Body></soap:Envelope>

 

    响应报文:

   

HTTP/1.1 100 Continue

HTTP/1.1 200 OK
Server: Apache-Coyote/1.1
X-Powered-By: Servlet 2.4; JBoss-4.2.3.GA (build: SVNTag=JBoss_4_2_3_GA date=200807181417)/JBossWeb-2.0
Content-Type: text/xml;charset=UTF-8
Transfer-Encoding: chunked
Date: Thu, 02 Apr 2015 09:48:25 GMT

246
<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"><soap:Body><ns1:getBooksResponse xmlns:ns1="http://xfire.codehaus.org/BookService"><ns1:out><ns2:Book xmlns:ns2="http://demo.xfire.codehaus.org"><author xmlns="http://demo.xfire.codehaus.org">Dan Diephouse</author><isbn xmlns="http://demo.xfire.codehaus.org">0123456789</isbn><title xmlns="http://demo.xfire.codehaus.org">Using XFire</title></ns2:Book></ns1:out></ns1:getBooksResponse></soap:Body></soap:Envelope>
0

HTTP/1.1 100 Continue

HTTP/1.1 200 OK
Server: Apache-Coyote/1.1
X-Powered-By: Servlet 2.4; JBoss-4.2.3.GA (build: SVNTag=JBoss_4_2_3_GA date=200807181417)/JBossWeb-2.0
Content-Type: text/xml;charset=UTF-8
Transfer-Encoding: chunked
Date: Thu, 02 Apr 2015 09:48:25 GMT

275
<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"><soap:Body><ns1:getBooksMapResponse xmlns:ns1="http://xfire.codehaus.org/BookService"><ns1:BookMap><entry xmlns="http://xfire.codehaus.org/BookService"><key>0123456789</key><value><author xmlns="http://demo.xfire.codehaus.org">Dan Diephouse</author><isbn xmlns="http://demo.xfire.codehaus.org">0123456789</isbn><title xmlns="http://demo.xfire.codehaus.org">Using XFire</title></value></entry></ns1:BookMap></ns1:getBooksMapResponse></soap:Body></soap:Envelope>
0

 

   

 

 

你可能感兴趣的:(TcpMon监听SOAP消息)