📄 abstractpopulateactionform.java.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.struts.Globals;import org.apache.struts.action.ActionForm;import org.apache.struts.chain.contexts.ActionContext;import org.apache.struts.config.ActionConfig;import java.util.Map;/** * <p>Populate the form bean (if any) for this request.</p> * * @version $Rev$ $Date: 2005-11-12 13:01:44 -0500 (Sat, 12 Nov 2005) * $ */public abstract class AbstractPopulateActionForm extends ActionCommandBase { // ---------------------------------------------------------- Public Methods /** * <p>Populate the form bean (if any) for this request.</p> * * @param actionCtx The <code>Context</code> for the current request * @return <code>false</code> so that processing continues * @throws Exception On an unexpected error */ public boolean execute(ActionContext actionCtx) throws Exception { ActionConfig actionConfig = actionCtx.getActionConfig(); ActionForm actionForm = actionCtx.getActionForm(); // First determine if the request was cancelled handleCancel(actionCtx, actionConfig, actionForm); // Is there a form bean for this request? if (actionForm == null) { return (false); } // If request is cancelled, form manipulation is prevented if (actionCtx.getCancelled().booleanValue()) { return (false); } // Reset and repopulate the form bean property values reset(actionCtx, actionConfig, actionForm); populate(actionCtx, actionConfig, actionForm); return (false); } // ------------------------------------------------------- Protected Methods /** * <p>Call the <code>reset()</code> method on the specified form * bean.</p> * * @param context The context for this request * @param actionConfig The actionConfig for this request * @param actionForm The form bean for this request */ protected abstract void reset(ActionContext context, ActionConfig actionConfig, ActionForm actionForm); /** * <p> Populate the given <code>ActionForm</code> with request parameter * values, taking into account any prefix/suffix values configured on the * given <code>ActionConfig</code>. </p> * * @param context The ActionContext we are processing * @param actionConfig The ActionConfig we are processing * @param actionForm The ActionForm we are processing * @throws Exception On an unexpected error */ protected abstract void populate(ActionContext context, ActionConfig actionConfig, ActionForm actionForm) throws Exception; // original implementation casting context to WebContext is not safe // when the input value is an ActionContext. /** * <p>For a given request parameter name, trim off any prefix and/or * suffix which are defined in <code>actionConfig</code> and return what * remains. If either prefix or suffix is defined, then return null for * <code>name</code> values which do not begin or end accordingly.</p> * * @param actionConfig The ActionConfig we are processing * @param name The request parameter name to proceess * @return The request parameter name trimmed of any suffix or prefix */ protected String trimParameterName(ActionConfig actionConfig, String name) { String stripped = name; String prefix = actionConfig.getPrefix(); String suffix = actionConfig.getSuffix(); if (prefix != null) { if (!stripped.startsWith(prefix)) { return null; } stripped = stripped.substring(prefix.length()); } if (suffix != null) { if (!stripped.endsWith(suffix)) { return null; } stripped = stripped.substring(0, stripped.length() - suffix.length()); } return stripped; } /** * <p>Take into account whether the request includes any defined value for * the global "cancel" parameter.</p> <p> An issue was raised (but I don't * think a Bugzilla ticket created) about the security implications of * using a well-known cancel property which skips form validation, as you * may not write your actions to deal with the cancellation case. </p> * * @param context The ActionContext we are processing * @param actionConfig The ActionConfig we are processing * @param actionForm The ActionForm we are processing * @throws Exception On an unexpected error * @see Globals.CANCEL_PROPERTY * @see Globals.CANCEL_PROPERTY_X */ protected void handleCancel(ActionContext context, ActionConfig actionConfig, ActionForm actionForm) throws Exception { Map paramValues = context.getParameterMap(); // Set the cancellation attribute if appropriate if ((paramValues.get(Globals.CANCEL_PROPERTY) != null) || (paramValues.get(Globals.CANCEL_PROPERTY_X) != null)) { context.setCancelled(Boolean.TRUE); } else { context.setCancelled(Boolean.FALSE); } }}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -