⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 filtersecurityinterceptor.java

📁 acegi构造安全的java系统
💻 JAVA
字号:
/* Copyright 2004, 2005, 2006 Acegi Technology Pty Limited * * 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.acegisecurity.intercept.web;import org.acegisecurity.intercept.AbstractSecurityInterceptor;import org.acegisecurity.intercept.InterceptorStatusToken;import org.acegisecurity.intercept.ObjectDefinitionSource;import java.io.IOException;import javax.servlet.Filter;import javax.servlet.FilterChain;import javax.servlet.FilterConfig;import javax.servlet.ServletException;import javax.servlet.ServletRequest;import javax.servlet.ServletResponse;/** * Performs security handling of HTTP resources via a filter implementation.<p>The * <code>ObjectDefinitionSource</code> required by this security interceptor is of type {@link * FilterInvocationDefinitionSource}.</p> *  <P>Refer to {@link AbstractSecurityInterceptor} for details on the workflow.</p> * * @author Ben Alex * @version $Id: FilterSecurityInterceptor.java 1496 2006-05-23 13:38:33Z benalex $ */public class FilterSecurityInterceptor extends AbstractSecurityInterceptor implements Filter {    //~ Static fields/initializers =====================================================================================    private static final String FILTER_APPLIED = "__acegi_filterSecurityInterceptor_filterApplied";    //~ Instance fields ================================================================================================    private FilterInvocationDefinitionSource objectDefinitionSource;    private boolean observeOncePerRequest = true;    //~ Methods ========================================================================================================    /**     * Not used (we rely on IoC container lifecycle services instead)     */    public void destroy() {}    /**     * Method that is actually called by the filter chain. Simply delegates to the {@link     * #invoke(FilterInvocation)} method.     *     * @param request the servlet request     * @param response the servlet response     * @param chain the filter chain     *     * @throws IOException if the filter chain fails     * @throws ServletException if the filter chain fails     */    public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)        throws IOException, ServletException {        FilterInvocation fi = new FilterInvocation(request, response, chain);        invoke(fi);    }    public FilterInvocationDefinitionSource getObjectDefinitionSource() {        return this.objectDefinitionSource;    }    public Class getSecureObjectClass() {        return FilterInvocation.class;    }    /**     * Not used (we rely on IoC container lifecycle services instead)     *     * @param arg0 ignored     *     * @throws ServletException never thrown     */    public void init(FilterConfig arg0) throws ServletException {}    public void invoke(FilterInvocation fi) throws IOException, ServletException {        if ((fi.getRequest() != null) && (fi.getRequest().getAttribute(FILTER_APPLIED) != null)            && observeOncePerRequest) {            // filter already applied to this request and user wants us to observce            // once-per-request handling, so don't re-do security checking            fi.getChain().doFilter(fi.getRequest(), fi.getResponse());        } else {            // first time this request being called, so perform security checking            if (fi.getRequest() != null) {                fi.getRequest().setAttribute(FILTER_APPLIED, Boolean.TRUE);            }            InterceptorStatusToken token = super.beforeInvocation(fi);            try {                fi.getChain().doFilter(fi.getRequest(), fi.getResponse());            } finally {                super.afterInvocation(token, null);            }        }    }    /**     * Indicates whether once-per-request handling will be observed. By default this is <code>true</code>,     * meaning the <code>FilterSecurityInterceptor</code> will only execute once-per-request. Sometimes users may wish     * it to execute more than once per request, such as when JSP forwards are being used and filter security is     * desired on each included fragment of the HTTP request.     *     * @return <code>true</code> (the default) if once-per-request is honoured, otherwise <code>false</code> if     *         <code>FilterSecurityInterceptor</code> will enforce authorizations for each and every fragment of the     *         HTTP request.     */    public boolean isObserveOncePerRequest() {        return observeOncePerRequest;    }    public ObjectDefinitionSource obtainObjectDefinitionSource() {        return this.objectDefinitionSource;    }    public void setObjectDefinitionSource(FilterInvocationDefinitionSource newSource) {        this.objectDefinitionSource = newSource;    }    public void setObserveOncePerRequest(boolean observeOncePerRequest) {        this.observeOncePerRequest = observeOncePerRequest;    }}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -