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

org.frameworkset.web.servlet.context.AbstractRequestAttributes Maven / Gradle / Ivy

Go to download

bboss is a j2ee framework include aop/ioc,mvc,persistent,taglib,rpc,event ,bean-xml serializable and so on.http://www.bbossgroups.com

There is a newer version: 6.2.7
Show newest version
/*
 *  Copyright 2008 biaoping.yin
 *
 *  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.frameworkset.web.servlet.context;

import java.util.Iterator;
import java.util.LinkedHashMap;
import java.util.Map;

import org.frameworkset.util.Assert;

/**
 * 

Title: AbstractRequestAttributes.java

*

Description:

*

bboss workgroup

*

Copyright (c) 2008

* @Date 2010-10-1 * @author biaoping.yin * @version 1.0 */ public abstract class AbstractRequestAttributes implements RequestAttributes,RequestContainer { /** Map from attribute name String to destruction callback Runnable */ protected final Map requestDestructionCallbacks = new LinkedHashMap(8); private volatile boolean requestActive = true; /** * Signal that the request has been completed. *

Executes all request destruction callbacks and updates the * session attributes that have been accessed during request processing. */ public void requestCompleted() { executeRequestDestructionCallbacks(); updateAccessedSessionAttributes(); this.requestActive = false; } /** * Determine whether the original request is still active. * @see #requestCompleted() */ protected final boolean isRequestActive() { return this.requestActive; } /** * Register the given callback as to be executed after request completion. * @param name the name of the attribute to register the callback for * @param callback the callback to be executed for destruction */ protected final void registerRequestDestructionCallback(String name, Runnable callback) { Assert.notNull(name, "Name must not be null"); Assert.notNull(callback, "Callback must not be null"); synchronized (this.requestDestructionCallbacks) { this.requestDestructionCallbacks.put(name, callback); } } /** * Remove the request destruction callback for the specified attribute, if any. * @param name the name of the attribute to remove the callback for */ protected final void removeRequestDestructionCallback(String name) { Assert.notNull(name, "Name must not be null"); synchronized (this.requestDestructionCallbacks) { this.requestDestructionCallbacks.remove(name); } } /** * Execute all callbacks that have been registered for execution * after request completion. */ private void executeRequestDestructionCallbacks() { synchronized (this.requestDestructionCallbacks) { for (Runnable runnable : this.requestDestructionCallbacks.values()) { runnable.run(); } this.requestDestructionCallbacks.clear(); } } /** * Update all session attributes that have been accessed during request processing, * to expose their potentially updated state to the underlying session manager. */ protected abstract void updateAccessedSessionAttributes(); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy