SpringMVC的入门案例
一、案例
案例实现简单的发送请求控制台输出打印案例
(基于 黑马课程 学习的资料与图片)
1.创建maven的WEB工程
2.引入开发的jar包 (坐标)
具体的坐标如下:
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<maven.compiler.source>1.8</maven.compiler.source>
<maven.compiler.target>1.8</maven.compiler.target>
<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</groupId>
<artifactId>servlet-api</artifactId>
<version>2.5</version>
<scope>provided</scope> <!-- provided表明该jar包只在编译和测试的时候起作用。-->
</dependency>
<dependency>
<groupId>javax.servlet.jsp</groupId>
<artifactId>jsp-api</artifactId>
<version>2.0</version>
<scope>provided</scope> <!-- provided表明该jar包只在编译和测试的时候起作用。-->
</dependency>
</dependencies>
3.配置核心的控制器(配置DispatcherServlet)
在web.xml配置文件中核心控制器DispatcherServlet
<!DOCTYPE web-app PUBLIC
"-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN"
"http://java.sun.com/dtd/web-app_2_3.dtd" >
<web-app>
<display-name>Archetype Created Web Application</display-name>
<!-- 配置前端控制器 -->
<servlet>
<servlet-name>dispatcherServlet</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<!-- 建立与springmvc.xml联系 配置全局初始化参数让servlet加载xml文件 -->
<init-param>
<!-- 给DispatcherServlet类的contextConfigLocation属性传一个路径 -->
<param-name>contextConfigLocation</param-name>
<param-value>classpath:springmvc.xml</param-value>
</init-param>
<!-- 配置启动服务器创建对象加载 xml 文件 -->
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>dispatcherServlet</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
</web-app>
4. 编写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 IOC注解扫描-->
<context:component-scan base-package="cn.itcast"></context:component-scan>
<!-- 配置springMVC视图解析器 -->
<bean id="internalResourceViewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<!-- prefix 表示文件所在目录 -->
<property name="prefix" value="/WEB-INF/pages/"></property>
<!-- suffix 表示文件后缀名 -->
<property name="suffix" value=".jsp"></property>
</bean>
<!-- 开启springMVC 注解支持 -->
<mvc:annotation-driven conversion-service="conversionServiceFactoryBean"></mvc:annotation-driven>
</beans>
5. 编写index.jsp和HelloController控制器类
5.1 index.jsp
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>index</title>
</head>
<body>
<h1>快速入门</h1>
<a href="hello">快速入门</a>
</body>
</html>
5.2. HelloController
@Controller
@RequestMapping(path = "/user")
public class HelloController {
@RequestMapping(path = "/hello") //配置请求映射路径
public String hello(){
System.out.println("hello springMVC");
return "success";
}
}
5. 在WEB-INF目录下创建pages文件夹,编写success.jsp的成功页
<%@ page contentType="text/html;charset=UTF-8" language="java" isELIgnored="false" %>
<html>
<head>
<title>success</title>
</head>
<body>
<h1>成功</h1>
</body>
</html>
6. 启动Tomcat服务器,进行测试
二、入门案例的执行过程分析
1. 入门案例的执行流程
1.当启动Tomcat服务器的时候,因为配置了load-on-startup标签,所以会创建DispatcherServlet对象, 就会加载springmvc.xml配置文件
2.开启了注解扫描,那么HelloController对象就会被创建
3.从index.jsp发送请求,请求会先到达DispatcherServlet核心控制器,根据配置@RequestMapping注解 找到执行的具体方法
4. 根据执行方法的返回值,再根据配置的视图解析器,去指定的目录下查找指定名称的JSP文件
5. 5. Tomcat服务器渲染页面,做出响应
2.入门案例中的组件分析
三、RequestMapping注解使用
-
RequestMapping注解的作用是 建立请求URL和处理方法之间的对应关系
-
RequestMapping注解可以作用在方法和类上
2.1. 作用在类上:第一级的访问目录
2.2. 作用在方法上:第二级的访问目录
2.3. 细节:路径可以不编写 / 表示应用的根目录开始
2.4. 细节:${ pageContext.request.contextPath }也可以省略不写,但是路径上不能写 / -
RequestMapping的属性 1. path 指定请求路径的url 2. value value属性和path属性是一样的 3. mthod 指定该方法的请求方式 4. params 指定限制请求参数的条件 5. headers 发送的请求中必须包含的请求头