SpringWeb
SpringWeb
SpringWeb 概述
SpringWeb特点
1.SpringWeb是spring家族原生产品,与IOC容器等基础设施无缝对接
2.基于原生的Servlet,提供了一个前端控制器DispatcherServlet,开发者无须额外开发控制器对象
3.可以自动绑定用户输入,并正确地转换数据类型
4.代码清新简洁,大幅度提升开发效率
5.内部组件化程度高,可插拔式组件即插即用
6.性能卓著,尤其适合现代大型、超大型互联网项目要求
SpringWeb运行流程
1.用户发送请求到前段控制器DispatcherServlet
2.DispatcherServlet收到请求调用HandlerMapping(处理器映射器)
3.HandlerMapping找到具体的处理器(可查找xml配置或注解配置),生成处理器对象及处理器拦截器(如果有的话),再一起返回给DispatcherServlet
4.DispatcherServlet调用HandlerAdapter(处理器适配器)
5.HandlerAdapter经过适配调用具体的处理器(Handler/Controller)
6.Controller执行完成向前端响应结果
SpringWeb组件
前端控制器:DispatcherServlet(不需要程序员开发),由框架提供,在web.xml中配置
作用:统一处理请求和响应,整个流程控制的中心,由它调用其它组件处理用户的请求
处理器映射器:HandlerMapping(不需要程序员开发),由框架提供
作用:根据请求的url查找Handler(处理器/Controller)
处理器适配器:HandlerAdapter(不需要程序员开发),由框架提供
作用:按照特定规则(HandlerAdapter要求的规则)去执行Handler
处理器:Handler(也称之为Controller,需要工程师开发)
注意编写Handler时按照HandlerAdapter的要求去做,这样适配器才可以正确执行Handler
作用:接受用户请求信息,调用业务方法处理请求,也称为后端控制器
搭建SpringWeb
导包
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>5.2.2.RELEASE</version>
</dependency>
配置DispatcherServlet
在web.xml文件中配置DispatcherServlet
配置spring核心请求分发器
<servlet>
<servlet-name>application</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:spring.xml</param-value>
</init-param>
<load-on-startup>0</load-on-startup>
</servlet>
<!-- 请求映射 -->
<servlet-mapping>
<servlet-name>application</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
开启SpringWeb注解
<mvc:annotation-driven></mvc:annotation-driven>
处理器搭建
接收请求
@RequestMapping
@RequestMapping是一个用来为处理器地址映射的注解,可用于类和方法上
作用在类上,在整个项目中不能重复,作用在方法上,整个类中不能重复
常用属性 path,value,method
path和value用来定义地址
method用来定义请求方式
@RequestMapping(vlaue="/world",method=RequestMethod.GET)
@RequestMapping(path="/world",method=RequestMethod.PUT)
获取请求数据
SpringWeb支持对多种类型的请求参数进行封装
1.使用request对象接收
@GetMapping(path = "/test")
public voidtset(HttpServletRequest request){
System.out.println(request.getParameter("num"));
}
2.spring自动封装
@RequestMapping("/save")
public void save(String userName,Integer age){
}
3.当请求参数名与形参名不一致时,可以使用@RequestParam("")进行参数绑定
@RequestMapping("/save")
public voidsave(@RequestParam("userName") String name,
@RequestParam("userAge") Integer age){
}
@RequestMapping("/save")
public void save(@RequestParam(value = "userName") String name){
}
@RequestMapping("/save")
public void save(@RequestBody Admin admin){
}
<!--jackson-->
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-databind</artifactId>
<version>2.13.3</version>
</dependency>
5.日期类型转换
属性类型为Date类型需要指定转换格式
@DateTimeFormat(pattern = "yyyy-MM-dd")
private Date birthday
返回JSON
只需要方法中返回对象即可,框架可以自动将对象转为json格式响应
@RequestMapping(path = "/login",method = RequestMethod.POST)
public Result login(@RequestBody Admin admin){
Result result = new Result(200,"登录成功",admin1);
return result;
}
拦截器

拦截器实现
添加servlet api的maven依赖
<!--servlet-->
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
<version>4.0.1</version>
<scope>provided</scope>
</dependency>
注册拦截器
<mvc:interceptors>
<mvc:interceptor>
<mvc:mapping path="/**"/>
<mvc:exclude-mapping path="/loginCtl/checklogin"/>
<bean id="demo" class="com.ffyc.ssm.util.DemoInterceptor"></bean>
</mvc:interceptor>
</mvc:interceptors>