一、入门案例
使用idea开发软件,创建maven工程。
1、创建Web工程,引入开发jar包。(pom.xml文件主要内容如下)
<!-- 版本锁定 -->
<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</groupId>
<artifactId>servlet-api</artifactId>
<version>2.5</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>javax.servlet.jsp</groupId>
<artifactId>jsp-api</artifactId>
<version>2.0</version>
<scope>provided</scope>
</dependency>
</dependencies>
2、配置核心控制器(DispatcherServlet,web.xml文件主要内容如下)
<!-- SpringMVC的核心控制器 -->
<servlet>
<servlet-name>dispatcherServlet</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servletclass>
<!-- 配置Servlet的初始化参数,读取springmvc的配置文件,创建spring容器 -->
<!-- 可理解为在dispatcherServlet这个类中,添加了一个属性contextConfigLocation,且为这个属性赋值为classpath:springmvc.xml,这样DispatcherServlet实例一被创建,就可以加载springmvc.xml -->
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:springmvc.xml</param-value>
</init-param>
<!-- 正常情况下,在第一次发请求的时候创建DispatcherServlet实例,添加以下标签后,可以实现在服务器启动后,就创建DispatcherServlet实例 -->
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<!-- 必须与上面的servlet-name一致 -->
<servlet-name>dispatcherServlet</servlet-name>
<!-- 设置为所有请求都被DispatcherServlet拦截 -->
<url-pattern>/</url-pattern>
</servlet-mapping>
<!--配置解决中文乱码的过滤器-->
<filter>
<filter-name>characterEncodingFilter</filter-name>
<filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
<init-param>
<param-name>encoding</param-name>
<param-value>UTF-8</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>characterEncodingFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
3、编写springmvc.xml的配置文件(文件必须在:项目名/src/main/resources/下,springmvc.xml文件主要内容如下)
<!-- 配置spring创建容器时要扫描的包,使spring相关的注解生效,如@Controller、@Service等 -->
<context:component-scan base-package="com.practice"></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的支持,使springmvc相关的注解生效,如@RequestMapping等 -->
<!-- 此标签也表明,同时配置并开启了:请求处理器映射器(HandlerMapping)、处理器适配器(HandlerAdapter) 组件 -->
<mvc:annotation-driven/>
4、编写jsp页面和Controller控制器类
(1) index.jsp
<body>
<h3>入门案例</h3>
<a href="${ pageContext.request.contextPath }/hello">入门案例</a>
</body>
(2) HelloController.java
@Controller
public class HelloController {
@RequestMapping(path="/hello")
public String sayHello() {
System.out.println("Hello SpringMVC!!");
return "success";
}
}
(3) success.jsp,在WEB-INF目录下创建pages文件夹中创建,路径与springmvc.xml中,在视图解析器中配置的路径一致。
<body>
<h3>入门成功!!</h3>
</body>
二、工作流程
1、入门案例执行流程
(1)启动Tomcat服务器的时候,因为配置了load-on-startup标签,所以会创建DispatcherServlet对象,然后就会加载springmvc.xml配置文件。
(2)springmvc.xml中,开启了spring相关的注解扫描,被@Controller标注的HelloController对象就会被创建。
(3)从index.jsp发送请求,请求会先到达DispatcherServlet核心控制器,根据配置的@RequestMapping注解,找到执行的具体方法。
(4)根据执行方法的返回值,结合springmvc.xml中配置的视图解析器,去指定目录下查找指定名称的JSP文件。
(5)Tomcat服务器渲染页面,给客户端做出响应。
2、执行流程图