`

Spring3MVC 学习笔记 四

 
阅读更多

BaseCommandController
命令控制器通用基类,提供了以下功能支持:
1、数据绑定:请求参数绑定到一个command object(命令对象,非GoF里的命令设计模式),这里的命令对象是指绑
定请求参数的任何POJO 对象;
commandClass:表示命令对象实现类,如UserModel;
commandName:表示放入请求的命令对象名字(默认command),request.setAttribute(commandName, commandObject);
2、验证功能:提供Validator 注册功能,注册的验证器会验证命令对象属性数据是否合法;
validators:通过该属性注入验证器,验证器用来验证命令对象属性是否合法;
该抽象类没有没有提供流程功能,只是提供了一些公共的功能,实际使用时需要使用它的子类。



AbstractCommandController
命令控制器之一,可以实现该控制器来创建命令控制器,该控制器能把自动封装请求参数到一个命令对象,而且提供
了验证功能。
1、创建命令类(就是普通的JavaBean类/POJO)

package cn.javass.chapter4.model;
public class UserModel {
    private String username;
    private String password;
    //省略setter/getter
}

 2、实现控制器

import org.springframework.validation.BindException;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.web.servlet.mvc.AbstractCommandController;

import com.auto.oper.config.domain.UserModel;

//提交的 参数自动绑定到 命令对象 实现类上
//http://localhost:8080/AutoOper/abstractCommand?username=admin&password=admin
//这里的参数 username 和 password 值自动绑定到 UserModel上,传到前台进行展示
public class MyAbstractCommandController extends AbstractCommandController{

  public MyAbstractCommandController(){
   //设置命令对象实现类 也可以进行依赖注入,这里使用的是构造函数
   setCommandClass(UserModel.class);
 }
 
 @Override
 protected ModelAndView handle(HttpServletRequest request,
   HttpServletResponse response, Object command, BindException errors)
   throws Exception {
  UserModel user = (UserModel)command;
  ModelAndView mv = new ModelAndView();
  mv.setViewName("abstractCommand");
  mv.addObject("user",user);
  return mv;
 }

}

 3. 配置

<!— 在chapter4-servlet.xml配置处理器-->
<bean name="/abstractCommand"
class="cn.javass.chapter4.web.controller.MyAbstractCommandController">
      <!-- 也可以通过依赖注入注入命令实现类-->
      <!-- property name="commandClass" value="cn.javass.chapter4.model.UserModel"/-->
</bean>

 

<!— WEB-INF/jsp/abstractCommand.jsp视图下的主要内容-->
${user.username }-${user.password }

当我们在浏览器中输入“http://localhost:9080/springmvc-chapter4/abstractCommand?username=123&password=123”,会自
动将请求参数username和password绑定到命令对象;绑定时按照JavaBean命名规范绑定;


AbstractFormController

用于支持带步骤的表单提交的命令控制器基类,使用该控制器可以完成:
1、定义表单处理(表单的渲染),并从控制器获取命令对象构建表单;
2、提交表单处理,当用户提交表单内容后,AbstractFormController 可以将用户请求的数据绑定到命令对象,并可以验
证表单内容、对命令对象进行处理。

@Override
protected ModelAndView handleRequestInternal(HttpServletRequest request, HttpServletResponse response)
throws Exception {
//1、是否是表单提交? 该方法实现为("POST".equals(request.getMethod())),即POST表示表单提交
if (isFormSubmission(request)) {
try {
Object command = getCommand(request);
ServletRequestDataBinder binder = bindAndValidate(request, command);
BindException errors = new BindException(binder.getBindingResult());
//表单提交应该放到该方法实现
return processFormSubmission(request, response, command, errors);
}
catch (HttpSessionRequiredException ex) {
//省略部分代码
return handleInvalidSubmit(request, response);
}
}
else {
//2、表示是表单展示,该方法又转调showForm方法,因此我们需要覆盖showForm来完成表单展示
return showNewForm(request, response);
}
}

bindOnNewForm:是否在进行表单展示时绑定请求参数到表单对象,默认false,不绑定;
sessionForm:session表单模式,如果开启(true)则会将表单对象放置到session中,从而可以跨越多次请求保证
数据不丢失(多步骤表单常使用该方式,详解AbstractWizardFormController),默认false;
Object formBackingObject(HttpServletRequest request) :提供给表单展示时使用的表单对象(form object表单要
展示的默认数据),默认通过commandName暴露到请求给展示表单;
Map referenceData(HttpServletRequest request, Object command, Errors errors):展示表单时需要的一些引用数
据(比如用户注册,可能需要选择工作地点,这些数据可以通过该方法提供),

protected Map referenceData(HttpServletRequest request) throws Exception {
Map model = new HashMap();
model.put("cityList", cityList);
return model;
}
这样就可以在表单展示页面获取cityList数据

SimpleFormController 继承该类AbstractFormController,而且提供了更简单的表单流程控制。
如下: 注册 处理器
(1、控制器
 

package cn.javass.chapter4.web.controller;
 //省略import
 public class RegisterSimpleFormController extends SimpleFormController {
     public RegisterSimpleFormController() {
          setCommandClass(UserModel.class); //设置命令对象实现类
       setCommandName("user");//设置命令对象的名字
  }
  //form object 表单对象,提供展示表单时的表单数据(使用commandName放入请求)
  protected Object formBackingObject(HttpServletRequest request) throws Exception {
        UserModel user = new UserModel();
        user.setUsername("请输入用户名");
        return user;
  }
  //提供展示表单时需要的一些其他数据
  protected Map referenceData(HttpServletRequest request) throws Exception {
        Map map = new HashMap();
        map.put("cityList", Arrays.asList("山东", "北京", "上海"));
        return map;
  }
  protected void doSubmitAction(Object command) throws Exception {
        UserModel user = (UserModel) command;
        //TODO 调用业务对象处理
        System.out.println(user);
  } 
 }
 

 setCommandClasssetCommandName:分别设置了命令对象的实现类和名字;
formBackingObjectreferenceData:提供了表单展示需要的视图;
doSubmitAction:用于执行表单提交动作,由onSubmit方法调用,如果不需要请求/响应对象或进行数据验证,可以直
接使用doSubmitAction方法进行功能处理。


(2、spring配置(chapter4-servlet.xml)

<bean name="/simpleForm"
class="cn.javass.chapter4.web.controller.RegisterSimpleFormController">
<property name="formView" value="register"/>
<property name="successView" value="redirect:/success"/>
</bean>
<bean name="/success" class="cn.javass.chapter4.web.controller.SuccessController"/>

 formView:表示展示表单时显示的页面;
successView:表示处理成功时显示的页面;“redirect:/success”表示成功处理后重定向到/success 控制器;防
止表单重复提交;
“/success” bean的作用是显示成功页面,跳转到统一的成功界面。

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.springframework.web.servlet.ModelAndView;
import org.springframework.web.servlet.mvc.Controller;

public class SuccessController implements Controller{

	public ModelAndView handleRequest(HttpServletRequest request,
			HttpServletResponse response) throws Exception {
		// TODO Auto-generated method stub
		ModelAndView mv = new ModelAndView();
		mv.setViewName("success");
		return mv;
	}

}

 (3、视图页面

<!-- register.jsp 注册展示页面 就是<property name="formView" value="register"/> 配置的form页面-->
<form method="post">
    username:<input type="text" name="username" value="${user.username}"><br/>
    password:<input type="password" name="username"><br/>
   city:<select>
             <c:forEach items="${cityList }" var="city">
               <option>${city}</option>
             </c:forEach>
       </select><br/>
   <input type="submit" value="注册"/>
</form>





CancellableFormController
一个可取消的表单控制器,继承SimpleFormController,额外提供取消表单功能。
1、表单展示:和SimpleFormController 一样;
2、表单取消:和SimpleFormController 一样;
3、表单成功提交:取消功能处理方法为:onCancel(Object command),而且默认返回cancelView 属性指定的逻辑视图名。
那如何判断是取消呢?如果请求中有参数名为“_cancel”的参数,则表示表单取消。也可以通过cancelParamKey
来修改参数名(如“_cancel.x”等)。
(1、控制器
复制RegisterSimpleFormController 一份命名为CanCancelRegisterSimpleFormController,添加取消功能处理方法实现:

@Override
protected ModelAndView onCancel(Object command) throws Exception {
UserModel user = (UserModel) command;
//TODO 调用业务对象处理
System.out.println(user);
return super.onCancel(command);
}

 
onCancel:在该功能方法内实现取消逻辑,父类的onCancel方法默认返回cancelView属性指定的逻辑视图名。

(2、spring配置(chapter4-servlet.xml)

<bean name="/canCancelForm"
class="cn.javass.chapter4.web.controller.CanCancelRegisterSimpleFormController">
<property name="formView" value="register"/>
<property name="successView" value="redirect:/success"/>
<property name="cancelView" value="redirect:/cancel"/>
</bean>
<bean name="/cancel" class="cn.javass.chapter4.web.controller.CancelController"/>

 

cancelParamKey:用于判断是否是取消的请求参数名,默认是_cancel,即如果请求参数数据中含有名字_cancel则表
示是取消,将调用onCancel功能处理方法;
cancelView:表示取消时时显示的页面;“redirect:/cancel”表示成功处理后重定向到/cancel控制器;防止表单
重复提交;
“/cancel” bean的作用是显示取消页面,此处就不列举

(3、视图页面(修改register.jsp)
<input type="submit" name="_cancel" value="取消"/>

该提交按钮的作用是取消,因为name="_cancel",即请求后会有一个名字为_cancel 的参数,因此会执行onCancel
功能处理方法。

(4、测试:
在浏览器输入“http://localhost:9080/springmvc-chapter4/canCancelForm”,则首先到展示视图页面,点击“取消按钮”将
重定向到“http://localhost:9080/springmvc-chapter4/cancel”,说明取消成功了。


AbstractWizardFormController
向导控制器类提供了多步骤(向导)表单的支持(如完善个人资料时分步骤填写基本信息、工作信息、学校信息等)
假设现在做一个完善个人信息的功能,分三个页面展示:
1、页面1 完善基本信息;
2、页面2 完善学校信息;
3、页面3 完善工作信息。
这里我们要注意的是当用户跳转到页面2 时页面1 的信息是需要保存起来的,还记得AbstractFormController 中的
sessionForm吗? 如果为true则表单数据存放到session中,哈哈,AbstractWizardFormController 就是使用了这个特性


向导中的页码从0开始;
PARAM_TARGET = "_target":
用于选择向导中的要使用的页面参数名前缀,如“_target0”则选择第0 个页面显示,即图中的“wizard/baseInfo”,以
此类推,如“_target1”将选择第1 页面,要得到的页码为去除前缀“_target”后的数字即是;
PARAM_FINISH = "_finish":
如果请求参数中有名为“_finish”的参数,表示向导成功结束,将会调用processFinish方法进行完成时的功能处理;
PARAM_CANCEL = "_cancel":
如果请求参数中有名为“_cancel”的参数,表示向导被取消,将会调用processCancel方法进行取消时的功能处理;
向导中的命令对象:
向导中的每一个步骤都会把相关的参数绑定到命令对象,该表单对象默认放置在session中,从而可以跨越多次请求得
到该命令对象。

ParameterizableViewController
参数化视图控制器,不进行功能处理(即静态视图),根据参数的逻辑视图名直接选择需要展示的视图。

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics