All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.springframework.security.web.header.writers.XXssProtectionHeaderWriter Maven / Gradle / Ivy

There is a newer version: 6.2.4
Show newest version
/*
 * Copyright 2002-2013 the original author or authors.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package org.springframework.security.web.header.writers;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.springframework.security.web.header.HeaderWriter;

/**
 * Renders the X-XSS-Protection header.
 *
 * @author Rob Winch
 * @since 3.2
 */
public final class XXssProtectionHeaderWriter implements HeaderWriter {
	private static final String XSS_PROTECTION_HEADER = "X-XSS-Protection";

	private boolean enabled;

	private boolean block;

	private String headerValue;

	/**
	 * Create a new instance
	 */
	public XXssProtectionHeaderWriter() {
		this.enabled = true;
		this.block = true;
		updateHeaderValue();
	}

	public void writeHeaders(HttpServletRequest request, HttpServletResponse response) {
		response.setHeader(XSS_PROTECTION_HEADER, headerValue);
	}

	/**
	 * If true, will contain a value of 1. For example:
	 *
	 * 
	 * X-XSS-Protection: 1
	 * 
* * or if {@link #setBlock(boolean)} is true * * *
	 * X-XSS-Protection: 1; mode=block
	 * 
* * If false, will explicitly disable specify that X-XSS-Protection is disabled. For * example: * *
	 * X-XSS-Protection: 0
	 * 
* * @param enabled the new value */ public void setEnabled(boolean enabled) { if (!enabled) { setBlock(false); } this.enabled = enabled; updateHeaderValue(); } /** * If false, will not specify the mode as blocked. In this instance, any content will * be attempted to be fixed. If true, the content will be replaced with "#". * * @param block the new value */ public void setBlock(boolean block) { if (!enabled && block) { throw new IllegalArgumentException( "Cannot set block to true with enabled false"); } this.block = block; updateHeaderValue(); } private void updateHeaderValue() { if (!enabled) { this.headerValue = "0"; return; } this.headerValue = "1"; if (block) { this.headerValue += "; mode=block"; } } @Override public String toString() { return getClass().getName() + " [headerValue=" + headerValue + "]"; } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy