There are three RESTEasy GitHub projects that provide components for RESTEasy's Spring Framework support.
                resteasy-spring:
                This project has been created to separate RESTEasy's Spring
                integration extensions from RESTEasy's core code.  It contains RESTEasy's
                modules resteasy-spring-web, resteasy-spring, resteasy-undertow-spring
                and related tests.  These modules were moved out of the RESTEasy project
                as of version 5.0.0.  In maven the GAV groupId is now
                org.jboss.resteasy.spring.  The artifactIds remain the same.
                
<dependency>
    <groupId>org.jboss.resteasy.spring</groupId>
    <artifactId>resteasy-spring</artifactId>
    <version>${version.org.jboss.resteasy.spring}</version>
</dependency>
            
resteasy-spring-boot: provides two Spring Boot starters.
<dependency>
    <groupId>org.jboss.resteasy</groupId>
    <artifactId>resteasy-spring-boot-starter</artifactId>
    <version>${latest_version_of_restesy_spring_boot}</version>
</dependency>
                
RESTEasy currently supports Spring version 6.0
            RESTEasy provides integrated support for Spring Framework.
            It supplies a default org.springframework.web.context.ContextLoaderListener
            and org.springframework.beans.factory.config.BeanPostProcessor
            implementation that is used to run Spring applications.  Alternatively
            RESTEasy provides support for registering a custom
            org.springframework.beans.factory.config.BeanFactoryPostProcessor
            thus enabling the user to create their own bean factories.
        
            Spring MVC Framework support is provided in RESTEasy.
            A default implementation of Spring's org.springframework.web.servlet.DispatcherServlet
            is supplied.
        
            RESTEasy furnishes an Undertow based embedded Spring
            container in which Spring applications can run.  It supplies
            class org.jboss.resteasy.plugins.server.undertow.spring.UndertowJaxrsSpringServer
            which accepts a Spring context configuration file and preforms the appropriate wiring
            of Spring to RESTEasy.
        
Two types of Spring Boot starters are provided by resteasy-spring-boot. These can be used by any regular Spring Boot application that wants to have REST endpoints and prefers RESTEasy as the JAX-RS implementation. The starters integrate with Spring, thus Spring beans will be automatically auto-scanned, integrated, and available. Two types of starters are available, one Servlet based for Tomcat and one for Reactor Netty.
RESTEasy supports Spring's singleton and prototype scopes and Spring Web REST annotations.
The following subsections discuss ways of configuring these features for use in RESTEasy. Code examples can be found in project resteasy-examples
            Basic integration makes use of RESTEasy's default implementations of interface
            jakarta.servlet.ServletContextListener, and classes
            org.springframework.web.context.ContextLoaderListener
            org.springframework.beans.factory.config.BeanPostProcessor
            org.jboss.resteasy.plugins.server.servlet.ResteasyBootstrap,
            org.jboss.resteasy.plugins.spring.SpringContextLoaderListener and
            org.jboss.resteasy.plugins.spring.ResteasyBeanPostProcessor.
        
To use this feature the user must add the maven resteasy-spring dependency to their project.
<dependency>
    <groupId>org.jboss.resteasy.spring</groupId>
    <artifactId>resteasy-spring</artifactId>
    <version>${version.org.jboss.resteasy.spring}</version>
</dependency>
        
            RESTEasy's SpringContextLoaderListener registers its
            ResteasyBeanPostProcessor.  It processes Jakarta RESTful
            Web Services annotations when a bean is created by a BeanFactory.
            It automatically scans for @Provider and Jakarta RESTful
            Web Services resource annotations on bean classes and registers them as
            Jakarta RESTful Web Services resources.
        
            A user's application must be configured via a web.xml and optionally a
            bean.xml file to use these classes.  The configuration files discussed
            below can be found in example,
            Basic Example
        
            Optionally Spring Framework can be configured to scan for the Jakarta RESTful
            Web Services resources and beans with a Spring configuration file.
            Here is an example bean.xml that declares component scanning.  In the example code
            this file is named, resteasy-spring-basic.xml.
        
<beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xmlns:p="http://www.springframework.org/schema/p"
    xmlns:context="http://www.springframework.org/schema/context"
    xsi:schemaLocation="http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd
    http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd">
    <context:component-scan base-package="org.jboss.resteasy.examples.springbasic">
        <context:include-filter type="annotation" expression="jakarta.ws.rs.Path"/>
    </context:component-scan>
    <context:annotation-config/>
</beans>
        
            Two or three elements will need to be added to the application's web.xml.
            Two listener classes must be declared.  The RESTEasy servlet must be identified.
            If the user provided an optional bean.xml file, that needs to be referenced also.
        
Here is the content that should add into the web.xml file:
        
...
    <listener>
(1)     <listener-class>org.jboss.resteasy.plugins.server.servlet.ResteasyBootstrap</listener-class>
    </listener>
    <listener>
(1)     <listener-class>org.jboss.resteasy.plugins.spring.SpringContextLoaderListener</listener-class>
    </listener>
    <servlet>
        <servlet-name>resteasy-dispatcher</servlet-name>
(2)     <servlet-class>org.jboss.resteasy.plugins.server.servlet.HttpServletDispatcher</servlet-class>
    </servlet>
    <context-param>
        <param-name>contextConfigLocation</param-name>
(3)     <param-value>classpath:resteasy-spring-basic.xml</param-value>
    </context-param>
        ResteasyBootstrap and SpringContextLoaderListener.
                The declaration order is critical.  ResteasyBootstrap must be declared first because
                SpringContextLoaderListener relies on ServletContext
                attributes initialized by it.
            An alternative for using HttpServletDispatcher for deployment, a
            FilterDispatcher can be declared instead:
        
<filter>
    <filter-name>resteasy-filter</filter-name>
    <filter-class>
        org.jboss.resteasy.plugins.server.servlet.FilterDispatcher
    </filter-class>
</filter>
        
            The user is not limited to using RESTEasy's ContextLoaderListener
            implementation.  The user may provide their own implementation, however such a
            customization will require the creation of two additional custom classes, to
            facilitate the wiring of needed RESTEasy classes into the Spring configuration.
            An implementation of org.springframework.web.WebApplicationInitializer
            and a class that provides an instance of
            org.jboss.resteasy.plugins.spring.SpringBeanProcessorServletAware
            will be needed.
            Spring and
                Resteasy Customized Example
             provides an example of the wiring that is required.
        
            There are four RESTEasy classes that must be registered with Spring in the
            implementation of WebApplicationInitializer, ResteasyBootstrap,
            HttpServletDispatcher, ResteasyDeployment, and
            SpringBeanProcessorServletAware.
        
@Override
public void onStartup(ServletContext servletContext) throws ServletException {
(1)     servletContext.addListener(ResteasyBootstrap.class);
        AnnotationConfigWebApplicationContext context = new AnnotationConfigWebApplicationContext();
(2)     context.register(MyConfig.class);
(3)     servletContext.addListener(new MyContextLoaderListener(context));
(4)     ServletRegistration.Dynamic dispatcher = servletContext.addServlet("resteasy-dispatcher", new HttpServletDispatcher());
        dispatcher.setLoadOnStartup(1);
        dispatcher.addMapping("/rest/*");
}
        ResteasyBootstrap needs to be registered in the
                servletContext so that the RESTEasy container can gain access to it.
            MyConfig class provides RESTEasy's implementation of
                BeanProcessorServletAware as a @Bean to the Spring container.
            ContextLoaderListener is registered in
                servletContext so that the RESTEasy container can gain access to it.
            HttpServletDispatcher is registered in
                servletContext so that the RESTEasy container can gain access to it.
            
            The user's implementation of ContextLoaderListener performs two
            important actions.
        
@Override
protected void customizeContext(ServletContext servletContext, ConfigurableWebApplicationContext configurableWebApplicationContext) {
        super.customizeContext(servletContext, configurableWebApplicationContext);
(1)     ResteasyDeployment deployment = (ResteasyDeployment) servletContext.getAttribute(ResteasyDeployment.class.getName());
        if (deployment == null) {
            throw new RuntimeException(Messages.MESSAGES.deploymentIsNull());
        }
(2)     SpringBeanProcessor processor = new SpringBeanProcessor(deployment);
        configurableWebApplicationContext.addBeanFactoryPostProcessor(processor);
        configurableWebApplicationContext.addApplicationListener(processor);
    }
        ResteasyDeployment must be
                retrieved from the servletContext.
            
            RESTEasy's Spring integration supports both singleton and prototype scope. It handles
            injecting @Context references. Constructor injection is not supported.
            With the prototype scope RESTEasy will inject any @*Param annotated fields
            or setters before the request is dispatched.
        
            Note: Only auto-proxied beans can be used with RESTEasy's
            Spring integration.  There will be undesirable affects if you use handcoded proxying
            with Spring, i.e., with ProxyFactoryBean.
        
            RESTEasy can be integrated with the Spring MVC Framework. Generally speaking, Jakarta RESTful Web Services
            can be combined with a Spring org.springframework.web.servlet.DispatcherServlet
            and used in the same web application.
            An application combined in this way allows the application to dispatch to either
            the Spring controller or the Jakarta RESTful Web Services resource using the same base URL.
            In addition Spring ModelAndView objects can be returned as
            arguments from @GET resource methods.
        
The Spring MVC Integration Example demonstrates how to configure an application using Spring MVC.
            resteasy-spring provides bean xml file, springmvc-resteasy.xml.
            It resides in the org.jboss.resteasy.spring:resteasy-spring archive.
            The file defines the beans for the Spring MVC/RESTEasy integration.  The file is required
            to be imported into the user's MVC application.
            This bean file can be used as a template to define more advanced functionality,
            such as configuring multiple RESTEasy factories, dispatchers and registries.
        
            In the example, the reference to springmvc-resteasy.xml is declared in an
            application provided bean xml named, resteasy-spring-mvc-servlet.xml.
            This file imports springmvc-resteasy.xml.
        
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:context="http://www.springframework.org/schema/context"
       xsi:schemaLocation="
        http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-2.5.xsd
        http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
    ">
(1)    <context:component-scan base-package="org.jboss.resteasy.examples.springmvc"/>
       <context:annotation-config/>
(2)    <import resource="classpath:springmvc-resteasy.xml"/>
....
</beans>
        springmvc-resteasy.xml
            
            The setup requires the application to provide a web.xml file in which a
            Spring DispatcherServlet implementation is declared.
            Project resteasy-spring provides a default Spring DispatcherServlet
            implementation, org.jboss.resteasy.springmvc.ResteasySpringDispatcherServlet.
            This is the DispatcherServlet used in the example code.
        
            The DispatcherServlet takes as an input parameter a reference to the application's
            bean file.  This reference is declared as an init-param to the servlet.
        
The application's web.xml should define the servlet as follows:
<web-app version="3.0" xmlns="http://java.sun.com/xml/ns/javaee"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
         http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd">
    <display-name>resteasy-spring-mvc</display-name>
    <servlet>
        <servlet-name>resteasy-spring-mvc</servlet-name>
 (1)    <servlet-class>org.jboss.resteasy.springmvc.ResteasySpringDispatcherServlet</servlet-class>
        <init-param>
            <param-name>contextConfigLocation</param-name>
 (2)        <param-value>classpath:resteasy-spring-mvc-servlet.xml</param-value>
        </init-param>
    </servlet>
    ....
</web-app>
        DispatcherServlet
            org.jboss.resteasy.spring:resteasy-spring archive's
                springmvc-resteasy.xml file.
            
            A jakarta.ws.rs.core.Application subclass can be combined with a Spring
            DispatcherServlet and used in the same web application.
            In this scenario a servlet declaration is required for the Spring
            DispatcherServlet and the jakarta.ws.rs.core.Application subclass.
            A RESTEasy Configuration Switch, resteasy.scan.resources must be declared
            as a context-param in the web.xml.  Here is an example of the minimum
            configuration information needed in the web.xml.
        
