The RESTEasy Spring Boot starters can be used by any regular Spring Boot application that wants to have REST endpoints and prefers RESTEasy as the JAX-RS implementation. They integrate with Spring as expected, which means every JAX-RS REST resource that is also a Spring bean will be automatically auto-scanned, integrated, and available. There are two flavors of starters available that provide integration with the following types of application servers:
- Servlet based (e.g. Tomcat)
- Reactor Netty
- Enables RESTEasy for Spring Boot applications
- Supports JAX-RS providers, resources and sub-resources as Spring beans
- Supports automatic discovery and registration of multiple JAX-RS Application classes as Spring beans
- Supports optional registration of JAX-RS Application classes via class-path scanning, or manually, via configuration properties (or YAML) file
- Leverages and supports RESTEasy configuration
- Supports RESTEasy Asynchronous Job Service
- Servlet based server integration
- Reactor Netty integration
This project has been kindly donated by PayPal. Please refer to https://github.com/paypal/resteasy-spring-boot for old versions.
Add the Maven dependency below to your Spring Boot application pom file.
Servlet
<dependency>
<groupId>org.jboss.resteasy</groupId>
<artifactId>resteasy-servlet-spring-boot-starter</artifactId>
<version>6.0.1-SNAPSHOT</version>
<scope>runtime</scope>
</dependency>
Reactor Netty
<dependency>
<groupId>org.jboss.resteasy</groupId>
<artifactId>resteasy-reactor-netty-spring-boot-starter</artifactId>
<version>6.0.1-SNAPSHOT</version>
<scope>runtime</scope>
</dependency>
Just define your JAX-RS application class (a subclass of Application) as a Spring bean, and it will be automatically registered. See the example below. See section JAX-RS application registration methods in How to use RESTEasy Spring Boot Starter for further information.
package com.sample.app;
import org.springframework.stereotype.Component;
import jakarta.ws.rs.ApplicationPath;
import jakarta.ws.rs.core.Application;
@Component
@ApplicationPath("/sample-app/")
public class JaxrsApplication extends Application {
}
Just define them as Spring beans, and they will be automatically registered. Notice that JAX-RS resources can be singleton or request scoped, while JAX-RS providers must be singletons.
See How to use RESTEasy Spring Boot Starter.
Servlet
- resteasy-servlet-spring-boot-starter: The RESTEasy Spring Boot Starter project for servlet based application servers.
- resteasy-servlet-spring-boot-sample-app: A simple Spring Boot application that exposes JAX-RS endpoints as Spring beans using RESTEasy via the RESTEasy Spring Boot servlet starter.
- resteasy-servlet-spring-boot-starter-test: Integration tests for the RESTEasy Spring Boot servlet starter.
Reactor Netty
- resteasy-reactor-netty-spring-boot-starter: The RESTEasy Spring Boot Starter project using Reactor Netty as application server.
- resteasy-reactor-netty-spring-boot-sample-app: A simple Spring Boot application that exposes JAX-RS endpoints as Spring beans using RESTEasy via the RESTEasy Spring Boot starter using Reactor Netty.
- resteasy-reactor-netty-spring-boot-starter-test: Integration tests for the RESTEasy Spring Boot Starter with Reactor Netty as application server.
Please open an issue using JIRA (be sure to set Spring / Spring Boot in the Component/s field).
To contact us, please use RESTEasy mailing lists.
This project is licensed under the Apache 2 License.