如图所示,SpringMVC负责表述层(控制层Controller)实现简化!
SpringMVC的作用主要覆盖的是表述层,例如:
以下做个对比:
原生Servlet开发:
//重写一个doGet方法
protected void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
//request方法拉取前端传来的参数
String userName = request.getParameter("userName");
//response对象写出参数到前端
System.out.println("userName="+userName);
}
基于SpringMVC开发:
//通过@RequestMapping注解,完成路径对外的暴露,外部只要请求这个地址,就调用这个方法
@RequestMapping("/user/login")
//不需要request拉取,直接在形参列表中就可以拿到前端传来的参数
public String loginHandle(@RequestParam("userName") String userName,Sting password){
//调用业务即可
log.debug("userName="+userName);
//处理完后,返回一个对象包给前端解析
return "result";
}
SpringMVC涉及组件理解:
依赖如下,也更改了Properties,将Version提级管理:
<properties>
<spring.version>6.0.6</spring.version>
<servlet.api>9.1.0</servlet.api>
<maven.compiler.source>17</maven.compiler.source>
<maven.compiler.target>17</maven.compiler.target>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>
<dependencies>
<!-- springioc相关依赖 -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>${spring.version}</version>
</dependency>
<!-- web相关依赖 -->
<!-- 在 pom.xml 中引入 Jakarta EE Web API 的依赖 -->
<!--
在 Spring Web MVC 6 中,Servlet API 迁移到了 Jakarta EE API,因此在配置 DispatcherServlet 时需要使用
Jakarta EE 提供的相应类库和命名空间。错误信息 “‘org.springframework.web.servlet.DispatcherServlet’
is not assignable to ‘javax.servlet.Servlet,jakarta.servlet.Servlet’” 表明你使用了旧版本的
Servlet API,没有更新到 Jakarta EE 规范。
-->
<dependency>
<groupId>jakarta.platform</groupId>
<artifactId>jakarta.jakartaee-web-api</artifactId>
<version>${servlet.api}</version>
<scope>provided</scope>
</dependency>
<!-- springwebmvc相关依赖 -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>${spring.version}</version>
</dependency>
</dependencies>
新建一个子工程, 然后转成JBLJavaToWeb插件转成Web工程.
Controller声明
package com.sunsplanter.Controller;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
//声明为Controller类型的Bean对象,纳入IoC容器管理
@Controller
public class HelloController {
//handlers
/**
* handler就是controller内部的具体方法
* @RequestMapping("/springmvc/hello") 本handler的地址是/springmvc/hello.即外部的访问地址
* @ResponseBody 代表向浏览器直接返回数据,不找视图解析器!
*/
@RequestMapping("/springmvc/hello")
@ResponseBody
public String hello(){
System.out.println("HelloController.hello");
return "hello springmvc!!";
}
}
回顾开头要干的三个配置,我们是一个也没干.在config包下新建一个WebMvcIconfig类负责:
package com.sunsplanter.config;
//*TODO: SpringMVC对应组件的配置类 [声明SpringMVC需要的组件信息]
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.HandlerAdapter;
import org.springframework.web.servlet.HandlerMapping;
import org.springframework.web.servlet.config.annotation.EnableWebMvc;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
import org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter;
import org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping;
//*TODO: 导入handlerMapping和handlerAdapter的三种方式
//*1.自动导入handlerMapping和handlerAdapter [推荐]
//*2.可以不添加,springmvc会检查是否配置handlerMapping和handlerAdapter,没有配置默认加载
//*3.使用@Bean方式配置handlerMapper和handlerAdapter
@EnableWebMvc
@Configuration
//干的第一件事
@ComponentScan(basePackages = "com.sunsplanter.controller") //
//WebMvcConfigurer springMvc进行组件配置的规范,配置组件,提供各种方法! 前期可以实现
public class WebMvcConfig implements WebMvcConfigurer {
//干的第二件事
@Bean
public HandlerMapping handlerMapping(){
return new RequestMappingHandlerMapping();
}
@Bean
public HandlerAdapter handlerAdapter(){
return new RequestMappingHandlerAdapter();
}
}