2016-09-23 13:02:27 -05:00
[[jackson]]
2021-07-30 13:52:15 -05:00
= Jackson Support
2016-09-23 13:02:27 -05:00
2025-10-17 11:24:48 +02:00
Spring Security provides Jackson 3 support for persisting Spring Security related classes.
2016-09-23 13:02:27 -05:00
This can improve the performance of serializing Spring Security related classes when working with distributed sessions (i.e. session replication, Spring Session, etc).
2025-10-17 11:24:48 +02:00
[NOTE]
====
Jackson 2 support is still available but deprecated for removal, so you are encouraged to migrate to Jackson 3.
====
To use it, register `SecurityJacksonModules.getModules(ClassLoader)` with `JsonMapper.Builder` (https://github.com/FasterXML/jackson-databind[jackson-databind]):
2016-09-23 13:02:27 -05:00
2023-06-18 21:30:41 -05:00
[tabs]
======
Java::
+
2021-06-16 10:31:29 +02:00
[source,java,role="primary"]
2016-09-23 13:02:27 -05:00
----
ClassLoader loader = getClass().getClassLoader();
2025-09-01 18:23:31 +02:00
JsonMapper mapper = JsonMapper.builder()
.addModules(SecurityJacksonModules.getModules(loader))
.build();
2016-09-23 13:02:27 -05:00
2025-09-01 18:23:31 +02:00
// ... use JsonMapper as normally ...
2016-09-23 13:02:27 -05:00
SecurityContext context = new SecurityContextImpl();
// ...
String json = mapper.writeValueAsString(context);
----
2020-03-18 13:59:40 -04:00
2023-06-18 21:30:41 -05:00
Kotlin::
+
2021-06-16 10:31:29 +02:00
[source,kotlin,role="secondary"]
----
val loader = javaClass.classLoader
2025-09-01 18:23:31 +02:00
val mapper = JsonMapper.builder()
.addModules(SecurityJacksonModules.getModules(loader))
.build()
2021-06-16 10:31:29 +02:00
2025-09-01 18:23:31 +02:00
// ... use JsonMapper as normally ...
2021-06-16 10:31:29 +02:00
val context: SecurityContext = SecurityContextImpl()
// ...
val json: String = mapper.writeValueAsString(context)
----
2023-06-18 21:30:41 -05:00
======
2021-06-16 10:31:29 +02:00
2025-10-17 11:24:48 +02:00
[NOTE]
====
Using `SecurityJacksonModules` as above enables automatic inclusion of type information and configure a
`PolymorphicTypeValidator` that handles the validation of class names.
====
If needed, you can add custom classes to the validation handling.
[tabs]
======
Java::
+
[source,java,role="primary"]
----
ClassLoader loader = getClass().getClassLoader();
BasicPolymorphicTypeValidator.Builder builder = BasicPolymorphicTypeValidator.builder()
.allowIfSubType(MyCustomType.class);
JsonMapper mapper = JsonMapper.builder()
.addModules(SecurityJacksonModules.getModules(loader, builder))
.build();
----
Kotlin::
+
[source,kotlin,role="secondary"]
----
val loader = javaClass.classLoader
val builder = BasicPolymorphicTypeValidator.builder()
.allowIfSubType(MyCustomType::class)
val mapper = JsonMapper.builder()
.addModules(SecurityJacksonModules.getModules(loader, builder))
.build()
----
======
2020-03-18 13:59:40 -04:00
[NOTE]
====
The following Spring Security modules provide Jackson support:
2025-10-17 11:24:48 +02:00
- spring-security-core (javadoc:org.springframework.security.jackson.CoreJacksonModule[])
- spring-security-web (javadoc:org.springframework.security.web.jackson.WebJacksonModule[], javadoc:org.springframework.security.web.jackson.WebServletJacksonModule[], javadoc:org.springframework.security.web.server.jackson.WebServerJacksonModule[])
- spring-security-oauth2-client (javadoc:org.springframework.security.oauth2.client.jackson.OAuth2ClientJacksonModule[])
- spring-security-cas (javadoc:org.springframework.security.cas.jackson.CasJacksonModule[])
- spring-security-ldap (javadoc:org.springframework.security.ldap.jackson.LdapJacksonModule[])
- spring-security-saml2 (javadoc:org.springframework.security.saml2.jackson.Saml2JacksonModule[])
2020-03-18 13:59:40 -04:00
====