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

📄 abstractauthenticationmanager.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;/** * An abstract implementation of the {@link AuthenticationManager}. * * @author Wesley Hall * @version $Id: AbstractAuthenticationManager.java 2654 2008-02-18 20:44:09Z luke_t $ */public abstract class AbstractAuthenticationManager implements AuthenticationManager {    //~ Instance fields ================================================================================================    private boolean clearExtraInformation = true;    //~ Methods ========================================================================================================    /**     * <p>An implementation of the <code>authenticate</code> method that calls the abstract method     * <code>doAuthenticatation</code> to do its work.</p>     *  <p>If doAuthenticate throws an <code>AuthenticationException</code> then the exception is populated     * with the failed <code>Authentication</code> object that failed.</p>     *     * @param authRequest the authentication request object     *     * @return a fully authenticated object including credentials     *     * @throws AuthenticationException if authentication fails     */    public final Authentication authenticate(Authentication authRequest)        throws AuthenticationException {        try {            return doAuthentication(authRequest);        } catch (AuthenticationException e) {            e.setAuthentication(authRequest);            if (clearExtraInformation) {                e.clearExtraInformation();            }            throw e;        }    }    /**     * <p>Concrete implementations of this class override this method to provide the authentication service.</p>     *  <p>The contract for this method is documented in the {@link     * AuthenticationManager#authenticate(Authentication)}.</p>     *     * @param authentication the authentication request object     *     * @return a fully authenticated object including credentials     *     * @throws AuthenticationException if authentication fails     */    protected abstract Authentication doAuthentication(Authentication authentication)        throws AuthenticationException;    /**     * If set to true, the <tt>extraInformation</tt> set on an <tt>AuthenticationException</tt> will be cleared     * before rethrowing it. This is useful for use with remoting protocols where the information shouldn't     * be serialized to the client. Defaults to 'false'.     *     * @see AuthenticationException#getExtraInformation()     */    public void setClearExtraInformation(boolean clearExtraInformation) {        this.clearExtraInformation = clearExtraInformation;    }}

⌨️ 快捷键说明

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