Class CorsFilter
- java.lang.Object
- 
- org.apache.catalina.filters.CorsFilter
 
- 
- All Implemented Interfaces:
- Filter
 
 public class CorsFilter extends Object implements Filter A Filterthat enable client-side cross-origin requests by implementing W3C's CORS (Cross-Origin Resource Sharing) specification for resources. EachHttpServletRequestrequest is inspected as per specification, and appropriate response headers are added toHttpServletResponse.By default, it also sets following request attributes, that help to determine the nature of the request downstream. - cors.isCorsRequest: Flag to determine if the request is a CORS
 request. Set to trueif a CORS request;falseotherwise.
- cors.request.origin: The Origin URL, i.e. the URL of the page from where the request is originated.
- 
 cors.request.type: Type of request. Possible values:
 - SIMPLE: A request which is not preceded by a pre-flight request.
- ACTUAL: A request which is preceded by a pre-flight request.
- PRE_FLIGHT: A pre-flight request.
- NOT_CORS: A normal same-origin request.
- INVALID_CORS: A cross-origin request which is invalid.
 
- cors.request.headers: Request headers sent as 'Access-Control-Request-Headers' header, for pre-flight request.
 doFilter(ServletRequest, ServletResponse, FilterChain)and add appropriate locking so that thedoFilter()method executes with a consistent configuration.- See Also:
- CORS specification
 
- 
- 
Nested Class SummaryNested Classes Modifier and Type Class Description protected static classCorsFilter.CORSRequestTypeEnumerates varies types of CORS requests.
 - 
Field SummaryFields Modifier and Type Field Description static StringDEFAULT_ALLOWED_HTTP_HEADERSBy default, following headers are supported: Origin,Accept,X-Requested-With, Content-Type, Access-Control-Request-Method, and Access-Control-Request-Headers.static StringDEFAULT_ALLOWED_HTTP_METHODSBy default, following methods are supported: GET, POST, HEAD and OPTIONS.static StringDEFAULT_ALLOWED_ORIGINSBy default, no origins are allowed to make requests.static StringDEFAULT_DECORATE_REQUESTBy default, request is decorated with CORS attributes.static StringDEFAULT_EXPOSED_HEADERSBy default, none of the headers are exposed in response.static StringDEFAULT_PREFLIGHT_MAXAGEBy default, time duration to cache pre-flight response is 30 mins.static StringDEFAULT_SUPPORTS_CREDENTIALSBy default, support credentials is disabled.static StringHTTP_REQUEST_ATTRIBUTE_IS_CORS_REQUESTBoolean value, suggesting if the request is a CORS request or not.static StringHTTP_REQUEST_ATTRIBUTE_ORIGINAttribute that contains the origin of the request.static StringHTTP_REQUEST_ATTRIBUTE_PREFIXThe prefix to a CORS request attribute.static StringHTTP_REQUEST_ATTRIBUTE_REQUEST_HEADERSRequest headers sent as 'Access-Control-Request-Headers' header, for pre-flight request.static StringHTTP_REQUEST_ATTRIBUTE_REQUEST_TYPEType of CORS request, of typeCorsFilter.CORSRequestType.static StringPARAM_CORS_ALLOWED_HEADERSKey to retrieve allowed headers fromFilterConfig.static StringPARAM_CORS_ALLOWED_METHODSKey to retrieve allowed methods fromFilterConfig.static StringPARAM_CORS_ALLOWED_ORIGINSKey to retrieve allowed origins fromFilterConfig.static StringPARAM_CORS_EXPOSED_HEADERSKey to retrieve exposed headers fromFilterConfig.static StringPARAM_CORS_PREFLIGHT_MAXAGEKey to retrieve preflight max age fromFilterConfig.static StringPARAM_CORS_REQUEST_DECORATEKey to determine if request should be decorated.static StringPARAM_CORS_SUPPORT_CREDENTIALSKey to retrieve support credentials fromFilterConfig.static StringREQUEST_HEADER_ACCESS_CONTROL_REQUEST_HEADERSThe Access-Control-Request-Headers header indicates which headers will be used in the actual request as part of the preflight request.static StringREQUEST_HEADER_ACCESS_CONTROL_REQUEST_METHODThe Access-Control-Request-Method header indicates which method will be used in the actual request as part of the preflight request.static StringREQUEST_HEADER_ORIGINThe Origin header indicates where the cross-origin request or preflight request originates from.static StringREQUEST_HEADER_VARYDeprecated.Unused.static StringRESPONSE_HEADER_ACCESS_CONTROL_ALLOW_CREDENTIALSThe Access-Control-Allow-Credentials header indicates whether the response to request can be exposed when the omit credentials flag is unset.static StringRESPONSE_HEADER_ACCESS_CONTROL_ALLOW_HEADERSThe Access-Control-Allow-Headers header indicates, as part of the response to a preflight request, which header field names can be used during the actual request.static StringRESPONSE_HEADER_ACCESS_CONTROL_ALLOW_METHODSThe Access-Control-Allow-Methods header indicates, as part of the response to a preflight request, which methods can be used during the actual request.static StringRESPONSE_HEADER_ACCESS_CONTROL_ALLOW_ORIGINThe Access-Control-Allow-Origin header indicates whether a resource can be shared based by returning the value of the Origin request header in the response.static StringRESPONSE_HEADER_ACCESS_CONTROL_EXPOSE_HEADERSThe Access-Control-Expose-Headers header indicates which headers are safe to expose to the API of a CORS API specificationstatic StringRESPONSE_HEADER_ACCESS_CONTROL_MAX_AGEThe Access-Control-Max-Age header indicates how long the results of a preflight request can be cached in a preflight result cache.static Collection<String>SIMPLE_HTTP_REQUEST_CONTENT_TYPE_VALUESCollectionof media type values for the Content-Type header that will be treated as 'simple'.
 - 
Constructor SummaryConstructors Constructor Description CorsFilter()
 - 
Method SummaryAll Methods Static Methods Instance Methods Concrete Methods Deprecated Methods Modifier and Type Method Description protected CorsFilter.CORSRequestTypecheckRequestType(HttpServletRequest request)Determines the request type.protected static voiddecorateCORSProperties(HttpServletRequest request, CorsFilter.CORSRequestType corsRequestType)Decorates theHttpServletRequest, with CORS attributes.voiddestroy()Called by the web container to indicate to a filter that it is being taken out of service.voiddoFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain)ThedoFiltermethod of the Filter is called by the container each time a request/response pair is passed through the chain due to a client request for a resource at the end of the chain.Collection<String>getAllowedHttpHeaders()Returns aSetof headers support by resource.Collection<String>getAllowedHttpMethods()Returns aSetof HTTP methods that are allowed to make requests.Collection<String>getAllowedOrigins()Returns theSetof allowed origins that are allowed to make requests.Collection<String>getExposedHeaders()Obtain the headers to expose.longgetPreflightMaxAge()Returns the preflight response cache time in seconds.protected voidhandlePreflightCORS(HttpServletRequest request, HttpServletResponse response, FilterChain filterChain)Handles CORS pre-flight request.protected voidhandleSimpleCORS(HttpServletRequest request, HttpServletResponse response, FilterChain filterChain)Handles a CORS request of typeCorsFilter.CORSRequestType.SIMPLE.voidinit(FilterConfig filterConfig)Called by the web container to indicate to a filter that it is being placed into service.booleanisAnyOriginAllowed()Determines if any origin is allowed to make CORS request.booleanisDecorateRequest()Should CORS specific attributes be added to the request.booleanisSupportsCredentials()Determines is supports credentials is enabled.protected static booleanisValidOrigin(String origin)Deprecated.This will be removed in Tomcat 10 UseRequestUtil.isValidOrigin(String)protected static Stringjoin(Collection<String> elements, String joinSeparator)Joins elements ofSetinto a string, where each element is separated by the provided separator.
 
- 
- 
- 
Field Detail- 
RESPONSE_HEADER_ACCESS_CONTROL_ALLOW_ORIGINpublic static final String RESPONSE_HEADER_ACCESS_CONTROL_ALLOW_ORIGIN The Access-Control-Allow-Origin header indicates whether a resource can be shared based by returning the value of the Origin request header in the response.- See Also:
- Constant Field Values
 
 - 
RESPONSE_HEADER_ACCESS_CONTROL_ALLOW_CREDENTIALSpublic static final String RESPONSE_HEADER_ACCESS_CONTROL_ALLOW_CREDENTIALS The Access-Control-Allow-Credentials header indicates whether the response to request can be exposed when the omit credentials flag is unset. When part of the response to a preflight request it indicates that the actual request can include user credentials.- See Also:
- Constant Field Values
 
 - 
RESPONSE_HEADER_ACCESS_CONTROL_EXPOSE_HEADERSpublic static final String RESPONSE_HEADER_ACCESS_CONTROL_EXPOSE_HEADERS The Access-Control-Expose-Headers header indicates which headers are safe to expose to the API of a CORS API specification- See Also:
- Constant Field Values
 
 - 
