SpringMVC的入门程序
工程目录如下:
1. 创建WEB工程,引入开发的jar包
具体的坐标如下:
<!-- 版本锁定 --> <properties> <spring.version>5.0.2.RELEASE</spring.version> </properties> <dependencies> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-context</artifactId> <version>${spring.version}</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-web</artifactId> <version>${spring.version}</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-webmvc</artifactId> <version>${spring.version}</version> </dependency> <dependency> <groupId>javax.servlet.jsp</groupId> <artifactId>jsp-api</artifactId> <version>2.0</version> <scope>provided</scope> </dependency> <dependency> <groupId>javax.servlet</groupId> <artifactId>servlet-api</artifactId> <version>2.5</version> <scope>provided</scope> </dependency> </dependencies
2. 配置核心的控制器(配置DispatcherServlet)
在web.xml配置文件中核心控制器DispatcherServlet
<!--SpringMVC的核心控制器--> <servlet> <servlet-name>dispatcherServlet</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <!--配置Servlet的初始化参数,读取springmvc的配置文件,创建spring容器--> <init-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:springmvc.xml</param-value> </init-param> <!--配置servlet启动时加载对象--> <load-on-startup>1</load-on-startup> </servlet> <servlet-mapping> <servlet-name>dispatcherServlet</servlet-name> <url-pattern>/</url-pattern> </servlet-mapping>
敲代码时在<url-pattern>/</url-pattern>中多敲了一个*,导致路径错误,要注意!!!
3. 编写springmvc.xml的配置文件
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:mvc="http://www.springframework.org/schema/mvc" xmlns:context="http://www.springframework.org/schema/context" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation=" http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd"> <!--配置spring创建容器时要扫描的包--> <context:component-scan base-package="com.churujianghudezai"></context:component-scan> <!--配置视图解析器--> <bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver"> <property name="prefix" value="/WEB-INF/pages/"></property> <property name="suffix" value=".jsp"></property> </bean> <!--配置spring开启注解mvc的支持--> <mvc:annotation-driven></mvc:annotation-driven> </beans>
在"/WEB-INF/pages/"的最后不要忘记加/,否则同样会导致路径错误!!!
4. 编写index.jsp和HelloController控制器类
<%@ page contentType="text/html;charset=UTF-8" language="java" %> <html> <head> <title>Title</title> </head> <body> <h3>入门案例</h3> <a href="hello">入门程序</a> </body> </html>
@Controller public class HelloController { /** * 接受请求 */ @RequestMapping(path="/hello") public String sayHello(){ System.out.println("Hello,springMVC!"); return "success"; } }
5. 在WEB-INF目录下创建pages文件夹,编写success.jsp的成功页面
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Title</title>
</head>
<body>
入门成功!!!
</body>
</html>
6. 启动Tomcat服务器,进行测试
入门案例的执行过程分析
1. 入门案例的执行流程
1. 当启动Tomcat服务器的时候,因为配置了load-on-startup标签,所以会创建DispatcherServlet对象, 就会加载springmvc.xml配置文件
2. 开启了注解扫描,那么HelloController对象就会被创建
3. 从index.jsp发送请求,请求会先到达DispatcherServlet核心控制器,根据配置@RequestMapping注解 找到执行的具体方法
4. 根据执行方法的返回值,再根据配置的视图解析器,去指定的目录下查找指定名称的JSP文件
5. Tomcat服务器渲染页面,做出响应
详细的执行过程如下:
2. 入门案例中的组件分析
1. 前端控制器(DispatcherServlet):
用户请求到达前端控制器,它就相当于 mvc 模式中的 c,dispatcherServlet 是整个流程控制的中心,由 它调用其它组件处理用户的请求,dispatcherServlet 的存在降低了组件之间的耦合性。
2. 处理器映射器(HandlerMapping):
HandlerMapping 负责根据用户请求找到 Handler 即处理器,SpringMVC 提供了不同的映射器实现不同的 映射方式,例如:配置文件方式,实现接口方式,注解方式等。
3. 处理器(Handler):
它就是我们开发中要编写的具体业务控制器。由 DispatcherServlet 把用户请求转发到 Handler。由 Handler 对具体的用户请求进行处理。
4. 处理器适配器(HandlAdapter):
通过 HandlerAdapter 对处理器进行执行,这是适配器模式的应用,通过扩展适配器可以对更多类型的处理 器进行执行。
5. 视图解析器(View Resolver):
View Resolver 负责将处理结果生成 View 视图,View Resolver 首先根据逻辑视图名解析成物理视图名 即具体的页面地址,再生成 View 视图对象,最后对 View 进行渲染将处理结果通过页面展示给用户
6. 视图(View):
SpringMVC 框架提供了很多的 View 视图类型的支持,包括:jstlView、freemarkerView、pdfView 等。我们最常用的视图就是 jsp。 一般情况下需要通过页面标签或页面模版技术将模型数据通过页面展示给用户,需要由程序员根据业务需求开
发具体的页面。
特别说明一下:
:
在 SpringMVC 的各个组件中,处理器映射器、处理器适配器、视图解析器称为 SpringMVC 的三大组件。
使用<mvc:annotation-driven> 自动加载 RequestMappingHandlerMapping (处理映射器)和 RequestMappingHandlerAdapter ( 处 理 适 配 器 ) , 可 用 在 SpringMVC.xml 配 置 文 件 中 使 用 <mvc:annotation-driven>替代注解处理器和适配器的配置。 它就相当于在 xml 中配置了:
<!-- 上面的标签相当于 如下配置--> <!-- Begin --> <!-- HandlerMapping --> <bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerM apping"></bean> <bean class="org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping"></bean> <!-- HandlerAdapter --> <bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerA dapter"></bean> <bean class="org.springframework.web.servlet.mvc.HttpRequestHandlerAdapter"></bean> <bean class="org.springframework.web.servlet.mvc.SimpleControllerHandlerAdapter"></bean> <!-- HadnlerExceptionResolvers --> <bean class="org.springframework.web.servlet.mvc.method.annotation.ExceptionHandlerExcept ionResolver"></bean> <bean class="org.springframework.web.servlet.mvc.annotation.ResponseStatusExceptionResolv er"></bean> <bean class="org.springframework.web.servlet.mvc.support.DefaultHandlerExceptionResolver" ></bean> <!-- End -->
注意: 一般开发中,我们都需要写上此标签(虽然从入门案例中看,我们不写也行,随着课程的深入,该标签还 有具体的使用场景)。
明确: 我们只需要编写处理具体业务的控制器以及视图。
RequestMapping注解
1. RequestMapping注解的作用是 建立请求URL和处理方法之间的对应关系
2. RequestMapping注解可以作用在方法和类上
1. 作用在类上:第一级的访问目录
2. 作用在方法上:第二级的访问目录
3. 细节:路径可以不编写 / 表示应用的根目录开始
4. 细节:${ pageContext.request.contextPath }也可以省略不写,但是路径上不能写 /
3. RequestMapping的属性 (后面笔记都会讲到)
1. path 指定请求路径的url
2. value value属性和path属性是一样的 (value可省去不写)
@Controller
//@RequestMapping(path="/haha")
//@RequestMapping(value"/haha")
@RequestMapping("/haha")//与前两种等价,作用在类上:表示第一级的访问目录
public class HelloController {
/**
* 接受请求
*/
//@RequestMapping(path="/hello")
//@RequestMapping(value="/hello")
@RequestMapping("/hello")//与前两种等价,作用在方法上:表示第二级的访问目录
public String sayHello(){
System.out.println("Hello,springMVC!");
return "success";
}
}
由以上代码中的两处requestmapping()可知,发起的请求相对路径为 href="haha/hello"。
3. method 指定该方法的请求方式 ( "get"或者"post", 链接的方式一般是"get" )
@RequestMapping(value="/hello",method={RequestMethod.POST}) public String sayHello(){ System.out.println("Hello,springMVC!"); return "success"; }
当@RequestMapping()中不止value一个属性时,这时的value就不可以省去。这里我们添加一个method属性,属性值为post,还是用链接 href="haha/hello" 发送请求,则浏览器将会报错:
如果改为get方式将不会出现这个问题。
4. params 指定限制请求参数的条件
在链接路径不带参数的情况下,在@RequestMapping()中添加属性params,且内部属性名为username:
@RequestMapping(value="/hello",params = {"username"})
则点击链接便会报错:(只有路径为"haha/hello?username"或"haha/hello?username=xxx (+ &....&....)"才会成功)
同样,若链接地址为"haha/hello?username"或"haha/hello?username=haha",而@RequestMapping()中:
@RequestMapping(value="/hello",params = {"username=heihei"})
结果同样会报错!(只有路径为"haha/hello?username=heihei (+&...&...)"才能成功)
5. headers 指定发送的请求中必须包含的请求头
@RequestMapping(value="/hello",headers = {"Accept"})
规定了只有在发送请求的请求头中含有Accept才能映射成功。