JavaWeb开发_Day05

发布于:2025-08-16 ⋅ 阅读:(16) ⋅ 点赞:(0)

参考课程:

黑马程序员 JavaWeb开发教程】

[https://www.bilibili.com/video/BV1m84y1w7Tb]

@ZZHow(ZZHow1024)

请求响应概述

  • 概述
    • 请求(HttpServletRequest):获取请求数据
    • 响应(HttpServletResponse):设置响应数据
    • BS 架构:Browser / Server,浏览器/服务器架构模式。客户端只需要浏览器,应用程序的逻辑和数据都存储在服务端。(维护方便 体验一般)
    • CS 架构:Client / Server,客户端/服务器架构模式。(开发、维护麻烦
      体验不错)
  • Postman
    • 简介:Postman 是一款功能强大的网页调试与发送网页 HTTP 请求的 Chrome 插件。
    • 作用:常用于进行接口测试。

请求

  • 简单参数的接收

    请求:http://localhost:8080/simpleParam?name=Tom&age=10

    • 原始方式

      在原始的 Web 程序中,获取请求参数,需要通过 HttpServletRequest 对象手动获取。

      @RequestMapping("/simpleParam")
      public String simpleParam(HttpServletRequest request)
      	String name = request.getParameter("name");
      	String ageStr = request.getParameter("age");
      
      	int age = Integer.parselnt(ageStr);
      
      	system.outprintln(name + " : " + age);
      
      	return "OK";
      }
      
    • SpringBoot 方式

      参数名与形参变量名相同,定义形参即可接收参数。

      @RequestMapping("/simpleParam")
      public String simpleParam(String name, Integer age) {
      	System.out.println(name + " : " + age);
      
      	return "OK";
      }
      
    • @RequestParam 注解

      如果方法形参名称与请求参数名称不匹配,可以使用 @RequestParam 完成映射。

      @RequestMapping("/simpleParam")
      public String simpleParam(@RequestParam(name = "name") String username, Integer age) {
      	System.out.println(username + " : " + age);
      
      	return "OK";
      }
      
      • @RequestParam 中的 required 属性默认为 true,代表该请求参数必须传递,如果不传递将报错。如果该参数是可选的,可以将 required 属性设置为 false。
  • 实体参数的接收

    • 简单实体对象:请求参数名与形参对象属性名相同,定义 POJO 接收即可。

      请求:http://localhost:8080/simplePojo?name=Tom&age=10

      @RequestMapping("/simplePojo")
      public String simplePojo(User user) {
      	System.out.println(user);
      
      	return "OK";
      }
      
      public class User {
      	private String name;
      	private Integer age;
      }
      
    • 复杂实体对象:请求参数名与形参对象属性名相同,按照对象层次结构关系即可接收嵌套 POJO 属性参数。

      请求:http://localhost:8080/complexPojo?name=Tom&age=10&address.province=beijing&address.city=beijing

      @RequestMapping("/complexPojo")
      public String complexPojo(User user) {
      	System.out.println(user);
      
      	return "OK";
      }
      
      @RequestMapping("/complexPojo")
      public String complexPojo(User user) {
      	System.out.println(user);
      
      	return "OK";
      }
      
      public class Address {
      	private String province;
      	private String city;
      }
      
  • 数组参数的接收

    请求:http://localhost:8080/arrayParam?hobby=game&hobby=java

    • 使用数组接收

      数组参数:请求参数名与形参数组名称相同且请求参数为多个,定义数组类型形参即可接收参数。

      @RequestMapping("/arrayParam")
      public String arrayParam(String[] hobby) {
      	System.out.println(Arrays.toString(hobby));
      
      	return "OK";
      }
      
    • 使用集合接收

      集合参数:请求参数名与形参集合名称相同且请求参数为多个,@RequestParam
      绑定参数关系

      @RequestMapping("/listParam")
      public String listParam(@RequestParam List<String> hobby) {
      	System.out.println(hobby);
      
      	return "OK";
      }
      
  • 日期参数的接收

    请求:http://localhost:8080/dateParam?updateTime=2022-12-12 10:05:45

    日期参数:使用 @DateTimeFormat 注解完成日期参数格式转换

    @RequestMapping("/dateParam")
    public string dateParam(@DateTimeFormat(pattern="y//-MM-dd HH:mms")LocalDateTime updatefime) {
    	System.outprintln(updateTime);
    
    	return "OK";
    }
    
  • JSON 参数的接收

    请求:http://localhost:8080/jsonParam

    请求体:

    {
    	"name": "Tom",
    	"age": 10,
    	"address": {
    		"province": "beijing",
    		"city": "beijing"
    	}
    }
    

    JSON 参数:JSON 数据键名与形参对象属性名相同,定义 POJO 类型形参即可接收参数,需要使用 @RequestBody 标识

    @RequestMapping("/jsonParam")
    public String jsonParam(@RequestBody User user) {
    	System.out.println(user);
    
    	return "OK";
    }
    
    public class User {
    	private String name;
    	private Integer age;
    	private Address address;
    }
    
    public class Address {
    	private String province;
    	private String city;
    }
    
  • 路径参数的接收

    请求:http://localhost:8080/path/1

    路径参数:通过请求 URL 直接传递参数,使用 {…} 来标识该路径参数,需要使用 @PathVariable 获取路径参数。

    • 单个路径参数的接收
    @RequestMapping("/path/{id}")
    public String pathParam(@PathVariable Integer id) {
    	System.outprintln(id);
    
    	return "OK";
    }
    
    • 多个路径参数的接收
    @RequestMapping("/path/{id}/{name}")
    public String pathParam2(@PathVariable Integer id, @PathVariable String name) {
    	System.out.println(id + ": " + name);
    
    	return "ok";
    }
    