RESPONSE_HEADER_ACCESS_CONTROL_MAX_AGEpublic static final String RESPONSE_HEADER_ACCESS_CONTROL_MAX_AGE The Access-Control-Max-Age header indicates how long the results of a preflight request can be cached in a preflight result cache.- See Also:
- Constant Field Values
 
 - 
RESPONSE_HEADER_ACCESS_CONTROL_ALLOW_METHODSpublic static final String RESPONSE_HEADER_ACCESS_CONTROL_ALLOW_METHODS The Access-Control-Allow-Methods header indicates, as part of the response to a preflight request, which methods can be used during the actual request.- See Also:
- Constant Field Values
 
 - 
RESPONSE_HEADER_ACCESS_CONTROL_ALLOW_HEADERSpublic static final String RESPONSE_HEADER_ACCESS_CONTROL_ALLOW_HEADERS The Access-Control-Allow-Headers header indicates, as part of the response to a preflight request, which header field names can be used during the actual request.- See Also:
- Constant Field Values
 
 - 
REQUEST_HEADER_VARY@Deprecated public static final String REQUEST_HEADER_VARY Deprecated.Unused. Will be removed in Tomcat 10The Vary header indicates allows disabling proxy caching by indicating the the response depends on the origin.- See Also:
- Constant Field Values
 
 - 
REQUEST_HEADER_ORIGINpublic static final String REQUEST_HEADER_ORIGIN The Origin header indicates where the cross-origin request or preflight request originates from.- See Also:
- Constant Field Values
 
 - 
REQUEST_HEADER_ACCESS_CONTROL_REQUEST_METHODpublic static final String REQUEST_HEADER_ACCESS_CONTROL_REQUEST_METHOD The Access-Control-Request-Method header indicates which method will be used in the actual request as part of the preflight request.- See Also:
- Constant Field Values
 
 - 
REQUEST_HEADER_ACCESS_CONTROL_REQUEST_HEADERSpublic static final String REQUEST_HEADER_ACCESS_CONTROL_REQUEST_HEADERS The Access-Control-Request-Headers header indicates which headers will be used in the actual request as part of the preflight request.- See Also:
- Constant Field Values
 
 - 
HTTP_REQUEST_ATTRIBUTE_PREFIXpublic static final String HTTP_REQUEST_ATTRIBUTE_PREFIX The prefix to a CORS request attribute.- See Also:
- Constant Field Values
 
 - 
HTTP_REQUEST_ATTRIBUTE_ORIGINpublic static final String HTTP_REQUEST_ATTRIBUTE_ORIGIN Attribute that contains the origin of the request.- See Also:
- Constant Field Values
 
 - 
HTTP_REQUEST_ATTRIBUTE_IS_CORS_REQUESTpublic static final String HTTP_REQUEST_ATTRIBUTE_IS_CORS_REQUEST Boolean value, suggesting if the request is a CORS request or not.- See Also:
- Constant Field Values
 
 - 
HTTP_REQUEST_ATTRIBUTE_REQUEST_TYPEpublic static final String HTTP_REQUEST_ATTRIBUTE_REQUEST_TYPE Type of CORS request, of typeCorsFilter.CORSRequestType.- See Also:
- Constant Field Values
 
 - 
HTTP_REQUEST_ATTRIBUTE_REQUEST_HEADERSpublic static final String HTTP_REQUEST_ATTRIBUTE_REQUEST_HEADERS Request headers sent as 'Access-Control-Request-Headers' header, for pre-flight request.- See Also:
- Constant Field Values
 
 - 
SIMPLE_HTTP_REQUEST_CONTENT_TYPE_VALUESpublic static final Collection<String> SIMPLE_HTTP_REQUEST_CONTENT_TYPE_VALUES Collectionof media type values for the Content-Type header that will be treated as 'simple'. Note media-type values are compared ignoring parameters and in a case-insensitive manner.- See Also:
- http://www.w3.org/TR/cors/#terminology
 
 - 
DEFAULT_ALLOWED_ORIGINSpublic static final String DEFAULT_ALLOWED_ORIGINS By default, no origins are allowed to make requests.- See Also:
- Constant Field Values
 
 - 
DEFAULT_ALLOWED_HTTP_METHODSpublic static final String DEFAULT_ALLOWED_HTTP_METHODS By default, following methods are supported: GET, POST, HEAD and OPTIONS.- See Also:
- Constant Field Values
 
 - 