<web-app>
    <servlet>
        <servlet-name>mySpring</servlet-name>
 (1)    <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
    </servlet>
    <servlet-mapping>
        <servlet-name>mySpring</servlet-name>
        <url-pattern>/*</url-pattern>
    </servlet-mapping>
    <servlet>
        <servlet-name>myAppSubclass</servlet-name>
 (2)    <servlet-class>org.my.app.EntryApplicationSubclass</servlet-class>
    </servlet>
    <servlet-mapping>
        <servlet-name>myAppSubclass</servlet-name>
        <url-pattern>/*</url-pattern>
    </servlet-mapping>
    <!-- required RESTEasy Configuration Switch directs auto scanning
         of the archive for Jakarta RESTful Web Services resource files
    -->
    <context-param>
 (3)    <param-name>resteasy.scan.resources</param-name>
        <param-value>true</param-value>
    </context-param>
</web-app>
        DispatcherServlet declarationApplication declarationNote: RESTEasy parameters like
            resteasy.scan.resources may be set in a variety of ways. See
            Section 3.4, “Configuration”
            for more information about application configuration.
        
            If the web application contains Jakarta RESTful Web Services provider classes the RESTEasy Configuration
            Switch, resteasy.scan.providers, will also be needed. If the url-pattern for the
            Jakarta RESTful Web Services Application subclass is other than /* a declaration
            of RESTEasy Configuration Switch, resteasy.servlet.mapping.prefix will be
            required. This switch can be declared either as a context-param or as a servlet
            init-param.
            It's value must be the text that precedes the /*. Here is an example of such
            a web.xml:
            
<web-app>
    .....
    <servlet>
        <servlet-name>myAppSubclass</servlet-name>
        <servlet-class>org.my.app.EntryApplicationSubclass</servlet-class>
        <init-param>
 (1)        <param-name>resteasy.servlet.mapping.prefix</param-name>
            <param-value>/resources</param-value>
        </init-param>
    </servlet>
    <servlet-mapping>
        <servlet-name>myAppSubclass</servlet-name>
 (2)    <url-pattern>/resources/*</url-pattern>
    </servlet-mapping>
    <context-param>
 (3)    <param-name>resteasy.scan.resources</param-name>
        <param-value>true</param-value>
    </context-param>
    <context-param>
 (3)    <param-name>resteasy.scan.providers</param-name>
        <param-value>true</param-value>
    </context-param>
</web-app>
            
            Project resteasy-spring provides an Undertow based embedded Spring container
            module, resteasy-undertow-spring.  It provides class,
            org.jboss.resteasy.plugins.server.undertow.spring.UndertowJaxrsSpringServer.
            This class has a single method, undertowDeployment
            which requires an input parameter that references a Spring context configuration
            file.  The Spring context configuration data is used to wire Spring into Undertow.
        
An example of setting up the Undertow embedded Spring container can be found in example, resteasy-spring-undertow
To use this container the user must add the following two archives to their maven project.
<dependency>
  <groupId>org.jboss.resteasy</groupId>
  <artifactId>resteasy-undertow</artifactId>
  <version>${SOME_VERSION}</version>
</dependency>
<dependency>
  <groupId>org.jboss.resteasy</groupId>
  <artifactId>resteasy-undertow-spring</artifactId>
  <version>${SOME_VERSION}</version>
</dependency>
        
            The user's application must provide a bean xml file that imports a reference
            to the org.jboss.resteasy.spring:resteasy-spring archive's bean
            file, springmvc-resteasy.xml.
            In the example code the user's provided file is named, spring-servlet.xml
            Here is the information needed in this file.
        
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:p="http://www.springframework.org/schema/p"
       xmlns:context="http://www.springframework.org/schema/context"
       xmlns:util="http://www.springframework.org/schema/util"
       xsi:schemaLocation="
        http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-2.5.xsd
        http://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util-2.5.xsd
        http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
        ">
    <context:component-scan base-package="org.jboss.resteasy.springmvc.test"/>
    <context:annotation-config/>
    <import resource="classpath:springmvc-resteasy.xml"/>
</beans>
        Below is a code snippet that shows the creation and configuration of the Undertow embedded Spring container.
(1) UndertowJaxrsSpringServer server = new UndertowJaxrsSpringServer();
    server.start();
(2) DeploymentInfo deployment = server.undertowDeployment("classpath:spring-servlet.xml", null);
    deployment.setDeploymentName(BasicSpringTest.class.getName());
    deployment.setContextPath("/");
    deployment.setClassLoader(BasicSpringTest.class.getClassLoader());
    server.deploy(deployment);
        
            RESTEasy also provides the ability to process Spring Web REST annotations (i.e. Spring classes annotated
            with @RestController)
            and handle related REST requests without delegating to Spring MVC. This functionality is currently
            experimental.
        
            In order for RESTEasy to be able to process Spring @RestController,
            the user must include the following maven dependency.
        
<dependency>
    <groupId>org.jboss.resteasy.spring</groupId>
    <artifactId>resteasy-spring-web</artifactId>
    <version>${version.org.jboss.resteasy.spring}</version>
</dependency>
            
            RESTEasy does not auto-scan for @RestController annotated classes, so
            all @RestController annotated classes need to be declared in the application's
            web.xml file as shown below.
        
 <web-app>
   <display-name>RESTEasy application using Spring REST annotations</display-name>
    <context-param>
        <param-name>resteasy.scanned.resource.classes.with.builder</param-name>
        <param-value>org.jboss.resteasy.spi.metadata.SpringResourceBuilder:org.example.Controller1,org.example.Controller2</param-value>
    </context-param>
   ...
</web-app>
        
            In the example above, Controller1 and Controller2 are registered and expected
            to be annotated with @RestController.
        
Currently supported annotations:
| Annotation | Comment | 
|---|---|
| @RestController | |
| @RequestMapping | |
| @GetMapping | |
| @PostMapping | |
| @PutMapping | |
| @DeleteMapping | |
| @PatchMapping | |
| @RequestParam | |
| @RequestHeader | |
| @MatrixVariable | |
| @PathVariable | |
| @CookieValue | |
| @RequestBody | |
| @ResponseStatus | Only supported as a method annotation | 
| @RequestParam | 
            The use of org.springframework.http.ResponseEntity,
            jakarta.servlet.http.HttpServletRequest and
            jakarta.servlet.http.HttpServletResponse are supported as return values
            of method parameters.
        
A usage example can be found in sample project resteasy-spring-rest
RESTEasy supports Spring Boot integration. The code was developed by PayPal and donated to the RESTEasy community. The project is maintained in the RESTEasy Spring Boot Starter Project.
Here is the usage in brief:
Add this maven dependency to the Spring Boot application:
<dependency>
   <groupId>org.jboss.resteasy</groupId>
   <artifactId>resteasy-spring-boot-starter</artifactId>
   <version>${latest_version_of_restesy_spring_boot}</version>
   <scope>runtime</scope>
</dependency>
            
            Use Spring annotation @Component to register a Jakarta RESTful Web Services
            Application class:
            
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 {
}
            
To register Jakarta RESTful Web Services resources and providers, define them as Spring beans. They will be automatically registered. Notice that Jakarta RESTful Web Services resources can be singleton or request scoped, while Jakarta RESTful Web Services providers must be singletons.
To see an example, please check the sample-app .
As noted in Section 3.1.2, “Upgrading RESTEasy within WildFly”, Galleon is used in updating RESTEasy distributions in Wildfly. RESTEasy Spring also uses Galleon for the same task. Follow the directions in that section to install Galleon, then run command:
galleon.sh install org.jboss.resteasy.spring:galleon-feature-pack:{CURRENT-VERSION} --dir=${WILDFLY-HOME}
        Note Installing resteasy-spring feature pack, also installs the corresponding RESTEasy archives do to transitive dependencies.