THIS IS A TEST INSTANCE. ALL YOUR CHANGES WILL BE LOST!!!!
Wiki Markup |
---|
{span:style=font-size:2em;font-weight:bold} JAX-RS : Deployment {span} {toc} This page provides the tips on how to deploy CXF JAX-RS applications packaged as WAR archives or OSGI bundles into Java EE application servers and OSGI containers. h1. Servlet Containers h2. Tomcat 1. System "org.apache.tomcat.util.buf.UDecoder.ALLOW_ENCODED_SLASH" and "org.apache.catalina.connector.CoyoteAdapter.ALLOW_BACKSLASH" properties may have to be set to "true" to support URIs containing encoded forward or backward slashes. 2. When using mod_jk - ensure that the JkOptions setting has +ForwardURICompatUnparsed set. 3. Windows: upgrade isapi_redirect.dll if you see URI containing encoded spaces being decoded by Tomcat. h1. Application Servers h2. Glassfish *Verified with Glassfish Server Open Source Edition 3.1.1* 1. Make sure a cxf-rt-transport-http-jetty dependency is excluded during the war build 2. If a custom JAX-RS [Application|http://jsr311.java.net/nonav/releases/1.1/index.html] is included then use a [CXFNonSpringJaxrsServlet|http://cxf.apache.org/docs/jaxrs-services-configuration.html#JAXRSServicesConfiguration-ConfiguringJAXRSservicesincontainerwithoutSpring] to reference the Application implementation class and either 2.1 Disable the Jersey scanning the custom web applications. Setting the following system property may help: "-Dcom.sun.enterprise.overrideablejavaxpackages=javax.ws.rs,javax.ws.rs.core,javax.ws.rs.ext" 2.2 Remove jersey-gf-server.jar from $GLASSFISH_HOME/glassfish/modules h2. JBoss *Verified with JBoss AS 7.1.0.CR1b* 1. If a custom JAX-RS [Application|http://jsr311.java.net/nonav/releases/1.1/index.html] is included then use a [CXFNonSpringJaxrsServlet|http://cxf.apache.org/docs/jaxrs-services-configuration.html#JAXRSServicesConfiguration-ConfiguringJAXRSservicesincontainerwithoutSpring] to reference the Application implementation class and either 2.1 Disable the RestEasy scanning the custom web applications (TODO: specify how this actually can be done) 2.2 Modify $JBOSS_HOME/standalone/configuration/standalone.xml by commenting out a "org.jboss.as.jaxrs" extension and a "urn:jboss:domain:jaxrs:1.0" sybsystem. 2. JBoss does not support URI path slashes by default: http://securitytracker.com/id/1018110 h2. WebLogic *Verified with WebLogic Server 12c (12.1.1)* h3. Specifying a WebLogic specific JSP servlet If you configure CXFServlet to redirect to custom JSP pages then you need to add the following declaration to web.xml: {code:xml} <servlet> <servlet-name>jsp</servlet-name> <servlet-class>weblogic.servlet.JSPServlet</servlet-class> </servlet> {code} h3. CXF RuntimeDelegate Add a "prefer-application-packages" block in weblogic.xml, including the package "javax.ws.rs.*", for CXF RuntimeDelegate be visible after the application has been redeployed h3. Selecting Woodstox as the default parser WebLogic requires the following update to the proprietary deployment descriptor weblogic.xml: {code:xml} <container-descriptor> <!-- SNIP --> <prefer-web-inf-classes>true</prefer-web-inf-classes> </container-descriptor> {code} This instructs WebLogic's classloaders to look FIRST in the JARS from the application's WEB-INF/lib directory for Service Provider Implementations (in this case, to find META-INF/services/javax.xml.stream.XMLInputFactory in the Woodstox JAR) rather than to the system classloader. Please see this [thread|https://forums.oracle.com/forums/message.jspa?messageID=9953045] for more information. h2. Geronimo h3. CXF RuntimeDelegate It has been reported CXF RuntimeDelegate may not be visible after the application has been redeployed in Geronimo. Most likely Geronimo needs to be configured similar to the way WebLogic has to to resolve the same issue (please see the relevant section above), TODO: update the section once we know the actual details. |