Thanks for the reply. I've added the map, however i still get the same error
WARNING: javax.ws.rs.InternalServerErrorException:
java.lang.IllegalStateException: Invalid JSON namespace: urn:uddi-org
:api_v3
at
org.apache.cxf.jaxrs.provider.json.JSONProvider.writeTo(JSONProvider.java:377)
at
org.apache.cxf.jaxrs.utils.JAXRSUtils.writeMessageBody(JAXRSUtils.java:1326)
at
org.apache.cxf.jaxrs.interceptor.JAXRSOutInterceptor.serializeMessage(JAXRSOutInterceptor.java:282)
at
org.apache.cxf.jaxrs.interceptor.JAXRSOutInterceptor.processResponse(JAXRSOutInterceptor.java:154)
at
org.apache.cxf.jaxrs.interceptor.JAXRSOutInterceptor.handleMessage(JAXRSOutInterceptor.java:85)
at
org.apache.cxf.phase.PhaseInterceptorChain.doIntercept(PhaseInterceptorChain.java:271)
at
org.apache.cxf.interceptor.OutgoingChainInterceptor.handleMessage(OutgoingChainInterceptor.java:77)
at
org.apache.cxf.phase.PhaseInterceptorChain.doIntercept(PhaseInterceptorChain.java:271)
at
org.apache.cxf.transport.ChainInitiationObserver.onMessage(ChainInitiationObserver.java:121)
at
org.apache.cxf.transport.http.AbstractHTTPDestination.invoke(AbstractHTTPDestination.java:239)
at
org.apache.cxf.transport.servlet.ServletController.invokeDestination(ServletController.java:223)
at
org.apache.cxf.transport.servlet.ServletController.invoke(ServletController.java:203)
at
org.apache.cxf.transport.servlet.ServletController.invoke(ServletController.java:137)
at
org.apache.cxf.transport.servlet.CXFNonSpringServlet.invoke(CXFNonSpringServlet.java:158)
at
org.apache.cxf.transport.servlet.AbstractHTTPServlet.handleRequest(AbstractHTTPServlet.java:243)
at
org.apache.cxf.transport.servlet.AbstractHTTPServlet.doGet(AbstractHTTPServlet.java:168)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:617)
at
org.apache.cxf.transport.servlet.AbstractHTTPServlet.service(AbstractHTTPServlet.java:219)
at
org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290)
at
org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
at
org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:233)
at
org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:191)
at
org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:465)
at
org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:127)
at
org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102)
at
org.apache.catalina.authenticator.SingleSignOn.invoke(SingleSignOn.java:394)
at
org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
at
org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:298)
at
org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:852)
at
org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:588)
at
org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:489)
at java.lang.Thread.run(Thread.java:744)
Caused by: java.lang.IllegalStateException: Invalid JSON namespace:
urn:uddi-org:api_v3
at
org.codehaus.jettison.mapped.MappedNamespaceConvention.getJSONNamespace(MappedNamespaceConvention.java:252)
at
org.codehaus.jettison.mapped.MappedNamespaceConvention.createKey(MappedNamespaceConvention.java:260)
at
org.codehaus.jettison.mapped.MappedXMLStreamWriter.writeStartElement(MappedXMLStreamWriter.java:220)
at
com.sun.xml.bind.v2.runtime.output.XMLStreamWriterOutput.beginStartTag(XMLStreamWriterOutput.java:118)
at
com.sun.xml.bind.v2.runtime.output.XmlOutputAbstractImpl.beginStartTag(XmlOutputAbstractImpl.java:102)
at
com.sun.xml.bind.v2.runtime.output.NamespaceContextImpl$Element.startElement(NamespaceContextImpl.java:496)
at
com.sun.xml.bind.v2.runtime.XMLSerializer.endNamespaceDecls(XMLSerializer.java:288)
at
com.sun.xml.bind.v2.runtime.XMLSerializer.childAsSoleContent(XMLSerializer.java:590)
at
com.sun.xml.bind.v2.runtime.ClassBeanInfoImpl.serializeRoot(ClassBeanInfoImpl.java:342)
at
com.sun.xml.bind.v2.runtime.XMLSerializer.childAsRoot(XMLSerializer.java:494)
at
com.sun.xml.bind.v2.runtime.MarshallerImpl.write(MarshallerImpl.java:323)
at
com.sun.xml.bind.v2.runtime.MarshallerImpl.marshal(MarshallerImpl.java:178)
at
org.apache.cxf.jaxrs.provider.json.JSONProvider.marshal(JSONProvider.java:479)
at
org.apache.cxf.jaxrs.provider.json.JSONProvider.marshal(JSONProvider.java:542)
at
org.apache.cxf.jaxrs.provider.json.JSONProvider.writeTo(JSONProvider.java:369)
... 31 more
and the relevant parts of beans.xml
<util:map id="jsonNamespaceMap" map-class="java.util.Hashtable" >
<entry key="urn:uddi-org:api_v3" value="uddiv3"/>
</util:map>
<jaxrs:server id="inquiryRestService" address="/inquiryRest">
<jaxrs:serviceBeans>
<ref bean="inquiryRest" />
</jaxrs:serviceBeans>
</jaxrs:server>
<bean id="inquiryRest"
class="org.apache.juddi.api.impl.rest.UDDIInquiryJAXRS" />
<bean id="jaxbProvider" class="org.apache.cxf.jaxrs.provider.json.JSONProvider">
<property name="ignoreNamespaces" value="true"/>
<property name="namespaceMap" ref="jsonNamespaceMap"/>
</bean>
using this pom dependencies
<dependency>
<groupId>org.apache.cxf</groupId>
<artifactId>cxf-rt-rs-extension-providers</artifactId>
<version>2.7.5</version>
</dependency>
<dependency>
<groupId>org.codehaus.jettison</groupId>
<artifactId>jettison</artifactId>
<version>1.3.3</version>
</dependency>
I'll try 1.3.4
On Sat, Dec 7, 2013 at 7:19 AM, Jose María Zaragoza
<[email protected]> wrote:
> I had the same problem than you and ignoreNamespaces=true didn't work
> for me ( I'm using Apache CXF 2.7.3 and Jettison 1.3.4 )
> I don't know why.
> If you try it and it works for you, please notify to me.
>
>
> To solved that, I had to map my namespace to empty string ( "") **
> only for JSON messages**, not for XML messages:
>
>
> <util:map id="jsonNamespaceMap" map-class="java.util.Hashtable">
> <entry key="http://domain.com/ws/type" value=""/>
> </util:map>
>
>
> <bean id="jsonProvider"
> class="org.apache.cxf.jaxrs.provider.json.JSONProvider">
> <property name="namespaceMap" ref="jsonNamespaceMap"/>
> </bean>
>
>
> Regards
>
>
>
>
> 2013/12/7 Alex O'Ree <[email protected]>:
>> Hi I have a JAXB annotated (wsimport) jaxws service that i'm writing
>> an adapter for using jaxrs and jettison with 2.7.5.
>>
>> When service the rest endpoint with XML using the jaxws objects, it
>> works just fine. However when serving JSON encoding data in response,
>> I get this.
>>
>> Caused by: java.lang.IllegalStateException: Invalid JSON namespace:
>> urn:uddi-org:api_v3
>> at
>> org.codehaus.jettison.mapped.MappedNamespaceConvention.getJSONNamespace(MappedNamespaceConvention.java:252)
>> at
>> org.codehaus.jettison.mapped.MappedNamespaceConvention.createKey(MappedNamespaceConvention.java:260)
>> at
>> org.codehaus.jettison.mapped.MappedXMLStreamWriter.writeStartElement(MappedXMLStreamWriter.java:220)
>> at
>> com.sun.xml.bind.v2.runtime.output.XMLStreamWriterOutput.beginStartTag(XMLStreamWriterOutput.java:118)
>>
>> Beans.xml config file
>>
>> <jaxrs:server id="inquiryRestService" address="/inquiryRest">
>> <jaxrs:serviceBeans>
>> <ref bean="inquiryRest" />
>> </jaxrs:serviceBeans>
>> </jaxrs:server>
>> <bean id="inquiryRest"
>> class="org.apache.juddi.api.impl.rest.UDDIInquiryJAXRS" >
>> </bean>
>> <bean id="jaxbProvider"
>> class="org.apache.cxf.jaxrs.provider.json.JSONProvider">
>> <property name="ignoreNamespaces" value="true"/>
>> </bean>
>>
>>
>> this part works
>> @GET
>> @Path("/XML/businessDetail/{id}")
>> @Produces("application/xml")
>> @org.apache.cxf.jaxrs.model.wadl.Description("Returns the details
>> of a business entity in XML")
>> public org.uddi.api_v3.BusinessEntity
>> getBusinessDetailXML(@PathParam("id") String id) throws
>> WebApplicationException {
>> return getBusinessDetail(id);
>> }
>>
>>
>> this part does not
>> @GET
>> @Path("/JSON/businessDetail/{id}")
>> @Produces("application/json")
>> @org.apache.cxf.jaxrs.model.wadl.Description("Returns the details
>> of a business entity in JSON")
>> public org.uddi.api_v3.BusinessEntity
>> getBusinessDetailJSON(@PathParam("id") String id) throws
>> WebApplicationException {
>> return getBusinessDetail(id);
>> }
>>
>> The complete code is over here:
>> http://svn.apache.org/repos/asf/juddi/trunk/juddi-rest-cxf/
>>
>> From googling, I've seen that adding the ignoreNamespaces=true should
>> fix this, but I'm not sure if I have it in the write place. The docs
>> don't have a clear example of this