控制器
ParameterizableViewController
我们在之前使用Struts2的时候,如果仅仅要跳转到某个WEB-INF/JSP页面,也要写业务方法。而业务方法也仅仅是返回一个简单的字符串。
如下的代码:
public String home(){ return "home"; }
<package name="nsfw-home" namespace="/nsfw" extends="struts-default"> <action name="nsfw_*" class="zhongfucheng.nsfw.HomeAction" method="{1}"> <result name="{1}">/WEB-INF/jsp/nsfw/{1}.jsp</result> </action> </package>
在SpringMVC中,如果仅仅是跳转到某个视图上,我们可以省略该Action和业务方法。配置的Action只要继承着ParameterizableViewController这个类就行了!
<!-- 专用于jsp到jsp/html的转发控制器 --> <bean name="/ok.action" class="org.springframework.web.servlet.mvc.ParameterizableViewController"> <!-- 转发到真实视图名 --> <property name="viewName" value="/WEB-INF/ok.jsp"/> </bean>
- 2017年9月26日15:57:45 现在看来, 好像还是在方法上写更好。我觉得统一管理起来会更加方便
AbstractCommandController
到目前为止,我们都没有将SpringMVC是怎么接收web端传递过来的参数的。
我们在Struts2中,只要在Action类上写对应的成员变量,给出对应的set和get方法。那么Struts2就会帮我们把参数封装到对应的成员变量中,是非常方便的。
那么我们在SpringMVC中是怎么获取参数的呢????我们是将Action继承AbstractCommandController这么一个类的。
public class HelloAction extends AbstractCommandController { @Override protected ModelAndView handle(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o, BindException e) throws Exception { return null; } }
在讲解该控制器之前,首先我们要明白SpringMVC控制器一个与Struts2不同的地方:SpringMVC的控制器是单例的,Struts2的控制器是多例的!
也就是说:Struts2收集变量是定义成员变量来进行接收,而SpringMVC作为单例的,是不可能使用成员变量来进行接收的【因为会有多个用户访问,就会出现数据不合理性】!
那么SpringMVC作为单例的,他只能通过方法的参数来进行接收对应的参数!只有方法才能保证不同的用户对应不同的数据!
实体
实体的属性要和web页面上的name提交过来的名称是一致的。这和Struts2是一样的!
public class User { private String id; private String username; public User() { } public User(String id, String username) { this.id = id; this.username = username; } public String getId() { return id; } public void setId(String id) { this.id = id; } public String getUsername() { return username; } public void setUsername(String username) { this.username = username; } @Override public String toString() { return "User{" + "id='" + id + '\'' + ", username='" + username + '\'' + '}'; } }
提交参数的JSP
<form action="${pageContext.request.contextPath}/hello.action" method="post"> <table align="center"> <tr> <td>用户名:</td> <td><input type="text" name="username"></td> </tr> <tr> <td>编号</td> <td><input type="text" name="id"></td> </tr> <tr> <td colspan="2"> <input type="submit" value="提交"> </td> </tr> </table> </form>
配置Action处理请求
<bean class="HelloAction" id="helloAction"></bean> <!-- 注册映射器(handler包)(框架) --> <bean class="org.springframework.web.servlet.handler.SimpleUrlHandlerMapping"> <property name="mappings"> <props> <prop key="/hello.action">helloAction</prop> </props> </property> </bean>
Action接收参数
public class HelloAction extends AbstractCommandController { /*设置无参构造器,里边调用setCommandClass方法,传入要封装的对象*/ public HelloAction() { this.setCommandClass(User.class); } /** * * @param httpServletRequest * @param httpServletResponse * @param o 这里的对象就表示已经封装好的了User对象了。! * @param e * @return * @throws Exception */ @Override protected ModelAndView handle(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o, BindException e) throws Exception { User user = (User) o; System.out.println(user); ModelAndView modelAndView = new ModelAndView(); //跳转到ok.jsp modelAndView.setViewName("/WEB-INF/ok.jsp"); //将数据封装到ModelAndView中 modelAndView.addObject("USER", user); return modelAndView; } }
效果:
小总结
/
- SpringMVC的工作流程:
- 用户发送HTTP请求,SpringMVC核心控制器接收到请求
- 找到映射器看该请求是否交由对应的Action类进行处理
- 找到适配器看有无该Action类
- Action类处理完结果封装到ModelAndView中
- 通过视图解析器把数据解析,跳转到对应的JSP页面
- 控制器介绍了两种:
- 可以实现对参数数据的封装
- 能够实现跳转到WEB-INF下资源,并不用写处理方法
- ParameterizableViewController
- AbstractCommandController