Static Content in Spring WebFlux

1. Overview

Sometimes, we have to serve static content in our web applications. It might be an image, HTML, CSS, or a JavaScript file.

In this tutorial, we’ll show how to serve static content using Spring WebFlux. We also assume that our web application will be configured using Spring Boot.

2. Overriding the Default Configuration

By default, Spring Boot serves static content from the following locations:

  • /public
  • /static
  • /resources
  • /META-INF/resources

All files from these paths are served under the /[resource-file-name] path.

If we want to change the default path for Spring WebFlux, we need to add this property to our application.properties file:

spring.webflux.static-path-pattern=/assets/**

Now, the static resources will be located under /assets/[resource-file-name].

Please note that this won’t work when the @EnableWebFlux annotation is present.

3. Routing Example

It’s also possible to serve static content using the WebFlux routing mechanism.

Let’s look at an example of a routing definition to serve the index.html file:

@Bean
public RouterFunction<ServerResponse> htmlRouter(
  @Value("classpath:/public/index.html") Resource html) {
    return route(GET("/"), request
      -> ok().contentType(MediaType.TEXT_HTML).syncBody(html)
    );
}

We can also serve static content from custom locations with the help of RouterFunction.

Let’s see how to serve images from the src/main/resources/img directory using the /img/** path:

@Bean
public RouterFunction<ServerResponse> imgRouter() {
    return RouterFunctions
      .resources("/img/**", new ClassPathResource("img/"));
}

4. Custom Web Resources Path Example

Another way to serve static assets stored in custom locations, instead of the default src/main/resources path, is to use the maven-resources-plugin and an additional Spring WebFlux property.

First, let’s add the plugin to our pom.xml:

<plugin>
    <artifactId>maven-resources-plugin</artifactId>
    <version>3.1.0</version>
    <executions>
        <execution>
            <id>copy-resources</id>
            <phase>validate</phase>
            <goals>
                <goal>copy-resources</goal>
            </goals>
            <configuration>
                <resources>
                    <resource>
                        <directory>src/main/assets</directory>
                        <filtering>true</filtering>
                    </resource>
                </resources>
                <outputDirectory>${basedir}/target/classes/assets</outputDirectory>
            </configuration>
        </execution>
    </executions>
</plugin>

Then, we simply need to set the static locations property:

spring.resources.static-locations=classpath:/assets/

After these actions, the index.html will be available under the http://localhost:8080/index.html URL.

5. Conclusion

In this article, we learned how to serve static content in Spring WebFlux.

As always, the sample code presented is available over on GitHub.

Related posts:

Java String Conversions
Using a List of Values in a JdbcTemplate IN Clause
Java Program to Perform Searching Based on Locality of Reference
Hướng dẫn Java Design Pattern – Observer
Comparing Objects in Java
An Intro to Spring Cloud Security
Java Program to Implement Regular Falsi Algorithm
Converting Between Byte Arrays and Hexadecimal Strings in Java
Java Program to Solve Set Cover Problem assuming at max 2 Elements in a Subset
Hướng dẫn Java Design Pattern – Template Method
Spring WebClient Requests with Parameters
A Guide to @RepeatedTest in Junit 5
Call Methods at Runtime Using Java Reflection
Spring REST API + OAuth2 + Angular (using the Spring Security OAuth legacy stack)
Spring MVC Tutorial
Abstract class và Interface trong Java
Hướng dẫn Java Design Pattern – Iterator
Java Program to Implement Disjoint Set Data Structure
Converting Java Date to OffsetDateTime
Collection trong java
Java Program to Describe the Representation of Graph using Incidence List
Java Program to Implement Rolling Hash
Java 8 – Powerful Comparison with Lambdas
Java Program to Implement a Binary Search Algorithm for a Specific Search Sequence
Java Program to Implement Queue using Linked List
SOAP Web service: Authentication trong JAX-WS
Guide to Spring @Autowired
Redirect to Different Pages after Login with Spring Security
Java Program to Implement Bellman-Ford Algorithm
Spring Boot - Enabling HTTPS
Understanding Memory Leaks in Java
Hướng dẫn sử dụng biểu thức chính quy (Regular Expression) trong Java