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

org.frameworkset.web.servlet.support.JspAwareRequestContext 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

The 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.support;

import java.util.Locale;
import java.util.Map;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.jsp.PageContext;
import javax.servlet.jsp.jstl.core.Config;

/**
 * 

Title: JspAwareRequestContext.java

*

Description:

*

bboss workgroup

*

Copyright (c) 2008

* @Date 2010-9-28 * @author biaoping.yin * @version 1.0 */ public class JspAwareRequestContext extends RequestContext { private PageContext pageContext; /** * Create a new JspAwareRequestContext for the given page context, * using the request attributes for Errors retrieval. * @param pageContext current JSP page context */ public JspAwareRequestContext(PageContext pageContext) { initContext(pageContext, null); } /** * Create a new JspAwareRequestContext for the given page context, * using the given model attributes for Errors retrieval. * @param pageContext current JSP page context * @param model the model attributes for the current view * (can be null, using the request attributes for Errors retrieval) */ public JspAwareRequestContext(PageContext pageContext, Map model) { initContext(pageContext, model); } /** * Initialize this context with the given page context, * using the given model attributes for Errors retrieval. * @param pageContext current JSP page context * @param model the model attributes for the current view * (can be null, using the request attributes for Errors retrieval) */ protected void initContext(PageContext pageContext, Map model) { if (!(pageContext.getRequest() instanceof HttpServletRequest)) { throw new IllegalArgumentException("RequestContext only supports HTTP requests"); } this.pageContext = pageContext; initContext((HttpServletRequest) pageContext.getRequest(), pageContext.getServletContext(), model); } /** * Return the underlying PageContext. * Only intended for cooperating classes in this package. */ protected final PageContext getPageContext() { return this.pageContext; } /** * This implementation checks for a JSTL locale attribute * in page, request, session or application scope; if not found, * returns the HttpServletRequest.getLocale(). */ protected Locale getFallbackLocale() { // if (jstlPresent) { // Locale locale = JstlPageLocaleResolver.getJstlLocale(getPageContext()); // if (locale != null) { // return locale; // } // } return getRequest().getLocale(); } /** * Inner class that isolates the JSTL dependency. * Just called to resolve the fallback locale if the JSTL API is present. */ private static class JstlPageLocaleResolver { public static Locale getJstlLocale(PageContext pageContext) { Object localeObject = Config.find(pageContext, Config.FMT_LOCALE); return (localeObject instanceof Locale ? (Locale) localeObject : null); } } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy