4.11、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中,从而可以跨越多次请求得到该命令对象。

驱动式项目构建

内置高效可靠的代码生成器

支持多种数据模型,根据数据库表生成常规重复性代码,使研发工程师更专注于业务逻辑代码的实现,大幅提升其工作效率,解放其重复性工作


OPEN CI

开源规范化项目管理解决方案,实现软件流水线式生产,保证正确性、可靠性

向导式创建、导入项目,集成版本控制(GIT/SVN)、项目管理(Trac/Redmine)、代码质量(Sonar)、持续集成(Jenkins)

私有部署,统一管理,为开发者而生

愿意了解框架技术或者源码的朋友直接加求求2042849237

接下来具体看一下如何使用吧。

(1、修改我们的模型数据以支持多步骤提交:

Java代码

publicclassUserModel{

privateStringusername;

privateStringpassword;

privateStringrealname;//真实姓名

privateWorkInfoModelworkInfo;

privateSchoolInfoModelschoolInfo;

//省略getter/setter

}

Java代码

publicclassSchoolInfoModel{

privateStringschoolType;//学校类型:高中、中专、大学

privateStringschoolName;//学校名称

privateStringspecialty;//专业

//省略getter/setter

}

Java代码

publicclassWorkInfoModel{

privateStringcity;//所在城市

privateStringjob;//职位

privateStringyear;//工作年限

//省略getter/setter

}

(2、控制器

Java代码

packagecn.javass.chapter4.web.controller;

//省略import

publicclassInfoFillWizardFormControllerextendsAbstractWizardFormController{

publicInfoFillWizardFormController(){

setCommandClass(UserModel.class);

setCommandName("user");

}

protectedMapreferenceData(HttpServletRequestrequest,intpage)throwsException{

Mapmap=newHashMap();

if(page==1){//如果是填写学校信息页需要学校类型信息

map.put("schoolTypeList",Arrays.asList("高中","中专","大学"));

}

if(page==2){//如果是填写工作信息页需要工作城市信息

map.put("cityList",Arrays.asList("济南","北京","上海"));

}

returnmap;

}

protectedvoidvalidatePage(Objectcommand,Errorserrors,intpage){

//提供每一页数据的验证处理方法

}

protectedvoidpostProcessPage(HttpServletRequestrequest,Objectcommand,Errorserrors,intpage)throwsException{

//提供给每一页完成时的后处理方法

}

protectedModelAndViewprocessFinish(HttpServletRequestreq,HttpServletResponseresp,Objectcommand,BindExceptionerrors)throwsException{

//成功后的处理方法

System.out.println(command);

returnnewModelAndView("redirect:/success");

}

protectedModelAndViewprocessCancel(HttpServletRequestrequest,HttpServletResponseresponse,Objectcommand,BindExceptionerrors)throwsException{

//取消后的处理方法

System.out.println(command);

returnnewModelAndView("redirect:/cancel");

}

}

page页码:是根据请求中以“_target”开头的参数名来确定的,如“_target0”,则页码为0;

referenceData:提供每一页需要的表单支持对象,如完善学校信息需要学校类型,page页码从0开始(而且根据请求参数中以“_target”开头的参数来确定当前页码,如_target1,则page=1);

validatePage:验证当前页的命令对象数据,验证应根据page页码来分步骤验证;

postProcessPage:验证成功后的后处理;

processFinish:成功时执行的方法,此处直接重定向到/success控制器(详见CancelController);

processCancel:取消时执行的方法,此处直接重定向到/cancel控制器(详见SuccessController);

其他需要了解:

allowDirtyBack和allowDirtyForward:决定在当前页面验证失败时,是否允许向导前移和后退,默认false不允许;

onBindAndValidate(HttpServletRequest request, Object command, BindException errors, int page):允许覆盖默认的绑定参数到命令对象和验证流程。

(3、spring配置文件(chapter4-servlet.xml)

Java代码


class="cn.javass.chapter4.web.controller.InfoFillWizardFormController">

wizard/baseInfo

wizard/schoolInfo

wizard/workInfo

pages:表示向导中每一个步骤的逻辑视图名,当InfoFillWizardFormController的page=0,则将会选择“wizard/baseInfo”,以此类推,从而可以按步骤选择要展示的视图。

(4、向导中的每一步视图

(4.1、基本信息页面(第一步) baseInfo.jsp:

Java代码

真实姓名:

当前页码为0;

name="_target1":表示向导下一步要显示的页面的页码为1;

(4.2、学校信息页面(第二步) schoolInfo.jsp:

Java代码

学校类型:

selected="selected"

>

${schoolType}


学校名称:

专业:

(4.3、工作信息页面(第三步) workInfo.jsp:

Java代码

所在城市:

selected="selected"

>

${city}


职位:

工作年限:

当前页码为2;

name="_target1":上一步,表示向导上一步要显示的页面的页码为1;

name="_finish":向导完成,表示向导成功,将会调用向导控制器的processFinish方法;

name="_cancel":向导取消,表示向导被取消,将会调用向导控制器的processCancel方法;

到此向导控制器完成,此处的向导流程比较简单,如果需要更复杂的页面流程控制,可以选择使用Spring Web Flow框架。

4.12、ParameterizableViewController

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

Java代码

class="org.springframework.web.servlet.mvc.ParameterizableViewController">

该控制器接收到请求后直接选择参数化的视图,这样的好处是在配置文件中配置,从而避免程序的硬编码,比如像帮助页面等不需要进行功能处理,因此直接使用该控制器映射到视图。

4.13、AbstractUrlViewController

提供根据请求URL路径直接转化为逻辑视图名的支持基类,即不需要功能处理,直接根据URL计算出逻辑视图名,并选择具体视图进行展示:

urlDecode:是否进行url解码,不指定则默认使用服务器编码进行解码(如Tomcat默认ISO-8859-1);

urlPathHelper:用于解析请求路径的工具类,默认为org.springframework.web.util.UrlPathHelper。

UrlFilenameViewController是它的一个实现者,因此我们应该使用UrlFilenameViewController。

4.14、UrlFilenameViewController

将请求的URL路径转换为逻辑视图名并返回的转换控制器,即不需要功能处理,直接根据URL计算出逻辑视图名,并选择具体视图进行展示:

根据请求URL路径计算逻辑视图名;

Java代码

class="org.springframework.web.servlet.mvc.UrlFilenameViewController"/>

class="org.springframework.web.servlet.mvc.UrlFilenameViewController"/>

class="org.springframework.web.servlet.mvc.UrlFilenameViewController"/>

class="org.springframework.web.servlet.mvc.UrlFilenameViewController"/>

/index1/*:可以匹配/index1/demo,但不匹配/index1/demo/demo,如/index1/demo逻辑视图名为demo;

/index2/**:可以匹配/index2路径下的所有子路径,如匹配/index2/demo,或/index2/demo/demo,“/index2/demo”的逻辑视图名为demo,而“/index2/demo/demo”逻辑视图名为demo/demo;

/*.html:可以匹配如/abc.html,逻辑视图名为abc,后缀会被删除(不仅仅可以是html);

/index3/*.html:可以匹配/index3/abc.html,逻辑视图名也是abc;

上述模式为Spring Web MVC使用的Ant-style模式进行匹配的:

Java代码

?匹配一个字符,如/index?可以匹配/index1,但不能匹配/index或/index12

*匹配零个或多个字符,如/index1/*,可以匹配/index1/demo,但不匹配/index1/demo/demo

**匹配零个或多个路径,如/index2/**:可以匹配/index2路径下的所有子路径,如匹配/index2/demo,或/index2/demo/demo

如果我有如下模式,那Spring该选择哪一个执行呢?当我的请求为“/long/long”时如下所示:

/long/long

/long/**/abc

/long/**

/**

Spring的AbstractUrlHandlerMapping使用:最长匹配优先;

如请求为“/long/long”将匹配第一个“/long/long”,但请求“/long/acd”则将匹配“/long/**”,如请求“/long/aa/abc”则匹配“/long/**/abc”,如请求“/abc”则将匹配“/**”

UrlFilenameViewController还提供了如下属性:

prefix:生成逻辑视图名的前缀;

suffix:生成逻辑视图名的后缀;

Java代码

protectedStringpostProcessViewName(StringviewName){

returngetPrefix()+viewName+getSuffix();

}

Java代码

prefix=

“test

”,suffix=

“test

,如上所示的

/*.htm

可以匹配如/abc.htm,但逻辑视图名将变为testabctest。

分布式

分布式服务:Dubbo+Zookeeper+Proxy+Restful

分布式消息中间件:KafKa+Flume+Zookeeper

分布式缓存:Redis 分布式文件:FastDFS

负载均衡:Keepalived+Nginx+Proxy(三重负载)


欢迎大家一起学习研究相关技术愿意了解框架技术或者源码的朋友直接加求求(企鹅):2042849237

更多详细源码参考来源:http://minglisoft.cn/technology