链接: springMVC01,springMVC的执行流程【第一个springMVC例子(XML配置版本):HelloWorld】
在基于上一篇的文章基础上,使用注解配置来对比一下二者的差距。
创建项目
新建一个maven项目,在pom.xml中导入项目需要的依赖,然后添加web支持,配置tomcat以及web项目发布依赖包
(这一个过程我就忽略掉了,和上个项目是一模一样,可以根据自己的情况查看上面链接,我之前的文章)。
1.配置web.xml
web.xml中还是配置DispatcherServlet
<!--配置DispatcherServlet 前端控制器-->
<servlet>
<servlet-name>springmvc</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<!--绑定spring配置文件-->
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:springmvc-servlet.xml</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>springmvc</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
2.编写spring配置文件
spring配置文件中,用来开启注解驱动,以及mvc注解驱动和视图解析器。在resources目录下新建一个springmvc-servlet.xml的配置文件。
<!--开启注解驱动,交由ioc容器来管理bean-->
<context:component-scan base-package="com.gothic.sunset"/>
<!--过滤静态资源请求-->
<mvc:default-servlet-handler />
<!--
支持mvc注解驱动
在spring中一般采用@RequestMapping注解来完成映射关系
要想使@RequestMapping注解生效
必须向上下文中注册DefaultAnnotationHandlerMapping
和一个AnnotationMethodHandlerAdapter实例
这两个实例分别在类级别和方法级别处理。
而annotation-driven配置帮助我们自动完成上述两个实例的注入。
-->
<mvc:annotation-driven />
<!--配置视图解析器-->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver" id="internalResourceViewResolver">
<!--前缀-->
<property name="prefix" value="/WEB-INF/jsp/"/>
<!--后缀-->
<property name="suffix" value=".jsp"/>
</bean>
这里提一下,之前我们是通过modelAndView来完成页面数据传递跳转的,现在通过一个Model接口来完成数据传递。而@RequestMapping注解中的value属性值用来匹配我们地址栏的请求。
3.controller层
上一篇,xml配置controler层的类是用实现controler接口来做的,这回都换成spring之前的注解配置bean来做。
新建一个包 com/gothic/sunset/controller 然后在里面新建一个类HelloController.java
package com.gothic.sunset.controller;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;
@Controller //使用注解将bean标识交由ioc容器管理
public class HelloController {
@RequestMapping("/hello")
public String sayHello(Model model){
String str = "helloWorld!";
//向模型中添加属性msg与值,可以在JSP页面中取出并渲染
model.addAttribute("msg",str);
// 最终访问/WEB-INF/hello.jsp
return "hello";
}
}
3.1@RequestMapping注解
@RequestMapping注解的作用就是将请求和处理请求的控制器方法关联
起来,建立映射关系。
- @RequestMapping标识一个类:设置映射请求的请求路径的初始信息
- @RequestMapping标识一个方法:设置映射请求请求路径的具体信息
@RequestMapping注解的value属性:
- @RequestMapping注解的value属性通过请求的请求地址匹配请求映射
- @RequestMapping注解的value属性是一个字符串类型的数组,表示该请求映射能够匹配多个请求地址所对应的请求
- @RequestMapping注解的value属性必须设置,至少通过请求地址匹配请求映射
@RequestMapping注解的method属性:
- @RequestMapping注解的method属性通过请求的请求方式(get或post)匹配请求映射
- @RequestMapping注解的method属性是一个RequestMethod类型的数组,表示该请求映射能够匹配多种请求方式的请求
- 若当前请求的请求地址满足请求映射的value属性,但是请求方式不满足method属性,则浏览器报错 405:Request method ‘POST’ not supported
对于处理指定请求方式的控制器方法,SpringMVC中提供了@RequestMapping的派生注解:
处理get请求的映射–>@GetMapping
处理post请求的映射–>@PostMapping
处理put请求的映射–>@PutMapping
处理delete请求的映射–>@DeleteMapping
4.运行测试
5.小结
浏览器发送请求,若请求地址符合前端控制器的url-pattern,该请求就会被前端控制器
DispatcherServlet处理。前端控制器会读取SpringMVC的核心配置文件,通过扫描组件找到控制器,将请求地址和控制器中@RequestMapping注解的value属性值进行匹配,若匹配成功,该注解所标识的控制器方法就是处理请求的方法。处理请求的方法需要返回一个字符串类型的视图名称,该视图名称会被视图解析器解析,加上前缀和后缀组成视图的路径,最终转发到视图对应的页面。