SpringWeb

目录

SpringWeb概述

SpringWeb特点

SpringWeb运行流程

SpringWeb组件

前端控制器

作用

处理器映射器

处理器适配器

处理器

搭建SpringWeb

导包

配置DispatcherServelt

开启SpringWeb注解

处理器类搭建

接收请求

@RequestMapping

获取请求数据

返回JSON

拦截器

拦截器实现


SpringWeb概述

SpringWeb 是 spring 框架中的一个模块,基于 Servlet API 构建的 web 框架. springWeb 是Spring 为 web 层开发提供的一整套完备的解决方案。在 web 层框架历经 Strust1,WebWork,Strust2 等诸多产品的历代更选之后,目前业界普遍选择了 springWeb 作为 Java EE 项目 web 层开发的首选方案。

SpringWeb特点

SpringWEB 是 spring 家族原生产品,与 IOC 容器等基础设施无缝对接.

基于原生的 Servlet,提供了一个前端控制器 DispatcherServlet ,开发者无须额外开发控制器对象.

可以自动绑定用户输入,并正确地转换数据类型.

代码清新简洁,大幅度提升开发效率.

内部组件化程度高,可插拔式组件即插即用.

性能卓著,尤其适合现代大型、超大型互联网项目要求.

SpringWeb运行流程

用户发送出请求到前端控制器 DispatcherServlet。

DispatcherServlet 收到请求调用 HandlerMapping(处理器映射器)。

HandlerMapping 找到具体的处理器(可查找 xml 配置或注解配置),生成处理器对象及处理器拦截器(如果有),再一起返回给 DispatcherServlet。

DispatcherServlet 调用 HandlerAdapter(处理器适配器)。

HandlerAdapter 经过适配调用具体的处理器(Handler/Controller)。

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>

配置DispatcherServelt

在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注解

开启springweb注解

<mvc:annotation-driven></mvc:annotation-driven>

处理器类搭建

@RestController 用于标记在一个类上,使用它标记的类就是一个 SpringWEB控制器类.

Spring 配置中指定了自动扫描的 basepackage 后,Spring 会扫描这些包以及子包中的使用了@RestController 标识的类,然后将类加入到 Spring IOC 容器中,注入依赖。

@RequestMapping 注解是一个用来处理请求地址映射的注解,可用于类或方法上。

接收请求

@RequestMapping

@RequestMapping 是一个用来为处理器地址映射的注解,可用于类或方法上.作用在类上,在整个项目中不能重复,作用在方法上,整个类中不能重复.

常用属性 path,value,method.

path 和 value 用来定义地址

method 用来定义请求方式

@RequestMapping(value = "/hello",method = RequestMethod.GET)

@RequestMapping(path= "/hello",method = RequestMethod.POST)

获取请求数据

SpringWEB支持对多种类型的请求参数进行封装

1.使用request对象接收

@GetMapping(path = "/test") 
public void tset(HttpServletRequest request){ 
    System.out.println(request.getParameter("num")); 
}

在处理中如果需要使用到 HttpServletRequest 对象只需要定义即可 

2.spring自动封装

@RequestMapping("/save") 
public void save(String userName,Integer age){ 
}

Spring 会自定进行数据封装,这里要注意的是,处理器接收参数的形参名称必须和表单的 name 属性保持一致,否则会接收失败!

3.当请求参数名与形参名不一致时,可以使用@RequestParam("")进行参数绑定.

@RequestMapping("/save") 
public void save(@RequestParam("userName") String name, 
                @RequestParam("userAge") Integer age){ 
}

表单的 name 和控制器的形参并不一致,但是@RequestParam 注解的 value值必须和表单的 name 保持一致。

@RequestMapping("/save") 
public void save(@RequestParam(value = "userName") String name){ 
}

@RequestHeader("")用来接收请求中的数据.

@RequestHeader("user-agent") 可以用来接收请求头中的数据

4.使用实体类对象接收

@RequestBody 可以接收前端提交的 json 格式数据,将 json 格式封装到对象中.

@RequestMapping("/save") 
public void save(@RequestBody Admin admin){ 
}

需要添加json转换组件

<!--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; 
}

响应结果

 

拦截器

Spring WEB 中的拦截器(Interceptor)类似于 Servlet 中的过滤器(Filter),它主要用于拦截用户请求并作相应的处理。

Spring 中的拦截器与过滤器有着本质的区别,过滤器是 servlet 规范中定义并实现的,在进入到 servlet 之前截获请求.而拦截器是 spring 中定义的一种拦截机制,是对进入到处理器的请求进行拦截.

SpringWEB 定义了拦截器接口 HandlerInterceptor调用这个三个方法的时候,其参数的值也是从框架内部传递进来的。

boolean preHandle

预处理方法,实现处理器方法的预处理,就是在处理器方法执行之前这个方法会被执行,相当于拦截了处理器方法,框架会传递请求和响应对象给该方法,第三个参数为被拦截的处理器。如果 preHandle 方法返回 true 表示继续流程(如调用下一个拦截器或处理器方法),返回 false 表示流程中断,不会继续调用其他的拦截器或处理器方法,此时我们需要通过 response 来产生响应;

拦截器实现

添加servlet api依赖

<!--servlet--> 
<dependency> 
    <groupId>javax.servlet</groupId> 
    <artifactId>javax.servlet-api</artifactId> 
    <version>4.0.1</version> 
    <scope>provided</scope> 
</dependency>

编写一个类,继承HandlerInterceptorAdapter

public class DemoInterceptor implements HandlerInterceptor{ 
/* 
当请求到达控制器之前被执行 
true--继续向下执行,到达下一个拦截器,或控制器 
false--不会继续向下执行 
*/ 
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler)throws Exception { 
    System.out.println("之前执行"); 
    return false; 
}

注册拦截器

<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>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值