SpringMVC入门
一、SpringMVC 简介
- 首先,SpringMVC 是隶属于 Spring 框架的一部分,主要用来进行 Web 开发。
- SpringMVC 是一种基于 Java 实现 MVC 模型的轻量级 Web 框架。
- 优点: 1. 相对于 Servlet 来说,使用简单,开发便捷。2. 灵活性强。
二、SpringMVC 入门案例
1、创建 Maven 项目
- 按照下述图片步骤,一步一步进行。可能使用的 IEDA 版本之间会有些许差异,但是大体还是一样的。
- 此时正在创建相应插件,等待创建完成即可,如果是第一次创建需要等待一段时间。不用担心害怕,并不是创建出现了问题。
- 创建完成后项目结构如下所示,发现缺少书写 java 代码的文件夹,我们需要手动添加一下。
- 完成之后点击 Apply 应用即可。
- 修改 pom.xml 内部分内容,其他内容均可删除,只留下这些即可。
<?xml version="1.0" encoding="UTF-8"?><projectxmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><groupId>com.qdxorigin</groupId><artifactId>springmvc</artifactId><version>1.0-SNAPSHOT</version><packaging>war</packaging><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></properties><dependencies></dependencies></project>
2、在 pom.xml 文件中手动导入 jar 包
<dependencies><!-- 导入servlet jar包 --><dependency><groupId>javax.servlet</groupId><artifactId>javax.servlet-api</artifactId><version>4.0.1</version><scope>provided</scope></dependency><!-- 导入web开发 jar包 --><dependency><groupId>org.springframework</groupId><artifactId>spring-webmvc</artifactId><version>5.3.16</version></dependency></dependencies>
- 在导入 servlet 的坐标时需要使用 scope 标签指定作用范围。
- 如果不设置,默认的作用范围为 compile ,表示在编译、运行、测试时均有效。
- 如果运行有效会和 tomcat 中的 servlet-api 包发生冲突,导致启动报错。
- 设置为 provided 代表的是该包只在编译和测试的时候用,运行的时候无效,使用的是 tomcat 中的,可以有效避免冲突。
3、手动配置tomcat
- 因为目前和 tomcat 相关的 maven plugin 官方只提供了 tomcat7 ,但是这个版本的 tomcat 在使用过程中还存在些许的问题,所以博主就自己手动的配置了 tomcat 8.5.79 版本的tomcat。
4、编写 Controller 类
@ControllerpublicclassUserController{@ResponseBody@RequestMapping(value ="/select",method =RequestMethod.GET)publicStringselect(){System.out.println("SpringMVC select");return"{'msg':'qdxorigin'}";}}
- @RequestMapping 注解设置当前控制器方法请求访问路径。 - value 指定映射地址。- method 指定是请求方法类型。
- @ResponseBody 注解设置当前控制器方法响应内容为返回值,无需解析。
5、编写 ServletConfig 配置类
publicclassServletConfigextendsAbstractDispatcherServletInitializer{// 加载SpringMVC配置类@OverrideprotectedWebApplicationContextcreateServletApplicationContext(){// 初始化对象AnnotationConfigWebApplicationContext context =newAnnotationConfigWebApplicationContext();// 加载SpringMVC配置类
context.register(SpringMvcConfig.class);return context;}// 设置SpringMVC需要处理的请求映射路径@OverrideprotectedString[]getServletMappings(){returnnewString[]{"/"};}// 加载Spring配置类@OverrideprotectedWebApplicationContextcreateRootApplicationContext(){returnnull;}}
- 使用注解开发,不再使用 xml 文件的方式。
- 默认提供有 AbstractDispatcherServletInitializer ,只需要编写一个类继承并实现上述三个方法即可。
6、编写 SpringMvcConfig 配置类
@Configuration@ComponentScan("qdxorigin.controller")publicclassSpringMvcConfig{}
7、启动 tomcat ,浏览器访问 http://localhost:8080/springmvc/select
- 访问成功,入门案例结束。
三、SpringMVC 工作流程
- 以入门案例为例解析 SpringMVC 的工作流程。
1、启动服务器初始化过程
- 服务器启动,执行 ServletConfig 类(对应自己项目中的 Servlet 配置类),初始化web容器,功能类似于使用 web.xml 配置文件。
- 执行 Servlet 配置类中的 createServletApplicationContext 方法,创建 WebApplicationContext 对象。
- 加载 SpringMvcConfig 配置类。
- 执行 SpringMvcConfig 配置类中的 @ComponentScan 加载对应的 bean 。扫描指定包及其子包下所有类上的注解,如 Controller 类上的 @Controller 注解。
- 加载 UserController,每个 @RequestMapping 都对应一个具体的方法。即建立了 /select 和其对应的方法。
- 执行 Servlet 配置类中的 getServletMappings 方法,设定 SpringMVC 拦截请求的路径。/ 代表要拦截的请求路径,只有被拦截后才能交给 SpringMVC 来处理。
2、单次请求过程
- 发送请求 http://localhost:8080/springmvc/select 。
- web 容器发现该请求满足 SpringMVC 拦截规则,将请求交给 SpringMVC 处理。
- 解析请求路径 /select 。
- 由 /select 匹配执行对应的 select() 方法。
- 执行 select() 方法
- 检测到有 @ResponseBody 直接将 select() 方法的返回值作为响应体返回给请求方。
本文转载自: https://blog.csdn.net/Coder_Farmer/article/details/125115671
版权归原作者 qdxorigin 所有, 如有侵权,请联系我们删除。
版权归原作者 qdxorigin 所有, 如有侵权,请联系我们删除。