SpringWeb

SpringWeb

SpringWeb概述

SpringWeb是Spring框架中的一部分,是对java后端web层进行了封装,和Spring框架可以无缝对接,是基于Servlet API的实现。

特点

  • 与IOC容器等无缝对接
  • 基于原生的Servlet,提供了一个前端控制器DispatcherServlet,开发者不用再开发控制器对象
  • 可以自动绑定用户输入,并正确地转换数据类型
  • 代码清新简洁,大幅度提升开发效率

运行流程

  • 用户发送请求到前端控制器 DispatcherServlet
  • DispatcherServlet 收到请求调用 HandlerMapping(处理器映射器)
  • HandlerMapping 解析请求地址,生成处理器对象及处理器拦截对象(如果有),返回给DispatcherServlet
  • DispatcherServlet 调用 HandlerAdapter(处理器适配器)
  • HandlerAdapter 经过适配调用具体的处理器(Handler/Controller)
  • Controller 执行完向前端响应结果

组件

  • 前端控制器DispatcherServlet,由框架提供,在web.xml中配置
    作用:统一处理请求和响应,整个流程的控制中心
  • 处理器映射器HandlerMapping,不需要程序员开发,由框架提供
    作用:根据请求的URL查找Controller
  • 处理适配器HandlerAdapter
    作用:按照其规则去执行Handler
  • 处理器Handler(Controller),需要程序员自己开发。
    作用:接收用户请求信息,处理请求,也称后端控制器

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

    <servlet-mapping>
        <servlet-name>spring</servlet-name>
        <url-pattern>/</url-pattern>
    </servlet-mapping>
  • 开启 SpringMVC 注解
<!--开启springweb注解-->
    <mvc:annotation-driven></mvc:annotation-driven>
  • 处理器类搭建
    @RestController 用于标记在一个类上,使用它标记的类就是一个 SpringWEB控制器类。
    Spring 配置中指定了自动扫描的 basepackage 后,Spring 会扫描这些包以及子包中的使用了@RestController 标识的类,然后将类加入到 Spring IOC 容器中,注入依赖。
    @RequestMapping 注解是一个用来处理请求地址映射的注解,可用于类或方法上。

接收数据

  • @RestController 用来标注web层的类
  • @RequestMapping(path = "/loginCtl") 可以使用在类上,也可以使用在方法上,为类或方法定义访问地址,不能重复。可以使用path也可以使用value。method 用来定义访问此方法请求方式method = RequestMethod.POST,如果定义为post请求,通过地址栏访问 报错405 方法不允许
  • @PostMapping
  • @GetMapping

获取请求数据 四种方法

  • 使用request对象接收,需要添加依赖
  <!-- https://mvnrepository.***/artifact/javax.servlet/javax.servlet-api -->
        <dependency>
            <groupId>javax.servlet</groupId>
            <artifactId>javax.servlet-api</artifactId>
            <version>4.0.1</version>
            <scope>provided</scope>
        </dependency>
 @GetMapping(path = "/login")
    public String login(HttpServletRequest request){
        System.out.println(request.getParameter("a***ount"));
        System.out.println(request.getMethod());
        System.out.println(request.getRequestURL());
        return "666";
    }
  • Spring自动封装

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

    @GetMapping(path = "/login")
    public String login(String a***ount,Integer password){
        System.out.println(a***ount);
        System.out.println(password);
        return "su***ess";
    }
  • 使用@RequestParam(“”)进行参数绑定,@RequestHeader(“”)请求头
	public String login(String a***ount,
						@RequestParam("pwd") Integer password,
						@@RequestHeader("User-Agent") String UserAgent){
        System.out.println(a***ount);
        System.out.println(password);
        return "su***ess";
    }
  • 使用实体类对象接收
    @PostMapping(path = "/login")
    public ***monResult login(@RequestBody Admin admin) {
        System.out.println(admin.getA***ount());
        System.out.println(admin.getPassword());
        Admin a = loginService.login(admin);
        return "su***ess";
    }

返回json

当请求参数为json时,参数列表必须用一个类来接收,需要在前面添加@RequestBody

如果前端传递内容为 json 格式 使用@RequestBody 将 Json 字符串转换为后端 Java 对象

 	@PostMapping(path = "/login")
    public ***monResult login(@RequestBody Admin admin) {
        System.out.println(admin.getA***ount());
        System.out.println(admin.getPassword());
        Admin a = new Admin();
        ***monResult ***monResult = new ***monResult(200, a, "登录成功");
        return ***monResult;//springweb中,自动返回一个对象,可以自动将对象转化为json
    }

但是必须在项目中导入相应的转 json 组件才可以直接将响应的对象转为 json

<!--jackson-->
        <dependency>
            <groupId>***.fasterxml.jackson.core</groupId>
            <artifactId>jackson-databind</artifactId>
            <version>2.14.2</version>
        </dependency>

属性类型为 Date 类型需要指定转换格式

@DateTimeFormat(pattern = "yyyy-MM-dd")
private Date birthday

中文乱码处理

SpringWeb为我们提供了过滤器,在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>

拦截器

Spring中的拦截器是 spring 中定义的一种拦截机制, 是对进入到处理器的请求进行拦截实现。

  1. 编写一个类,继承 HandlerInterceptorAdapter

当请求到达控制器之前被执行
true–继续向下执行,到达下一个拦截器,或控制器
false–不会继续向下执行

ublic class DemoInterceptor implements HandlerInterceptor {

    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        System.out.println("进入到拦截器");
        return true;
    }
}
  1. 注册拦截器
 <!--拦截器配置-->
    <mvc:interceptors>
        <mvc:interceptor>
            <mvc:mapping path="/**"/>
            <mvc:exclude-mapping path="/loginCtl/login"/><!--不进入拦截器的地址-->
            <mvc:exclude-mapping path="/loginCtl/test2"/>
            <bean class="***.ffyc.ssm.util.DemoInterceptor"></bean>
        </mvc:interceptor>
    </mvc:interceptors>
转载请说明出处内容投诉
CSS教程_站长资源网 » SpringWeb

发表评论

欢迎 访客 发表评论

一个令你着迷的主题!

查看演示 官网购买