| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950 |
- [[jackson]]
- = Jackson Support
- Spring Security provides Jackson support for persisting Spring Security related classes.
- This can improve the performance of serializing Spring Security related classes when working with distributed sessions (i.e. session replication, Spring Session, etc).
- To use it, register the `SecurityJacksonModules.getModules(ClassLoader)` with `JsonMapper.Builder` (https://github.com/FasterXML/jackson-databind[jackson-databind]):
- [tabs]
- ======
- Java::
- +
- [source,java,role="primary"]
- ----
- ClassLoader loader = getClass().getClassLoader();
- JsonMapper mapper = JsonMapper.builder()
- .addModules(SecurityJacksonModules.getModules(loader))
- .build();
- // ... use JsonMapper as normally ...
- SecurityContext context = new SecurityContextImpl();
- // ...
- String json = mapper.writeValueAsString(context);
- ----
- Kotlin::
- +
- [source,kotlin,role="secondary"]
- ----
- val loader = javaClass.classLoader
- val mapper = JsonMapper.builder()
- .addModules(SecurityJacksonModules.getModules(loader))
- .build()
- // ... use JsonMapper as normally ...
- val context: SecurityContext = SecurityContextImpl()
- // ...
- val json: String = mapper.writeValueAsString(context)
- ----
- ======
- [NOTE]
- ====
- The following Spring Security modules provide Jackson support:
- - spring-security-core (`CoreJacksonModule`)
- - spring-security-web (`WebJacksonModule`, `WebServletJacksonModule`, `WebServerJacksonModule`)
- - xref:servlet/oauth2/client/index.adoc#oauth2client[ spring-security-oauth2-client] (`OAuth2ClientJacksonModule`)
- - spring-security-cas (`CasJacksonModule`)
- ====
|