实际上我们的第一个Hello案例中实现了Controller接口,这就具有了侵入,Spring MVC作为一个轻量级框架,一大特点就是没有侵入性(继承框架的类或者接口),所以平时写代码用注解开发的多,既简单而且方便,没有第一个案例那么复杂。
Controller的设计解析:
@Controller
public class HelloController {
@RequestMapping("/hello")
public ModelAndView hello(HttpServletRequest req,HttpServletResponse resp){
ModelAndView mv=new ModelAndView();
mv.addObject("msg", "hello Spring mvc annotation");
mv.setViewName("hello");
return mv;
}
}
必须添加@Controller注解;
@RequestingMapping 请求映射,一个请求一个方法,所以Spring MVC是基于方法的设计
方法自定义,但是返回类型是ModelAndView,参数是HttpServletRequest,HttpServletResponse(DispatcherServlet继承自HttpServlet,所以参数这么写就可以了)。
为什么要返回ModelAndView
Spring MVC支持很多种视图,视图解析器。支持多个视图解析器,可以串联他们,需指定order即可,跟welcome-file-list差不多,最大越靠后,可以查看文档。
注解比起Struts2好很多,配置文件少些很多,来一个请求Struts2就要在配置文件写,现在直接在类中配,麻烦的是封装数据,Struts2不需要特地去封装,但是个人觉得封装这个数据会比写配置文件爽很多。
DispatcherServlet的配置
可以在Servlet的声明元素上添加一些初始化属性(init-param),但是必须在on-startup前。
<servlet>
<servlet-name>springmvc</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:mvc.xml</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
具体可以查看文档,这里是利用init-param元素更改默认的文件名和文件路径
使用注解开发在配置文件中不需要配置HandlerMapping和HandlerAdapter,还要请求处理器,只需要配置渲染器(视图解析器),因为@RequestMapping注解实际上就使用了RequestMappingHandlerMapping(实现了HandlerMapping接口),RequestMappingHandlerAdapter(实现了HandlerAdapter接口)。
注解开发步骤:
- 导入相关的jar包
- 配置web.xml文件
- 写好Spring MVC配置文件的模板,需要添加扫描包
- 定义扫描包,在包下写Controller类
- jsp
BUG记载
- address is use:JVM_bind_ 8080端口被占用,在myeclipse运行项目卡退再重启下可能会出现,解决方法,任务管理器关闭javax.exe相关进程
- class not found :org.springframework.aop.TargetSource缺少相关jar包,这里是aop
- web.xml文件中定义是*.do,那么访问时必须.do结尾,否则Myeclispe没报错,但是404,同时强烈建议用.do,后面会涉及到,最好在web.xml里面强势规定.do,不要用.html等。