Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

JAX-RS: Multiple paths

Tags:

java

jax-rs

Is it possible to do something like that?

import javax.ws.rs.GET;
import javax.ws.rs.Path;

public class xxx
{
  @GET
  @Path(value = "path1")
  public Response m1()
  {
    ...
  }

  @GET
  @Path(value = "path2")
  public Response m1()
  {
    ...
  }
}

I'm using RESTEasy btw.

like image 235
terry207 Avatar asked Jan 24 '11 15:01

terry207


3 Answers

@Path("/{a:path1|path2}")

From resteasy docs: http://docs.jboss.org/resteasy/docs/1.0.2.GA/userguide/html_single/index.html#_Path_and_regular_expression_mappings

like image 71
Dieter Cailliau Avatar answered Oct 23 '22 04:10

Dieter Cailliau


yes you can do that although you will have to rename your methods so that their signature is different.

Update: Check Dieter Cailliau's answer, @Path("/{a:path1|path2}") is probably what you want...

public class BlahResource{
    @GET
    @Path("path1")
    public Response m1(){
        return Response.ok("blah").build();
    }

    @GET
    @Path("path2")
    public Response m2(){
        return this.m1();
}

you can check JSR-311's API and it's reference implementation named "jersey" there:

JSR311 API

Jersey

like image 45
fasseg Avatar answered Oct 23 '22 03:10

fasseg


Some extra details about Path annotation...

As a previous responses state, regular expressions to be used with in the annotated path declaration mapping:

{" variable-name [ ":" regular-expression ] "} 

You can declare multiple paths, but there is also a path hierarchy that was not immediately obvious to me whereby the class annotated path prefixes the following method path annotations. One might write the following class for a concise multiple path option which could be useful for resource versioning perhaps.

@Path("/{a:v1|v2}")
@Produces("text/*")
public class BlahResource {

    @GET
    @Path("/blah")
    public Response m1() {
        return Response.ok("blah").build();
    }
}

Please note the fact that the class "BlahResource" has been declared with the path "/v1" or "/v2" making the resource accessible as:

$ curl localhost:8080/v1/blah
blah

and also

$ curl localhost:8080/v2/blah
blah
like image 12
Opentuned Avatar answered Oct 23 '22 03:10

Opentuned