Spring Session MongoDB 2.0.0.M3 released

Engineering | Greg L. Turnquist | September 15, 2017 | ...

Dear Spring Community,

Spring Session MongoDB 2.0.0.M3 is released. It is based on:

In this release, several new features have been added to simplify using it with your Spring WebFlux application.

@EnableMongoWebSession
public class SpringWebFluxConfig {

}

All you must do is apply the @EnableMongoWebSession to any of your Spring configuration classes to activate session support with MongoDB. Additionally, you must provide a ReactorMongoOperations Spring bean, but if you’re using Spring Boot’s spring-boot-starter-data-mongodb-reactive starter, this is already provided.

@EnableMongoWebSession comes with the ability to set session-wide overrides including maxInactiveIntervalInSeconds and collectionName, to match the same features as the servlet-based @EnableMongoHttpSession annotation.

Note

@EnableMongoWebSession itself applies a Spring @Configuration annotation, so there is no need to apply the same annotation to your own configuration class.

Spring Session MongoDB, by default, uses the JDK-based serialization strategy and it is verified to support writing security context details out to MongoDB, making it seemless to integrate with Spring Security.

As mentioned in the recent Spring Session blog post, Spring Session MongoDB (through Spring Session and Spring WebFlux), leverages cookie-base session handling. This means that when a new session is created, the app will send back to the client a set-cookie SESSION=…​ response header, and also check incoming web requests for a cookie named SESSION. But with Spring Framework 5.0.0.M4, there is now the opportunity to switch from cookies to a header-based strategy.

To change from cookies to headers, simply add this Spring bean to your configuration:

@EnableMongoWebSession
public class SpringWebFluxConfig {

	@Bean
	HeaderWebSessionIdResolver headerBasedSessionIdResolver() {
	    return new HeaderWebSessionIdResolver();
	}
}

When creating a new session, HeaderWebSessionIdResolver will generate a SESSION=…​ response header clients can pick up. And incoming web requests will be parsed for a SESSION=…​ request header.

It’s also possible to change the name of the header as shown below:

@EnableMongoWebSession
public class SpringWebFluxConfig {

	@Bean
	HeaderWebSessionIdResolver headerBasedSessionIdResolver() {
	    HeaderWebSessionIdResolver resolver = new HeaderWebSessionIdResolver();
	    resolver.setHeaderName("MyCustomHeaderName"); // Use this instead of SESSION for the header
	    return resolver;
	}
}

With all this, you’re geared up to use Spring Session MongoDB for session management, and tailor it as you wish!

Important

In the past, Spring Session MongoDB would use Jackson-based serialization if it detected Jackson on the classpath. Since we’ve switched to JDK-based serialization, and not having it jump purely based on classpath settings, it’s recommended that any running applications may have to drop existing sessions and reinitialize.

In the meantime, you can get the bits today if you visit the project site, get the coordinates, and include the version number in your Spring Boot application.

Project Site | Reference | Help

Get the Spring newsletter

Thank you for your interest. Someone will get back to you shortly.

Get ahead

VMware offers training and certification to turbo-charge your progress.

Learn more

Get support

Tanzu Spring Runtime offers support and binaries for OpenJDK™, Spring, and Apache Tomcat® in one simple subscription.

Learn more

Upcoming events

Check out all the upcoming events in the Spring community.

View all