本文为转载学习html
原文连接:http://jinnianshilongnian.iteye.com/blog/1611743java
ServletForwardingControllerweb
将接收到的请求转发到一个命名的servlet,具体示例以下:spring
package cn.javass.chapter4.web.servlet; public class ForwardingServlet extends HttpServlet { @Override protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { resp.getWriter().write("Controller forward to Servlet"); } }
<servlet> <servlet-name>forwarding</servlet-name> <servlet-class>cn.javass.chapter4.web.servlet.ForwardingServlet</servlet-class> </servlet>
<!— 在xml配置处理器 --> <bean name="/forwardToServlet" class="org.springframework.web.servlet.mvc.ServletForwardingController"> <property name="servletName" value="forwarding"></property> </bean>
当咱们请求/forwardToServlet时,会被转发到名字为“forwarding”的servlet处理,该sevlet的servlet-mapping标签配置是可选的。设计模式
BaseCommandController命令控制器通用基类,提供了如下功能支持:浏览器
一、数据绑定:请求参数绑定到一个command object(命令对象,非GoF里的命令设计模式),这里的命令对象是指绑定请求参数的任何POJO对象;session
commandClass:表示命令对象实现类,如UserModel;mvc
commandName:表示放入请求的命令对象名字(默认command),request.setAttribute(commandName, commandObject);app
二、验证功能:提供Validator注册功能,注册的验证器会验证命令对象属性数据是否合法;jsp
validators:经过该属性注入验证器,验证器用来验证命令对象属性是否合法;
该抽象类没有没有提供流程功能,只是提供了一些公共的功能,实际使用时须要使用它的子类。
AbstractCommandController
命令控制器之一,能够实现该控制器来建立命令控制器,该控制器能把自动封装请求参数到一个命令对象,并且提供了验证功能
一、建立命令类(就是普通的JavaBean类/POJO)
package cn.javass.chapter4.model; public class UserModel { private String username; private String password; //省略setter/getter }
二、实现控制器
package cn.javass.chapter4.web.controller; //省略import public class MyAbstractCommandController extends AbstractCommandController { public MyAbstractCommandController() { //设置命令对象实现类 setCommandClass(UserModel.class); } @Override protected ModelAndView handle(HttpServletRequest req, HttpServletResponse resp, Object command, BindException errors) throws Exception { //将命令对象转换为实际类型 UserModel user = (UserModel) command; ModelAndView mv = new ModelAndView(); mv.setViewName("abstractCommand"); mv.addObject("user", user); return mv; } }
<!— 在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绑定到命令对象;绑定时按照
AbstractFormController
用于支持带步骤的表单提交的命令控制器基类,使用该控制器能够完成:
一、定义表单处理(表单的渲染),并从控制器获取命令对象构建表单;
二、提交表单处理,当用户提交表单内容后,AbstractFormController能够将用户请求的数据绑定到命令对象,并能够验证表单内容、对命令对象进行处理。
@Override protected ModelAndView handleRequestInternal(HttpServletRequest request, HttpServletResponse response)throws Exception { //一、是不是表单提交? 该方法实现为("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 { //二、表示是表单展现,该方法又转调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继承该类,并且提供了更简单的表单流程控制。
SimpleFormController
提供了更好的两步表单支持:
一、准备要展现的数据,并到表单展现页面;
二、提交数据数据进行处理。
第一步,展现:
第二步,提交表单:
接下来写一个用户注册的例子:
一、控制器
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); } }
setCommandClass和setCommandName:分别设置了命令对象的实现类和名字;
formBackingObject和referenceData:提供了表单展现须要的视图;
doSubmitAction:用于执行表单提交动做,由onSubmit方法调用,若是不须要请求/响应对象或进行数据验证,能够直接使用doSubmitAction方法进行功能处理。
二、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的做用是显示成功页面,此处就不列举了。
三、视图页面
<!-- register.jsp 注册展现页面--> <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>
此处可使用${user.username}获取到formBackingObject设置的表单对象、使用${cityList}获取referenceData设置的表单支持数据;
到此一个简单的两步表单到此结束,但这个表单有重复提交表单的问题,并且表单对象到页面的绑定是经过手工绑定的,后边咱们会学习spring标签库(提供自动绑定表单对象到页面)。
CancellableFormController
一个可取消的表单控制器,继承SimpleFormController,额外提供取消表单功能。
一、表单展现:和SimpleFormController同样;
二、表单取消:和SimpleFormController同样;
三、表单成功提交:取消功能处理方法为:onCancel(Object command),并且默认返回cancelView属性指定的逻辑视图名。
那如何判断是取消呢?若是请求中有参数名为“_cancel”的参数,则表示表单取消。也能够经过cancelParamKey来修改参数名(如“_cancel.x”等)。
示例:
一、控制器
复制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属性指定的逻辑视图名。
二、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的做用是显示取消页面,此处就不列举了(详见代码)。
三、视图页面(修改register.jsp)
<input type="submit" name="_cancel" value="取消"/>
该提交按钮的做用是取消,由于name="_cancel",即请求后会有一个名字为_cancel的参数,所以会执行onCancel功能处理方法。
四、测试:
在浏览器输入“http://localhost:9080/springmvc-chapter4/canCancelForm”,则首先到展现视图页面,点击“取消按钮”将重定向到“http://localhost:9080/springmvc-chapter4/cancel”,说明取消成功了。
实际项目可能会出现好比一些网站的完善我的资料都是多个页面(即多步),那应该怎么实现呢?接下来看一下spring Web MVC提供的对多步表单的支持类AbstractWizardFormController。