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

📄 abstractcreateaction.java.svn-base

📁 MVC开源框架
💻 SVN-BASE
字号:
/* * $Id$ * * Licensed to the Apache Software Foundation (ASF) under one * or more contributor license agreements.  See the NOTICE file * distributed with this work for additional information * regarding copyright ownership.  The ASF licenses this file * to you 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.apache.struts.chain.commands;import org.apache.commons.logging.Log;import org.apache.commons.logging.LogFactory;import org.apache.struts.action.Action;import org.apache.struts.chain.contexts.ActionContext;import org.apache.struts.config.ActionConfig;/** * <p> Create (if necessary) and cache an <code>Action</code> for this * request. </p> * * @version $Rev$ $Date: 2005-11-12 13:01:44 -0500 (Sat, 12 Nov 2005) *          $ */public abstract class AbstractCreateAction extends ActionCommandBase {    // ------------------------------------------------------ Instance Variables    /**     * Provide a Commons logging instance for this class.     */    private static final Log LOG =        LogFactory.getLog(AbstractCreateAction.class);    // ---------------------------------------------------------- Public Methods    /**     * <p>Create (if necessary) and cache an <code>Action</code> for this     * request.</p>     *     * @param actionCtx The <code>Context</code> for the current request     * @return <code>false</code> so that processing continues     * @throws Exception if there are any problems instantiating the Action     *                   class.     */    public boolean execute(ActionContext actionCtx)        throws Exception {        // Skip processing if the current request is not valid        Boolean valid = actionCtx.getFormValid();        if ((valid == null) || !valid.booleanValue()) {            LOG.trace("Invalid form; not going to execute.");            return (false);        }        // Check to see if an action has already been created        if (actionCtx.getAction() != null) {            LOG.trace("already have an action [" + actionCtx.getAction() + "]");            return (false);        }        // Look up the class name for the desired Action        ActionConfig actionConfig = actionCtx.getActionConfig();        String type = actionConfig.getType();        if (type == null) {            String command = actionConfig.getCommand();            if ((command == null) && (actionConfig.getForward() == null)                && (actionConfig.getInclude() == null)) {                LOG.error("no type or command for " + actionConfig.getPath());            } else {                LOG.trace("no type for " + actionConfig.getPath());            }            return (false);        }        // Create (if necessary) and cache an Action instance        Action action = getAction(actionCtx, type, actionConfig);        if (LOG.isTraceEnabled()) {            LOG.trace("setting action to " + action);        }        actionCtx.setAction(action);        return (false);    }    // ------------------------------------------------------- Protected Methods    /**     * <p> Create and return the appropriate <code>Action</code> class for the     * given <code>type</code> and <code>actionConfig</code>. </p> <p> NOTE:     * The dependence on ActionServlet suggests that this should be broken up     * along the lines of the other Abstract/concrete pairs in the     * org.apache.struts.chain.commands package. </p>     *     * @param context      The <code>Context</code> for this request     * @param type         Name of class to instantiate     * @param actionConfig The {@link ActionConfig} for this request     * @return Instantiated Action class     * @throws Exception if there are any problems instantiating the Action     *                   class.     */    protected abstract Action getAction(ActionContext context, String type,        ActionConfig actionConfig)        throws Exception;}

⌨️ 快捷键说明

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