# Security HTTP Response Headers [Security HTTP Response Headers](../../features/exploits/headers.html#headers) can be used to increase the security of web applications. This section is dedicated to WebFlux based support for Security HTTP Response Headers. ## Default Security Headers Spring Security provides a [default set of Security HTTP Response Headers](../../features/exploits/headers.html#headers-default) to provide secure defaults. While each of these headers are considered best practice, it should be noted that not all clients utilize the headers, so additional testing is encouraged. You can customize specific headers. For example, assume that you want the defaults except you wish to specify `SAMEORIGIN` for [X-Frame-Options](../../servlet/exploits/headers.html#servlet-headers-frame-options). You can easily do this with the following Configuration: Example 1. Customize Default Security Headers Java ``` @Bean SecurityWebFilterChain springSecurityFilterChain(ServerHttpSecurity http) { http // ... .headers(headers -> headers .frameOptions(frameOptions -> frameOptions .mode(Mode.SAMEORIGIN) ) ); return http.build(); } ``` Kotlin ``` @Bean fun webFilterChain(http: ServerHttpSecurity): SecurityWebFilterChain { return http { // ... headers { frameOptions { mode = Mode.SAMEORIGIN } } } } ``` If you do not want the defaults to be added and want explicit control over what should be used, you can disable the defaults. An example is provided below: Example 2. Disable HTTP Security Response Headers Java ``` @Bean SecurityWebFilterChain springSecurityFilterChain(ServerHttpSecurity http) { http // ... .headers(headers -> headers.disable()); return http.build(); } ``` Kotlin ``` @Bean fun webFilterChain(http: ServerHttpSecurity): SecurityWebFilterChain { return http { // ... headers { disable() } } } ``` ## Cache Control Spring Security includes [Cache Control](../../features/exploits/headers.html#headers-cache-control) headers by default. However, if you actually want to cache specific responses, your application can selectively add them to the [ServerHttpResponse](https://docs.spring.io/spring-framework/docs/current/javadoc-api/org/springframework/http/server/reactive/ServerHttpResponse.html) to override the header set by Spring Security. This is useful to ensure things like CSS, JavaScript, and images are properly cached. When using Spring WebFlux, this is typically done within your configuration. Details on how to do this can be found in the [Static Resources](https://docs.spring.io/spring/docs/5.0.0.RELEASE/spring-framework-reference/web-reactive.html#webflux-config-static-resources) portion of the Spring Reference documentation If necessary, you can also disable Spring Security’s cache control HTTP response headers. Example 3. Cache Control Disabled Java ``` @Bean SecurityWebFilterChain springSecurityFilterChain(ServerHttpSecurity http) { http // ... .headers(headers -> headers .cache(cache -> cache.disable()) ); return http.build(); } ``` Kotlin ``` @Bean fun webFilterChain(http: ServerHttpSecurity): SecurityWebFilterChain { return http { // ... headers { cache { disable() } } } } ``` ## Content Type Options Spring Security includes [Content-Type](../../features/exploits/headers.html#headers-content-type-options) headers by default. However, you can disable it with: Example 4. Content Type Options Disabled Java ``` @Bean SecurityWebFilterChain springSecurityFilterChain(ServerHttpSecurity http) { http // ... .headers(headers -> headers .contentTypeOptions(contentTypeOptions -> contentTypeOptions.disable()) ); return http.build(); } ``` Kotlin ``` @Bean fun webFilterChain(http: ServerHttpSecurity): SecurityWebFilterChain { return http { // ... headers { contentTypeOptions { disable() } } } } ``` ## Spring Security provides the [Strict Transport Security](../../features/exploits/headers.html#headers-hsts) header by default. However, you can customize the results explicitly. For example, the following is an example of explicitly providing HSTS: Example 5. Strict Transport Security Java ``` @Bean SecurityWebFilterChain springSecurityFilterChain(ServerHttpSecurity http) { http // ... .headers(headers -> headers .hsts(hsts -> hsts .includeSubdomains(true) .preload(true) .maxAge(Duration.ofDays(365)) ) ); return http.build(); } ``` Kotlin ``` @Bean fun webFilterChain(http: ServerHttpSecurity): SecurityWebFilterChain { return http { // ... headers { hsts { includeSubdomains = true preload = true maxAge = Duration.ofDays(365) } } } } ``` ## X-Frame-Options By default, Spring Security disables rendering within an iframe using [X-Frame-Options](../../features/exploits/headers.html#headers-frame-options). You can customize frame options to use the same origin using the following: Example 6. X-Frame-Options: SAMEORIGIN Java ``` @Bean SecurityWebFilterChain springSecurityFilterChain(ServerHttpSecurity http) { http // ... .headers(headers -> headers .frameOptions(frameOptions -> frameOptions .mode(SAMEORIGIN) ) ); return http.build(); } ``` Kotlin ``` @Bean fun webFilterChain(http: ServerHttpSecurity): SecurityWebFilterChain { return http { // ... headers { frameOptions { mode = SAMEORIGIN } } } } ``` ## X-XSS-Protection By default, Spring Security instructs browsers to block reflected XSS attacks using the \<\. You can disable `X-XSS-Protection` with the following Configuration: Example 7. X-XSS-Protection Customization Java ``` @Bean SecurityWebFilterChain springSecurityFilterChain(ServerHttpSecurity http) { http // ... .headers(headers -> headers .xssProtection(xssProtection -> xssProtection.disable()) ); return http.build(); } ``` Kotlin ``` @Bean fun webFilterChain(http: ServerHttpSecurity): SecurityWebFilterChain { return http { // ... headers { xssProtection { disable() } } } } ``` ## Spring Security does not add [Content Security Policy](../../features/exploits/headers.html#headers-csp) by default, because a reasonable default is impossible to know without context of the application. The web application author must declare the security policy(s) to enforce and/or monitor for the protected resources. For example, given the following security policy: Example 8. Content Security Policy Example ``` Content-Security-Policy: script-src 'self' https://trustedscripts.example.com; object-src https://trustedplugins.example.com; report-uri /csp-report-endpoint/ ``` You can enable the CSP header as shown below: Example 9. Content Security Policy Java ``` @Bean SecurityWebFilterChain springSecurityFilterChain(ServerHttpSecurity http) { http // ... .headers(headers -> headers .contentSecurityPolicy(policy -> policy .policyDirectives("script-src 'self' https://trustedscripts.example.com; object-src https://trustedplugins.example.com; report-uri /csp-report-endpoint/") ) ); return http.build(); } ``` Kotlin ``` @Bean fun webFilterChain(http: ServerHttpSecurity): SecurityWebFilterChain { return http { // ... headers { contentSecurityPolicy { policyDirectives = "script-src 'self' https://trustedscripts.example.com; object-src https://trustedplugins.example.com; report-uri /csp-report-endpoint/" } } } } ``` To enable the CSP `report-only` header, provide the following configuration: Example 10. Content Security Policy Report Only Java ``` @Bean SecurityWebFilterChain springSecurityFilterChain(ServerHttpSecurity http) { http // ... .headers(headers -> headers .contentSecurityPolicy(policy -> policy .policyDirectives("script-src 'self' https://trustedscripts.example.com; object-src https://trustedplugins.example.com; report-uri /csp-report-endpoint/") .reportOnly() ) ); return http.build(); } ``` Kotlin ``` @Bean fun webFilterChain(http: ServerHttpSecurity): SecurityWebFilterChain { return http { // ... headers { contentSecurityPolicy { policyDirectives = "script-src 'self' https://trustedscripts.example.com; object-src https://trustedplugins.example.com; report-uri /csp-report-endpoint/" reportOnly = true } } } } ``` ## Referrer Policy Spring Security does not add [Referrer Policy](../../features/exploits/headers.html#headers-referrer) headers by default. You can enable the Referrer Policy header using configuration as shown below: Example 11. Referrer Policy Configuration Java ``` @Bean SecurityWebFilterChain springSecurityFilterChain(ServerHttpSecurity http) { http // ... .headers(headers -> headers .referrerPolicy(referrer -> referrer .policy(ReferrerPolicy.SAME_ORIGIN) ) ); return http.build(); } ``` Kotlin ``` @Bean fun webFilterChain(http: ServerHttpSecurity): SecurityWebFilterChain { return http { // ... headers { referrerPolicy { policy = ReferrerPolicy.SAME_ORIGIN } } } } ``` ## Feature Policy Spring Security does not add [Feature Policy](../../features/exploits/headers.html#headers-feature) headers by default. The following `Feature-Policy` header: Example 12. Feature-Policy Example ``` Feature-Policy: geolocation 'self' ``` You can enable the Feature Policy header as shown below: Example 13. Feature-Policy Configuration Java ``` @Bean SecurityWebFilterChain springSecurityFilterChain(ServerHttpSecurity http) { http // ... .headers(headers -> headers .featurePolicy("geolocation 'self'") ); return http.build(); } ``` Kotlin ``` @Bean fun webFilterChain(http: ServerHttpSecurity): SecurityWebFilterChain { return http { // ... headers { featurePolicy("geolocation 'self'") } } } ``` ## Permissions Policy Spring Security does not add [Permissions Policy](../../features/exploits/headers.html#headers-permissions) headers by default. The following `Permissions-Policy` header: Example 14. Permissions-Policy Example ``` Permissions-Policy: geolocation=(self) ``` You can enable the Permissions Policy header as shown below: Example 15. Permissions-Policy Configuration Java ``` @Bean SecurityWebFilterChain springSecurityFilterChain(ServerHttpSecurity http) { http // ... .headers(headers -> headers .permissionsPolicy(permissions -> permissions .policy("geolocation=(self)") ) ); return http.build(); } ``` Kotlin ``` @Bean fun webFilterChain(http: ServerHttpSecurity): SecurityWebFilterChain { return http { // ... headers { permissionsPolicy { policy = "geolocation=(self)" } } } } ``` ## Clear Site Data Spring Security does not add [Clear-Site-Data](../../features/exploits/headers.html#headers-clear-site-data) headers by default. The following Clear-Site-Data header: Example 16. Clear-Site-Data Example ``` Clear-Site-Data: "cache", "cookies" ``` can be sent on log out with the following configuration: Example 17. Clear-Site-Data Configuration Java ``` @Bean SecurityWebFilterChain springSecurityFilterChain(ServerHttpSecurity http) { ServerLogoutHandler securityContext = new SecurityContextServerLogoutHandler(); ClearSiteDataServerHttpHeadersWriter writer = new ClearSiteDataServerHttpHeadersWriter(CACHE, COOKIES); ServerLogoutHandler clearSiteData = new HeaderWriterServerLogoutHandler(writer); DelegatingServerLogoutHandler logoutHandler = new DelegatingServerLogoutHandler(securityContext, clearSiteData); http // ... .logout() .logoutHandler(logoutHandler); return http.build(); } ``` Kotlin ``` @Bean fun webFilterChain(http: ServerHttpSecurity): SecurityWebFilterChain { val securityContext: ServerLogoutHandler = SecurityContextServerLogoutHandler() val writer = ClearSiteDataServerHttpHeadersWriter(CACHE, COOKIES) val clearSiteData: ServerLogoutHandler = HeaderWriterServerLogoutHandler(writer) val customLogoutHandler = DelegatingServerLogoutHandler(securityContext, clearSiteData) return http { // ... logout { logoutHandler = customLogoutHandler } } } ```