2012-06-12 16 views
5

Tengo un servicio de descanso dentro de mi aplicación y me gustaría utilizar frijoles primavera. Spring que estoy usando es la versión 2.5. Parte de web.xml:Jersey REST servicio como Spring Component

<servlet> 
    <servlet-name>jersey-servlet</servlet-name> 
    <servlet-class>com.sun.jersey.spi.container.servlet.ServletContainer</servlet-class> 
    <init-param> 
     <param-name>com.sun.jersey.config.property.packages</param-name> 
     <param-value>com.app.rest</param-value> 
    </init-param> 
    <init-param> 
     <param-name>com.sun.jersey.api.json.POJOMappingFeature</param-name> 
     <param-value>true</param-value> 
    </init-param> 
    <load-on-startup>1</load-on-startup> 
</servlet> 

<servlet-mapping> 
    <servlet-name>jersey-servlet</servlet-name> 
    <url-pattern>/rest/*</url-pattern> 
</servlet-mapping> 

En pom.xml i tienen dependencias:

<dependency> 
    <groupId>com.sun.jersey</groupId> 
    <artifactId>jersey-server</artifactId> 
    <version>1.8</version> 
</dependency> 
<dependency> 
     <groupId>com.sun.jersey</groupId> 
     <artifactId>jersey-json</artifactId> 
     <version>1.8</version> 
</dependency> 

En context.xml he añadido:

<context:component-scan base-package="com.app.rest"/> 

y también:

<tx:annotation-driven proxy-target-class="true" /> 

Parte interesante de se clase rvice:

@Component 
@Path("/notification") 
@Scope("singleton") 
public class PushNotification { 

    @Autowired 
    //@Resource(name = "sendMessageServiceFacade") 
    private SendMessageServiceFacade sendMessageServiceFacade; 

    @Autowired 
    //@Resource(name = "responseCode") 
    private NotificationResponseMessage responseCode; 

    @Autowired 
    //@Resource(name = "validator") 
    private PushMessagePreValidator validator; 

    @POST 
    @Path("/register") 
    @Consumes(MediaType.APPLICATION_JSON) 
    public Response registerDevice(PushWooshRegisterDeviceDto dto) { 
     if (validator.validate(dto) == 200) { 
      return invokePushMessage(dto, PushMessageType.REGISTER.getMsgType()); 
     } else { 
      return buildFailResponse(); 
     } 
    } 

    @GET 
    @Path("/{param}") 
    public Response ping(@PathParam("param") String param) { 
     return Response.status(200).entity(param).build(); 
    } 

método GET funciona como se esperaba (básicamente funciona :)), pero el método POST lanza NullPointerException en línea: if (validator.validate (dto) == 200).

No sé por qué @Autowired annotation doesnt trabajo aquí, ale intenté con @Resource - mismo efecto.

Cualquier sugerencia puede ayudar.

Gracias de antemano, Marek.

Respuesta

3

Si desea utilizar Jersey con muelle, debe utilizar el módulo de integración Spring, es decir, depender de jersey-spring y utilizar SpringServlet en lugar de la clase servlet Jersey ServletContainer. Consulte aquí para obtener más información: http://jersey.java.net/nonav/apidocs/latest/contribs/jersey-spring/com/sun/jersey/spi/spring/container/servlet/package-summary.html

+0

Tenía la esperanza de que puedo hacerlo sin el jersey de la primavera, así enferma añadir exludes en primavera en esta dependencia y es de esperar que duraran Yo trabajo :) – Marek

0

Si implementa la interfaz org.springframework.validation.Validator, debería ver la validación del método espera dos parámetros, es decir del tipo de objeto y de tipo errores, por lo que es necesario agregar otra clase a su validar llamada

BeanPropertyBindingResult v = new BeanPropertyBindingResult(dto,"Errors"); 
validator.validate(dto, v); 
Cuestiones relacionadas