SpringMVC优势
1、分工明确:
前端控制器(DispatcherServlet)
处理器映射(HandlerMapping)
处理器适配器(HandlerAdapter)
视图解析器(ViewResolver)
处理器或页面控制器(Controller)
验证器(Validator)
命令对象(Command Object请求参数绑定到的对象)
表单对象(Form Object提供给表单展示和提交到的对象)
模型对象(Model Object)
每一个角色都可以由一个专门的对象来实现
2、拥有强大的灵活性。
3、由于命令对象就是一个POJO,无需继承框架特定API,可以使用命令对象直接作为业务对象。
4、和Spring 其他框架无缝集成,是其它Web框架所不具备的。
5、可适配,通过HandlerAdapter可以支持任意的类作为处理器,根据不同的场景,选择合适的控制器子类。
6、可定制性,HandlerMapping、ViewResolver等能够非常简单的定制。
7、功能强大的数据验证、格式化、绑定机制:比如将类型不匹配作为应用级的验证错误,这可以保证错误的值。再比如本地化的日期和数字绑定等等。
8、利用Spring提供的Mock对象能够非常简单的进行Web层单元测试。
9、本地化、主题的解析的支持,支持国际化,支持根据用户区域显示多国语言,并且国际化的配置非常简单。
10、强大的JSP标签库,在Spring2.0中引入的表单标签库,使用在JSP编写表单更加容易。
11、Spring MVC使用的WebApplicationContext容器,使得Spring Bean的生命周期可以被限制在当前的HTTp Request或者HTTp Session。
12、可重用:可以使用现有的业务对象作为命令或表单对象,而不需要去扩展某个特定框架的基类。
SpringMVC工作原理
(图来自于网络,侵删)
1.服务器启动,应用被加载。读取到web.xml中的配置创建spring容器并且初始化容器中的对象。注意:从入门案例中可以看到的是:HelloController和InternalResourceViewResolver,但是远不止这些。
2.http请求:客户端提交请求到DispatcherServlet。
2.寻找以及调用处理器:被DispatherServlet捕获,该Servlet并不处理请求,而是把请求转发出去。转发的路径是根据请求URL,匹配@RequestMapping中的内容。
3.匹配到了后,Controller执行相关的逻辑代码,即对应的方法,该方法有一个返回值(返回ModelAndView)。
4.根据方法的返回值,借助InternalResourceViewResolver找到对应的结果视图。将一个逻辑上面的视图名称机械为一个真正的视图同时取出model。
5.将模型数据传给View显示:将model数据放入view中,即渲染浏览器。
RequestMapping
1.RequestMapping注解:配置请求路径URL,建立请求URL和处理方法之间的对应关系
2.该注解可以定义在方法上,也可以定义在类上,用来表示层级关系。
作用在类上:第一级的访问目录
作用在方法上:第二级的访问路径
配置URL时以/开头和不以/开头的区别:添加/代表从项目的根目录开始访问,不添加/代表从当前位置开始查找。
3.属性
param 限制请求参数,必须符合指定条件
path 指定请求路径的URL
例:
//请求参数中必须包含id,username必须为admin,password不能是1
@RequestMapping(path = "/test",params = {"id","username=admin","password!=1"})
public String test(){
return "param";
}
value value属性和path属性是一样的
value和path互为别名,值为数组,可以指定多个值
例:
@RequestMapping(value = "/test")
public String test(){
return "value";
}
method 指定该方法的请求方式
headers 限定请求头,必须符合指定条件才能访问URL
例:
//请求头中必须包含Cookie
@RequestMapping(path = "/test",headers = {"Cookie"})
public String test(){
return "headers";
}