目录
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
- <dependency>
- <groupId>org.springframeworkgroupId>
- <artifactId>spring-webmvcartifactId>
- <version>5.2.2.RELEASEversion>
- dependency>
在web.xml中配置DispatcherServlet
- <servlet>
- <servlet-name>applicationservlet-name>
- <servlet-class>org.springframework.web.servlet.DispatcherServletservlet-class>
- <init-param>
- <param-name>contextConfigLocationparam-name>
- <param-value>classpath:spring.xmlparam-value>
- init-param>
- <load-on-startup>0load-on-startup>
- servlet>
- <servlet-mapping>
- <servlet-name>applicationservlet-name>
- <url-pattern>/url-pattern>
- servlet-mapping>
<mvc:annotation-driven>mvc:annotation-driven>
@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>characterEncodingFilterfilter-name>
- <filter-class>org.springframework.web.filter.CharacterEncodingFilterfilter-class>
- <init-param>
- <param-name>encodingparam-name>
- <param-value>UTF-8param-value>
- init-param>
- filter>
- <filter-mapping>
- <filter-name>characterEncodingFilterfilter-name>
- <url-pattern>/*url-pattern>
- filter-mapping>
如果向前端返回数据为json时 , 只需要在方法上添加 @ResponseBody 注解即可

由于类中使用了@RestController注解,其中就包含@ResponseBody,所以我们就不用重复添加。但要在项目中导入json依赖
- <dependency>
- <groupId>com.fasterxml.jackson.coregroupId>
- <artifactId>jackson-databindartifactId>
- <version>2.13.3version>
- 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 {
-
- }
注册拦截器
-
-
"/**"/> -
"/statics/**"/> -
"/loginCtl/checklogin"/> -
"demo" class="com.ff.springMVC.util.DemoInterceptor"> -