目录
运行流程
组件介绍
简单搭建一个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)。
1. 前端控制器:DispatcherServlet(不需要程序员开发),由框架提供,在 web.xml 中配置。 作用:统一处理请求和响应,整个流程控制的中心,由它调用其它组件处理用户的请求.
2. 处理器映射器:HandlerMapping(不需要程序员开发),由框架提供。作用:根据请求的 url 查找 Handler(处理器/Controller) 处理器适配器:
3. HandlerAdapter(不需要程序员开发),由框架提供。作用:按照特定规则(HandlerAdapter 要求的规则)去执行 Handler。
4.处理器:Handler(也称之为 Controller,需要工程师开发)。 注意:编写 Handler 时按照 HandlerAdapter 的要求去做,这样适配器才可以去正确执行 Handler
org.springframework
spring-webmvc
5.2.2.RELEASE
在web.xml中配置DispatcherServlet
application
org.springframework.web.servlet.DispatcherServlet
contextConfigLocation
classpath:spring.xml
0
application
/
@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中进行配置
characterEncodingFilter
org.springframework.web.filter.CharacterEncodingFilter
encoding
UTF-8
characterEncodingFilter
/*
如果向前端返回数据为json时 , 只需要在方法上添加 @ResponseBody 注解即可
由于类中使用了@RestController注解,其中就包含@ResponseBody,所以我们就不用重复添加。但要在项目中导入json依赖
com.fasterxml.jackson.core
jackson-databind
2.13.3
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 {
}
注册拦截器