To deploy the JAX-RS application in Java SE, you can use the RuntimeDelegate and the HTTP server supported by your JAX -RS. A servlet container is not required.
JSR 339 states the following:
In Java SE, a configured instance of an endpoint class can be obtained using the createEndpoint RuntimeDelegate method. An application provides an instance of Application and the type of endpoint required. An implementation MAY support null or more finite types of any desired type.
How the resulting endpoint class instance is used to publish the application is beyond the scope of this specification.
Jersey, the JAX-RS reference implementation, supports a range of HTTP servers that can be used to deploy JAX-RS applications in Java SE.
For example, Grizzly and RuntimeDelegate , you can get the following:
public class Example { public static void main(String[] args) { ResourceConfig resourceConfig = new ResourceConfig(); resourceConfig.register(GreetingsResource.class); HttpHandler handler = RuntimeDelegate.getInstance() .createEndpoint(resourceConfig, HttpHandler.class); HttpServer server = HttpServer.createSimpleServer(null, 8080); server.getServerConfiguration().addHttpHandler(handler); try { server.start(); System.out.println("Press any key to stop the server..."); System.in.read(); } catch (Exception e) { System.err.println(e); } } @Path("/greetings") public static class GreetingsResource { @GET @Produces(MediaType.TEXT_PLAIN) public String getGreeting(){ return "Hello from the other side."; } } }
The application will be available at http://localhost:8080/greetings .
For the example shown above, the following dependencies are required:
<dependency> <groupId>org.glassfish.grizzly</groupId> <artifactId>grizzly-http-server</artifactId> <version>2.3.30</version> </dependency> <dependency> <groupId>org.glassfish.jersey.containers</groupId> <artifactId>jersey-container-grizzly2-http</artifactId> <version>2.25.1</version> </dependency>
Other supported implementations include:
The Jersey documentation also describes other deployment options for a Java SE environment without RuntimeDelegate .