DEFAULT_PREFLIGHT_MAXAGEpublic static final String DEFAULT_PREFLIGHT_MAXAGE By default, time duration to cache pre-flight response is 30 mins.- See Also:
- Constant Field Values
 
 - 
DEFAULT_SUPPORTS_CREDENTIALSpublic static final String DEFAULT_SUPPORTS_CREDENTIALS By default, support credentials is disabled.- See Also:
- Constant Field Values
 
 - 
DEFAULT_ALLOWED_HTTP_HEADERSpublic static final String DEFAULT_ALLOWED_HTTP_HEADERS By default, following headers are supported: Origin,Accept,X-Requested-With, Content-Type, Access-Control-Request-Method, and Access-Control-Request-Headers.- See Also:
- Constant Field Values
 
 - 
DEFAULT_EXPOSED_HEADERSpublic static final String DEFAULT_EXPOSED_HEADERS By default, none of the headers are exposed in response.- See Also:
- Constant Field Values
 
 - 
DEFAULT_DECORATE_REQUESTpublic static final String DEFAULT_DECORATE_REQUEST By default, request is decorated with CORS attributes.- See Also:
- Constant Field Values
 
 - 
PARAM_CORS_ALLOWED_ORIGINSpublic static final String PARAM_CORS_ALLOWED_ORIGINS Key to retrieve allowed origins fromFilterConfig.- See Also:
- Constant Field Values
 
 - 
PARAM_CORS_SUPPORT_CREDENTIALSpublic static final String PARAM_CORS_SUPPORT_CREDENTIALS Key to retrieve support credentials fromFilterConfig.- See Also:
- Constant Field Values
 
 - 
PARAM_CORS_EXPOSED_HEADERSpublic static final String PARAM_CORS_EXPOSED_HEADERS Key to retrieve exposed headers fromFilterConfig.- See Also:
- Constant Field Values
 
 - 
PARAM_CORS_ALLOWED_HEADERSpublic static final String PARAM_CORS_ALLOWED_HEADERS Key to retrieve allowed headers fromFilterConfig.- See Also:
- Constant Field Values
 
 - 
PARAM_CORS_ALLOWED_METHODSpublic static final String PARAM_CORS_ALLOWED_METHODS Key to retrieve allowed methods fromFilterConfig.- See Also:
- Constant Field Values
 
 - 
PARAM_CORS_PREFLIGHT_MAXAGEpublic static final String PARAM_CORS_PREFLIGHT_MAXAGE Key to retrieve preflight max age fromFilterConfig.- See Also:
- Constant Field Values
 
 - 
PARAM_CORS_REQUEST_DECORATEpublic static final String PARAM_CORS_REQUEST_DECORATE Key to determine if request should be decorated.- See Also:
- Constant Field Values
 
 
- 
 - 
Method Detail- 
doFilterpublic void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException Description copied from interface:javax.servlet.FilterThedoFiltermethod of the Filter is called by the container each time a request/response pair is passed through the chain due to a client request for a resource at the end of the chain. The FilterChain passed in to this method allows the Filter to pass on the request and response to the next entity in the chain.A typical implementation of this method would follow the following pattern:- 
 1. Examine the request
 2. Optionally wrap the request object with a custom implementation to filter content or headers for input filtering
 3. Optionally wrap the response object with a custom implementation to filter content or headers for output filtering
 4. a) Either invoke the next entity in the chain using the FilterChain object (chain.doFilter()),
 4. b) or not pass on the request/response pair to the next entity in the filter chain to block the request processing
 5. Directly set headers on the response after invocation of the next entity in the filter chain.- Specified by:
- doFilterin interface- Filter
- Parameters:
- servletRequest- The request to process
- servletResponse- The response associated with the request
- filterChain- Provides access to the next filter in the chain for this filter to pass the request and response to for further processing
- Throws:
- IOException- if an I/O error occurs during this filter's processing of the request
- ServletException- if the processing fails for any other reason
 
 - 
initpublic void init(FilterConfig filterConfig) throws ServletException Description copied from interface:javax.servlet.FilterCalled by the web container to indicate to a filter that it is being placed into service. The servlet container calls the init method exactly once after instantiating the filter. The init method must complete successfully before the filter is asked to do any filtering work.The web container cannot place the filter into service if the init method either: - Throws a ServletException
- Does not return within a time period defined by the web container
 - Specified by:
- initin interface- Filter
- Parameters:
- filterConfig- The configuration information associated with the filter instance being initialised
- Throws:
- ServletException- if the initialisation fails
 
 - 
