到目前为止我们已经大概学习了StringMVC的执行流程,以及详细的处理器映射器和处理器适配器的执行流程,并可以自己写一个配置方式开发的小Demo了。今天我们来总结一下实现一个Controller的几种方法。
一、实现Controller接口
/** * 要实现Controller接口,这样就算是一个springmvc的Controller了。 * @author Jonas * */ public class MyController implements Controller { @Override public ModelAndView handleRequest(HttpServletRequest request, HttpServletResponse response) throws Exception { ModelAndView mv = new ModelAndView(); mv.addObject("message","hello spring mvc world"); mv.setViewName("welcome"); return mv; } }
这种方式采用的适配器是SimpleControllerHandlerAdapter。
二、实现HttpRequestHandler接口
public class HelloController implements HttpRequestHandler { @Override public void handleRequest(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { request.setAttribute("message", "Hello HttpRequestHandler world"); request.getRequestDispatcher("/WEB-INF/jsp/welcome.jsp").forward(request, response); } }
这种方式和第一种完全不一样,该方式采用的适配器为HttpRequestHandlerAdapter。该类的handleRequest方法返回值为null,更多的是由程序员来实现的。比如上方的跳转页面。
三、继承AbstractController抽象类
public class MyController1 extends AbstractController { @Override protected ModelAndView handleRequestInternal(HttpServletRequest request, HttpServletResponse response) throws Exception { // TODO Auto-generated method stub return null; } }
该方式和第一种一样,都使用了SimpleControllerHandlerAdapter。不同的一点在于该方式采用了一种模版方法的方式进行实现。该方法可以限制HTTP的提交请求方式。在springmvc.xml中注册处理器的时候,添加property来进行注入属性。如下:
<!-- 注册SpringMVC处理器 --> <bean id="myController" class="cn.wechatbao.controller.MyController1"> <property name="supportedMethods" value="POST"></property> </bean>
以上设置当前controller只支持POST请求。supportedMethods属性来自于AbstractController的父类WebContentGenerator类。
public abstract class AbstractController extends WebContentGenerator implements Controller { //... }
我们打开WebContentGenerator类,如下:
四、继承MultiActionController类
public class MyController2 extends MultiActionController { public ModelAndView doFirst(HttpServletRequest request, HttpServletResponse response){ ModelAndView mv = new ModelAndView(); mv.addObject("message","hello first world"); mv.setViewName("welcome"); return mv; } public ModelAndView doSecond(HttpServletRequest request, HttpServletResponse response){ ModelAndView mv = new ModelAndView(); mv.addObject("message","hello second world"); mv.setViewName("welcome"); return mv; } }
springmvc.xml中需要如下配置:
<bean class="org.springframework.web.servlet.handler.SimpleUrlHandlerMapping"> <property name="mappings"> <props> <prop key="/multiAction/*.do">myController</prop> </props> </property> </bean> <!-- 注册SpringMVC处理器 --> <bean id="myController2" class="cn.wechatbao.controller.MyController2"></bean>
这样就实现了动态路径访问,原因是MultiActionController类内部使用了一个名叫InternalPathMethodNameResolver的内部方法名称路径解析器。该解析器将方法名作为资源名称进行解析,意味着,我们提交请求时要将方法名作为资源名称出现。如下:
http://localhost:8080/SpringMVC/multiAction/doFirst.do
http://localhost:8080/SpringMVC/multiAction/doSecond.do
但是该方法在Spring4.3以后就废弃了。不建议使用了,官方的解释为in favor of annotation-driven handler methods有利于注解驱动处理程序的方法。
来源:https://www.cnblogs.com/xinhudong/p/9987923.html