目录
运行流程
组件介绍
简单搭建一个SpringWeb项目
1.导入依赖
2.配置DispatcherServlet
3.开启注解
4.处理器搭建
5.接收请求
获取请求的数据
中文乱码
返回json格式
拦截器
代码实现
SpringWeb 是 spring 框架中的一个模块,基于 Servlet API 构建的原始 web 框架,在现在前后端分离开发中,多用于SpringWeb,MVC架构已经被慢慢淘汰掉了。
在 web 层框架历经 Strust1,WebWork,Strust2 等诸多产品的历代更选 之后,目前业界普遍选择了springWeb作为 Java EE 项目 web 层开发的首选方案。以前的ssm(spring struts2 mybatis)和ssh(spring struts2 hibernate),而现在的ssm指的是(spring springweb mybatis)。
运行流程
- 用户发出请求到前端的控制器DispatcherServlet
- DispatcherServlet收到请求后调用HandlerMapping(处理器映射器)
- HandlerMapping找到具体的处理器(查找xml或者注解),生成处理器拦截器(如果有的话),再一起返回给DispatcherServlet
- DispatcherServlet再调用HandlerAdapter(处理器适配器)
- HandlerAdapter找到具体的适配器(Controller)
- Controller完成响应
组件介绍
1. 前端控制器:DispatcherServlet(不需要程序员开发),由框架提供,在 web.xml 中配置。 作用:统一处理请求和响应,整个流程控制的中心,由它调用其它组件处理用户的请求.
2. 处理器映射器:HandlerMapping(不需要程序员开发),由框架提供。作用:根据请求的 url 查找 Handler(处理器/Controller) 处理器适配器:
3. HandlerAdapter(不需要程序员开发),由框架提供。作用:按照特定规则(HandlerAdapter 要求的规则)去执行 Handler。
4.处理器:Handler(也称之为 Controller,需要工程师开发)。 注意:编写 Handler 时按照 HandlerAdapter 的要求去做,这样适配器才可以去正确执行 Handler
简单搭建一个SpringWeb项目
1.导入依赖
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>5.2.2.RELEASE</version>
</dependency>
2.配置DispatcherServlet
在web.xml中配置DispatcherServlet
<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>
3.开启注解
<mvc:annotation-driven></mvc:annotation-driven>
4.处理器搭建
- @RestController 用于标记在一个类上,使用它标记的类就是一个 SpringWEB 控制器类,spring在扫描完包后,将该类加入IOC容器中,注入依赖
- @RequestMapping 注解是一个用来处理请求地址映射的注解,可用于类或方法上
5.接收请求
@RequestMapping 是一个用来为处理器地址映射的注解,可用于类或方法上. 作用在类上,在整个项目中不能重复,作用在方法上,整个类中不能重复.常用属性有:
path和value来指定路径
method指定请求的方法(post或get)
获取请求的数据
1.使用request对象接收
@GetMapping(path = "/test")
public voidtset(HttpServletRequest request){
System.out.println(request.getParameter("id"));
}
注意到导入相关的servlet依赖
2.spring自动封装
@GetMapping(path = "/test1")
public String login(String account,String password) {
return "msg";
}
处理器接收参数的形参名称必须 和表单的 name 属性保持一致,否则会接收失败
3. 使用@RequestParam("")进行参数绑定,@RequestHeader("")
@GetMapping(path = "/test1")
public String login(String account,
@RequestParam(value = "pwd",required = true,defaultValue = "111")String password,
@RequestHeader("User-Agent") String UserAgent) {
return "msg";
}
required:参数是否必须。代表页面是否必须传递该参数。如果该值为 true,但没有传递参数,会报错。
defaultValue:默认值。代表如果页面没有传递该参数,使用 defaultValue 的值代替
4.使用实体类
@RequestMapping("/save")
public void save(Admin admin){
}
5.属性类型为data的要进行格式化
@DateTimeFormat(pattern = "yyyy-MM-dd")
private Date birthday;
中文乱码
在web.xml中进行配置
<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>
返回json格式
如果向前端返回数据为json时 , 只需要在方法上添加 @ResponseBody 注解即可
由于类中使用了@RestController注解,其中就包含@ResponseBody,所以我们就不用重复添加。但要在项目中导入json依赖
<!--jackson-->
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-databind</artifactId>
<version>2.13.3</version>
</dependency>
拦截器
Spring WEB 中的拦截器(Interceptor)类似于 Servlet 中的过滤器(Filter),它主要用于拦截用户请求并作相应的处理。
两者区别:
过滤器是 servlet 规范中定义并实 现的,在进入到 servlet 之前截获请求
拦截器是 spring 中定义的一种拦截机制, 是对进入到处理器的请求进行拦截
代码实现
编写一个类,继承 HandlerInterceptorAdapte
public class DemoInterceptor implements HandlerInterceptor{
/* 当请求到达控制器之前被执行
true--继续向下执行,到达下一个拦截器,或控制器
false--不会继续向下执行*/
public boolean preHandle(HttpServletRequest request, HttpServletResponse
response, Object handler)throws Exception {
}
注册拦截器
<mvc:interceptors>
<mvc:interceptor>
<mvc:mapping path="/**"/>
<mvc:exclude-mapping path="/statics/**"/>
<mvc:exclude-mapping path="/loginCtl/checklogin"/>
<bean id="demo" class="com.ff.springMVC.util.DemoInterceptor"></bean>
</mvc:interceptor>
</mvc:interceptors>