2012-09-13 9 views
5

Si verificano problemi con l'iniezione di WebServiceContext tramite l'annotazione @Resource. Sto usando la combinazione JAXWS + Spring. Questo è un pezzo di codice che uso.Problema di iniezione di WebServiceContext tramite annotazione @Resource

@WebService 
public class AdminWSImpl { 

    @Resource 
    private WebServiceContext context; 

... 
} 

Parte del mio web.xml:

... 
<listener> 
    <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class> 
</listener> 


<listener> 
    <listener-class>com.sun.xml.ws.transport.http.servlet.WSServletContextListener</listener-class> 
</listener> 


<servlet> 
    <description>JAX-WS endpoint of Admin Service</description> 
    <display-name>JAX-WS Admin servlet</display-name> 
    <servlet-name>AdminService</servlet-name> 
    <servlet-class>com.sun.xml.ws.transport.http.servlet.WSServlet</servlet-class> 
    <load-on-startup>1</load-on-startup> 
</servlet> 


<servlet> 
    <servlet-name>context</servlet-name> 
    <servlet-class>org.springframework.web.context.ContextLoaderServlet</servlet-class>  
    <load-on-startup>2</load-on-startup> 
</servlet> 

<context-param> 
    <param-name>contextConfigLocation</param-name> 
    <param-value>/WEB-INF/applicationContext.xml</param-value> 
</context-param> 

Il problema è il contesto è sempre nullo! In base a How to use @Resource WebServiceContext injection with Spring's @Transactional springs-transactional ho definito il setter per il contesto e ho inserito l'annotazione @Resource sul setter.

Il risultato di mettere @Resource annotazioni sul setter è questo stack trace:

SEVERE: WSSERVLET11: failed to parse runtime descriptor: javax.xml.ws.WebServiceException: Unable to create JAXBContext 
javax.xml.ws.WebServiceException: Unable to create JAXBContext 
    at com.sun.xml.ws.model.AbstractSEIModelImpl.createJAXBContext(AbstractSEIModelImpl.java:171) 
    at com.sun.xml.ws.model.AbstractSEIModelImpl.postProcess(AbstractSEIModelImpl.java:99) 
    at com.sun.xml.ws.model.RuntimeModeler.buildRuntimeModel(RuntimeModeler.java:250) 
    at com.sun.xml.ws.server.EndpointFactory.createSEIModel(EndpointFactory.java:343) 
    at com.sun.xml.ws.server.EndpointFactory.createEndpoint(EndpointFactory.java:205) 
    at com.sun.xml.ws.api.server.WSEndpoint.create(WSEndpoint.java:513) 
    at com.sun.xml.ws.transport.http.DeploymentDescriptorParser.parseAdapters(DeploymentDescriptorParser.java:257) 
    at com.sun.xml.ws.transport.http.DeploymentDescriptorParser.parse(DeploymentDescriptorParser.java:151) 
    at com.sun.xml.ws.transport.http.servlet.WSServletContextListener.parseAdaptersAndCreateDelegate(WSServletContextListener.java:131) 
    at com.sun.xml.ws.transport.http.servlet.WSServletContextListener.contextInitialized(WSServletContextListener.java:152) 
    at org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java:4206) 
    at org.apache.catalina.core.StandardContext.start(StandardContext.java:4705) 
    at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:799) 
    at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:779) 
    at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:601) 
    at org.apache.catalina.startup.HostConfig.deployWAR(HostConfig.java:943) 
    at org.apache.catalina.startup.HostConfig.deployApps(HostConfig.java:563) 
    at org.apache.catalina.startup.HostConfig.check(HostConfig.java:1399) 
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39) 
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25) 
    at java.lang.reflect.Method.invoke(Method.java:597) 
    at org.apache.tomcat.util.modeler.BaseModelMBean.invoke(BaseModelMBean.java:297) 
    at com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.invoke(DefaultMBeanServerInterceptor.java:836) 
    at com.sun.jmx.mbeanserver.JmxMBeanServer.invoke(JmxMBeanServer.java:761) 
    at org.apache.catalina.manager.ManagerServlet.check(ManagerServlet.java:1500) 
    at org.apache.catalina.manager.HTMLManagerServlet.doPost(HTMLManagerServlet.java:252) 
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:637) 
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:717) 
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290) 
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206) 
    at org.apache.catalina.filters.CsrfPreventionFilter.doFilter(CsrfPreventionFilter.java:186) 
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235) 
    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:563) 
    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:127) 
    at com.googlecode.psiprobe.Tomcat60AgentValve.invoke(Tomcat60AgentValve.java:30) 
    at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102) 
    at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109) 
    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:293) 
    at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:859) 
    at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:602) 
    at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:489) 
    at java.lang.Thread.run(Thread.java:662) 
    Caused by: java.security.PrivilegedActionException: com.sun.xml.bind.v2.runtime.IllegalAnnotationsException: 1 counts of IllegalAnnotationExceptions 
    javax.xml.ws.WebServiceContext is an interface, and JAXB can't handle interfaces. 
    this problem is related to the following location: 

Qualcuno può fornire alcun aiuto?

Grazie in anticipo!

+0

Un 'JAXBContext' deve essere creato per i tipi di ritorno e i parametri per il servizio web. Poiché 'WebServiceContext' sembra che un' JAXBContext' viene creato su 'AdminWSImpl'. –

risposta

4

Ho trovato la soluzione che ora funziona! Inserisco l'annotazione WebService con l'attributo endpointInterface e aggiungo l'interfaccia di amministrazione implementa la classe generata da wsimport. Il mio web.xml rimane lo stesso descritto nella domanda!

@WebService(endpointInterface = "my.app.admin.Admin") 
    public class AdminWSImpl implements Admin{ 

    @Resource 
    private WebServiceContext wsContext; 

    public void setWsContext(WebServiceContext wsContext) { 
    this.wsContext = wsContext; 
} 
} 
+0

Non dovresti contrassegnare 'setWsContext' con l'annotazione' @WebMethod (exclude = true) '? Anch'io .. –

+0

Hai definito SEI (Service Endpoint Interfae)? Credo che nel mio caso il contratto per il servizio web sia SEI, quindi solo i metodi definiti nell'interfaccia di amministrazione sono esposti come metodi WS. Quindi penso che @WebMethod (exclude = true) non sia richiesto. –

Problemi correlati