Как вы используете FastInfoset с JAXWS? - PullRequest
4 голосов
/ 18 мая 2010

У меня есть код, который выглядит так, как будто он должен быть корректным, основываясь на том, что я могу найти, но извергнутый вывод не указывает, что он использует FastInfoset. Насколько я понимаю, Accept должен указывать на то, что он может принимать Fastinfoset, и ответ на самом деле использует его, то есть это не text / xml в качестве типа ответа. Есть идеи, что я делаю не так? Я пообщался с Google, и мне трудно найти много деталей о том, как вообще использовать FastInfoset.

    JaxWsProxyFactoryBean factory = new JaxWsProxyFactoryBean();
    factory.getInInterceptors().add(new LoggingInInterceptor());
    factory.getOutInterceptors().add(new LoggingOutInterceptor());
    factory.setServiceClass( C360Server.class);
    factory.setAddress("http://localhost:8501/cxfcontroller/cl_v5");
    C360Server client = (C360Server)factory.create();
    ((BindingProvider)client).getRequestContext().put(
        "com.sun.xml.ws.client.ContentNegotiation", "optimistic");

    C360Request requestTrans = new C360Request();
    ... code to fill in the request ...
    C360Response response = client.findContacts( requestTrans );

Регистрация не указывает на то, что FastInfoset даже предпринята попытка:

INFO: Outbound Message
---------------------------
ID: 1
Address: http://localhost:8501/cxfcontroller/cl_v5
Encoding: UTF-8
Content-Type: text/xml
Headers: {SOAPAction=[""], Authorization=[Basic cWFfc3VwZXI6cWFfc3VwZXI=], Accept=[*/*]}
Payload: <soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/"><soap:Body><ns1:findContacts>...bunch of xml deleted for brevity...</ns1:findContacts></soap:Body></soap:Envelope>
--------------------------------------
May 17, 2010 3:23:45 PM org.apache.cxf.interceptor.LoggingInInterceptor logging
INFO: Inbound Message
----------------------------
ID: 1
Response-Code: 200
Encoding: UTF-8
Content-Type: text/xml; charset=utf-8
Headers: {content-type=[text/xml; charset=utf-8], Content-Length=[611], Server=[Jetty(6.1.x)]}
Payload: <soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/"><soap:Body><ns1:findContactsResponse>...bunch of xml spew deleted for brevity...</ns1:findContactsResponse></soap:Body></soap:Envelope>
--------------------------------------

Есть идеи, что я делаю не так? Даже если сервер не поддерживает FastInfoset, я все равно должен увидеть попытку согласования в запросе, верно?

Ответы [ 2 ]

6 голосов
/ 04 июня 2010

Ответ в том, что информация о том, как ее включить, была устаревшей. Следующее работает на стороне клиента (и предположительно на стороне сервера, но там у меня включена конфигурация Spring, которая его обрабатывает).

           JaxWsProxyFactoryBean factory = new JaxWsProxyFactoryBean();
           // This enables FastInfoset as the communication protocol
           factory.getInInterceptors().add( new FIStaxInInterceptor() );
           factory.getOutInterceptors().add( new FIStaxOutInterceptor() );
           ... other code to set username, location, etc. goes here.
           client = (C360Server) factory.create();
0 голосов
/ 05 октября 2011
//Enabling FastInfoset by configuring proxy 
// Enabling FI in pessimistic mode
Map<String, Object> ctxt = ((BindingProvider)proxy).getRequestContext();
ctxt.put(JAXWSProperties.CONTENT_NEGOTIATION_PROPERTY, "pessimistic");

ИЛИ

Включение FastInfoset с использованием системного свойства

-Dcom.sun.xml.ws.client.ContentNegotiation=pessimistic
...