/* * Copyright 2002-2018 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 * * https://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. */
/** * Servlet Filter that allows one to specify a character encoding for requests. * This is useful because current browsers typically do not set a character * encoding even if specified in the HTML page or form. * * <p>This filter can either apply its encoding if the request does not already * specify an encoding, or enforce this filter's encoding in any case * ("forceEncoding"="true"). In the latter case, the encoding will also be * applied as default response encoding (although this will usually be overridden * by a full content type set in the view). * * @author Juergen Hoeller * @since 15.03.2004 * @see #setEncoding * @see #setForceEncoding * @see jakarta.servlet.http.HttpServletRequest#setCharacterEncoding * @see jakarta.servlet.http.HttpServletResponse#setCharacterEncoding */ publicclassCharacterEncodingFilterextendsOncePerRequestFilter {
@Nullable private String encoding;
privatebooleanforceRequestEncoding=false;
privatebooleanforceResponseEncoding=false;
/** * Create a default {@code CharacterEncodingFilter}, * with the encoding to be set via {@link #setEncoding}. * @see #setEncoding */ publicCharacterEncodingFilter() { }
/** * Create a {@code CharacterEncodingFilter} for the given encoding. * @param encoding the encoding to apply * @since 4.2.3 * @see #setEncoding */ publicCharacterEncodingFilter(String encoding) { this(encoding, false); }
/** * Create a {@code CharacterEncodingFilter} for the given encoding. * @param encoding the encoding to apply * @param forceEncoding whether the specified encoding is supposed to * override existing request and response encodings * @since 4.2.3 * @see #setEncoding * @see #setForceEncoding */ publicCharacterEncodingFilter(String encoding, boolean forceEncoding) { this(encoding, forceEncoding, forceEncoding); }
/** * Create a {@code CharacterEncodingFilter} for the given encoding. * @param encoding the encoding to apply * @param forceRequestEncoding whether the specified encoding is supposed to * override existing request encodings * @param forceResponseEncoding whether the specified encoding is supposed to * override existing response encodings * @since 4.3 * @see #setEncoding * @see #setForceRequestEncoding(boolean) * @see #setForceResponseEncoding(boolean) */ publicCharacterEncodingFilter(String encoding, boolean forceRequestEncoding, boolean forceResponseEncoding) { Assert.hasLength(encoding, "Encoding must not be empty"); this.encoding = encoding; this.forceRequestEncoding = forceRequestEncoding; this.forceResponseEncoding = forceResponseEncoding; }
/** * Set the encoding to use for requests. This encoding will be passed into a * {@link jakarta.servlet.http.HttpServletRequest#setCharacterEncoding} call. * <p>Whether this encoding will override existing request encodings * (and whether it will be applied as default response encoding as well) * depends on the {@link #setForceEncoding "forceEncoding"} flag. */ publicvoidsetEncoding(@Nullable String encoding) { this.encoding = encoding; }
/** * Return the configured encoding for requests and/or responses. * @since 4.3 */ @Nullable public String getEncoding() { returnthis.encoding; }
/** * Set whether the configured {@link #setEncoding encoding} of this filter * is supposed to override existing request and response encodings. * <p>Default is "false", i.e. do not modify the encoding if * {@link jakarta.servlet.http.HttpServletRequest#getCharacterEncoding()} * returns a non-null value. Switch this to "true" to enforce the specified * encoding in any case, applying it as default response encoding as well. * <p>This is the equivalent to setting both {@link #setForceRequestEncoding(boolean)} * and {@link #setForceResponseEncoding(boolean)}. * @see #setForceRequestEncoding(boolean) * @see #setForceResponseEncoding(boolean) */ publicvoidsetForceEncoding(boolean forceEncoding) { this.forceRequestEncoding = forceEncoding; this.forceResponseEncoding = forceEncoding; }
/** * Set whether the configured {@link #setEncoding encoding} of this filter * is supposed to override existing request encodings. * <p>Default is "false", i.e. do not modify the encoding if * {@link jakarta.servlet.http.HttpServletRequest#getCharacterEncoding()} * returns a non-null value. Switch this to "true" to enforce the specified * encoding in any case. * @since 4.3 */ publicvoidsetForceRequestEncoding(boolean forceRequestEncoding) { this.forceRequestEncoding = forceRequestEncoding; }
/** * Return whether the encoding should be forced on requests. * @since 4.3 */ publicbooleanisForceRequestEncoding() { returnthis.forceRequestEncoding; }
/** * Set whether the configured {@link #setEncoding encoding} of this filter * is supposed to override existing response encodings. * <p>Default is "false", i.e. do not modify the encoding. * Switch this to "true" to enforce the specified encoding * for responses in any case. * @since 4.3 */ publicvoidsetForceResponseEncoding(boolean forceResponseEncoding) { this.forceResponseEncoding = forceResponseEncoding; }
/** * Return whether the encoding should be forced on responses. * @since 4.3 */ publicbooleanisForceResponseEncoding() { returnthis.forceResponseEncoding; }