响应

  • @ResponseBody 注解

    • 类型:方法注解、类注解。
    • 位置:Controller 方法上/类上。
    • 作用:将方法返回值直接响应,如果返回值类型是 实体对象/集合,将会转换为 JSON 格式响应。
    • 说明:@RestController = @Controller + @ResponseBody;
  • 统一响应结果

    • Result(code、msg、data)
    public class Result {
    	//响应码,1 代表成功;0 代表失败
    	private Integer code;
    	//提示信息
    	private String msg;
    	//返回的数据
    	private Object data;
    	//......
    }
    
  • 静态资源:Springboot 项目的静态资源(HTML, CSS, JavaScript 等前端资源)默认存放目录为:classpath:/static、classpath:/public、classpath:/resources

分层解耦

  • 三层架构

    • Controller:控制层,接收前端发送的请求,对请求进行处理,并响应数据。
    • Service:业务逻辑层,处理具体的业务逻辑。
    • Dao:数据访问层(Data Access Object)(持久层),负责数据访问操作,包括数据的增、删、改、查。
  • 分层解耦

    • 内聚:软件中各个功能模块内部的功能联系。
    • 耦合:衡量软件中各个层/模块之间的依赖、关联的程度。
    • 软件设计原则:高内聚低耦合。
    • 控制反转:Inversion Of Control,简称 IOC。对象的创建控制权由程序自身转移到外部(容器),这种思想称为控制反转。
    • 依赖注入:Dependency Injection,简称 DI。容器为应用程序提供运行时,所依赖的资源,称之为依赖注入。
    • Bean 对象:IOC 容器中创建、管理的对象,称之为 bean。
  • IOC & DI 入门

    • 步骤:
      • Service 层及 Dao 层的实现类,交给 IOC 容器管理。
        • 在实现类上添加 @Component 注解。
      • 为 Controller 及 Service 注入运行时,依赖的对象。
        • 在成员变量上添加 @Autowired 注解。
      • 运行测试。
  • IOC 详解

    • Bean 的声明

      要把某个对象交给 IOC 容器管理,需要在对应的类上加上如下注解之一:

      注解 说明 位置
      @Component 声明 Bean 的基础注解 不属于以下三类时,用此注解
      @Controller @Component 的衍生注解 标注在控制器类上
      @Service @Component 的衍生注解 标注在业务类上
      @Repository @Component 的衍生注解 标注在数据访问类上(由于与 MyBatis 整合,用的少)
    • Bean 组件扫描
      • 前面声明 Bean 的四大注解,要想生效,还需要被组件扫描注解 @ComponentScan 扫描。
      • @ComponentScan 注解虽然没有显式配置,但是实际上已经包含在了启动类声明注解 @SpringBootApplication 中,默认扫描的范围是启动类所在包及其子包。
  • DI 详解

    • @Autowired 注解,默认是按照类型进行,如果存在多个相同类型的 Bean,将会报错。
    • 通过以下几种方案来解决:
      • 在希望注入的 Bean 上添加 @Primary 注解。
      • @Autowired + @Qualifier(“Bean 的名称”)
      • @Resource(name = “Bean 的名称”)
    • @Resource 与 @Autowired区别
      • @Autowired 是 Spring 框架提供的注解,而 @Resource 是 JDK 提供的注解。
      • @Autowired 默认按照类型注入,而 @Resource 默认按照名称注入。

网站公告

今日签到

点亮在社区的每一天
去签到