handleSimpleCORSprotected void handleSimpleCORS(HttpServletRequest request, HttpServletResponse response, FilterChain filterChain) throws IOException, ServletException Handles a CORS request of typeCorsFilter.CORSRequestType.SIMPLE.- Parameters:
- request- The- HttpServletRequestobject.
- response- The- HttpServletResponseobject.
- filterChain- The- FilterChainobject.
- Throws:
- IOException- an IO error occurred
- ServletException- Servlet error propagation
- See Also:
- Simple Cross-Origin Request, Actual Request, and Redirects
 
 - 
handlePreflightCORSprotected void handlePreflightCORS(HttpServletRequest request, HttpServletResponse response, FilterChain filterChain) throws IOException, ServletException Handles CORS pre-flight request.- Parameters:
- request- The- HttpServletRequestobject.
- response- The- HttpServletResponseobject.
- filterChain- The- FilterChainobject.
- Throws:
- IOException- an IO error occurred
- ServletException- Servlet error propagation
 
 - 
destroypublic void destroy() Description copied from interface:javax.servlet.FilterCalled by the web container to indicate to a filter that it is being taken out of service. This method is only called once all threads within the filter's doFilter method have exited or after a timeout period has passed. After the web container calls this method, it will not call the doFilter method again on this instance of the filter.
 
 This method gives the filter an opportunity to clean up any resources that are being held (for example, memory, file handles, threads) and make sure that any persistent state is synchronized with the filter's current state in memory.
 - 
decorateCORSPropertiesprotected static void decorateCORSProperties(HttpServletRequest request, CorsFilter.CORSRequestType corsRequestType) Decorates theHttpServletRequest, with CORS attributes.- cors.isCorsRequest: Flag to determine if request is a CORS
 request. Set to trueif CORS request;falseotherwise.
- cors.request.origin: The Origin URL.
- cors.request.type: Type of request. Values:
 simpleorpreflightornot_corsorinvalid_cors
- cors.request.headers: Request headers sent as 'Access-Control-Request-Headers' header, for pre-flight request.
 - Parameters:
- request- The- HttpServletRequestobject.
- corsRequestType- The- CorsFilter.CORSRequestTypeobject.
 
- cors.isCorsRequest: Flag to determine if request is a CORS
 request. Set to 
 - 
joinprotected static String join(Collection<String> elements, String joinSeparator) Joins elements ofSetinto a string, where each element is separated by the provided separator.
 - 
checkRequestTypeprotected CorsFilter.CORSRequestType checkRequestType(HttpServletRequest request) Determines the request type.- Parameters:
- request- The HTTP Servlet request
- Returns:
- the CORS type
 
 - 
isValidOrigin@Deprecated protected static boolean isValidOrigin(String origin) Deprecated.This will be removed in Tomcat 10 UseRequestUtil.isValidOrigin(String)Checks if a given origin is valid or not. Criteria:- If an encoded character is present in origin, it's not valid.
- If origin is "null", it's valid.
- Origin should be a valid URI
 - Parameters:
- origin- The origin URI
- Returns:
- trueif the origin was valid
- See Also:
- RFC952
 
 - 
isAnyOriginAllowedpublic boolean isAnyOriginAllowed() Determines if any origin is allowed to make CORS request.- Returns:
- trueif it's enabled; false otherwise.
 
 - 
getExposedHeaderspublic Collection<String> getExposedHeaders() Obtain the headers to expose.- Returns:
- the headers that should be exposed by browser.
 
 - 
isSupportsCredentialspublic boolean isSupportsCredentials() Determines is supports credentials is enabled.- Returns:
- trueif the use of credentials is supported otherwise- false
 
 - 
getPreflightMaxAgepublic long getPreflightMaxAge() Returns the preflight response cache time in seconds.- Returns:
- Time to cache in seconds.
 
 - 
getAllowedOriginspublic Collection<String> getAllowedOrigins() Returns theSetof allowed origins that are allowed to make requests.- Returns:
- Set
 
 - 
getAllowedHttpMethodspublic Collection<String> getAllowedHttpMethods() Returns aSetof HTTP methods that are allowed to make requests.- Returns:
- Set
 
 - 
getAllowedHttpHeaderspublic Collection<String> getAllowedHttpHeaders() Returns aSetof headers support by resource.- Returns:
- Set
 
 - 
isDecorateRequestpublic boolean isDecorateRequest() Should CORS specific attributes be added to the request.- Returns:
- trueif the request should be decorated, otherwise- false
 
 
- 
 
-