• 欢迎访问web前端中文站,JavaScript,CSS3,HTML5,web前端demo
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏web前端中文站吧

详解Spring MVC中的AbstractFormController

JAVA web前端中文站 2年前 (2017-07-20) 832次浏览 已收录 0个评论

AbstractFormController 用于支持带步骤的表单提交的命令控制器基类,使用该控制器可以完成:

更多精彩内容请看 web 前端中文站
http://www.lisa33xiaoq.net 可按 Ctrl + D 进行收藏

  1. 定义表单处理(表单的渲染),并从控制器获取命令对象构建表单;
  2. 提交表单处理,当用户提交表单内容后,AbstractFormController 可以将用户请求的数据绑定到命令对象,并可以验证表单内容、对命令对象进行处理。

集成 AbstractFormController 类,需要实现其中的 handleRequestInternal 方法:

 @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 数据。

【注:本文源自网络文章资源,由站长整理发布】


web 前端中文站 , 版权所有丨如未注明 , 均为原创丨本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:详解 Spring MVC 中的 AbstractFormController
喜欢 (0)
发表我的评论
取消评论
表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址