参考课程:
【黑马程序员 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 对象手动获取。
java@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 方式
参数名与形参变量名相同,定义形参即可接收参数。
java@RequestMapping("/simpleParam") public String simpleParam(String name, Integer age) { System.out.println(name + " : " + age); return "OK"; }
-
@RequestParam 注解
如果方法形参名称与请求参数名称不匹配,可以使用 @RequestParam 完成映射。
java@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
java@RequestMapping("/simplePojo") public String simplePojo(User user) { System.out.println(user); return "OK"; }
javapublic class User { private String name; private Integer age; }
-
复杂实体对象:请求参数名与形参对象属性名相同,按照对象层次结构关系即可接收嵌套 POJO 属性参数。
请求:http://localhost:8080/complexPojo?name=Tom\&age=10\&address.province=beijing\&address.city=beijing
java@RequestMapping("/complexPojo") public String complexPojo(User user) { System.out.println(user); return "OK"; }
java@RequestMapping("/complexPojo") public String complexPojo(User user) { System.out.println(user); return "OK"; }
javapublic class Address { private String province; private String city; }
-
-
数组参数的接收
请求:http://localhost:8080/arrayParam?hobby=game\&hobby=java
-
使用数组接收
数组参数:请求参数名与形参数组名称相同且请求参数为多个,定义数组类型形参即可接收参数。
java@RequestMapping("/arrayParam") public String arrayParam(String[] hobby) { System.out.println(Arrays.toString(hobby)); return "OK"; }
-
使用集合接收
集合参数:请求参数名与形参集合名称相同且请求参数为多个,@RequestParam
绑定参数关系
java@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 注解完成日期参数格式转换
java@RequestMapping("/dateParam") public string dateParam(@DateTimeFormat(pattern="y//-MM-dd HH:mms")LocalDateTime updatefime) { System.outprintln(updateTime); return "OK"; }
-
JSON 参数的接收
请求:http://localhost:8080/jsonParam
请求体:
json{ "name": "Tom", "age": 10, "address": { "province": "beijing", "city": "beijing" } }
JSON 参数:JSON 数据键名与形参对象属性名相同,定义 POJO 类型形参即可接收参数,需要使用 @RequestBody 标识
java@RequestMapping("/jsonParam") public String jsonParam(@RequestBody User user) { System.out.println(user); return "OK"; }
javapublic class User { private String name; private Integer age; private Address address; }
javapublic class Address { private String province; private String city; }
-
路径参数的接收
请求:http://localhost:8080/path/1
路径参数:通过请求 URL 直接传递参数,使用 {...} 来标识该路径参数,需要使用 @PathVariable 获取路径参数。
- 单个路径参数的接收
java@RequestMapping("/path/{id}") public String pathParam(@PathVariable Integer id) { System.outprintln(id); return "OK"; }
- 多个路径参数的接收
java@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)
javapublic 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)(持久层),负责数据访问操作,包括数据的增、删、改、查。
-
分层解耦
- 内聚:软件中各个功能模块内部的功能联系。
- 耦合:衡量软件中各个层/模块之间的依赖、关联的程度。
- 软件设计原则:高内聚低耦合。
- 控制反转:I nversion O f Control,简称 IOC。对象的创建控制权由程序自身转移到外部(容器),这种思想称为控制反转。
- 依赖注入:D ependency Injection,简称 DI。容器为应用程序提供运行时,所依赖的资源,称之为依赖注入。
- Bean 对象:IOC 容器中创建、管理的对象,称之为 bean。
-
IOC & DI 入门
- 步骤:
- Service 层及 Dao 层的实现类,交给 IOC 容器管理。
- 在实现类上添加 @Component 注解。
- 为 Controller 及 Service 注入运行时,依赖的对象。
- 在成员变量上添加 @Autowired 注解。
- 运行测试。
- Service 层及 Dao 层的实现类,交给 IOC 容器管理。
- 步骤:
-
IOC 详解
-
Bean 的声明
要把某个对象交给 IOC 容器管理,需要在对应的类上加上如下注解之一:
注解 说明 位置 @Component 声明 Bean 的基础注解 不属于以下三类时,用此注解 @Controller @Component 的衍生注解 标注在控制器类上 @Service @Component 的衍生注解 标注在业务类上 @Repository @Component 的衍生注解 标注在数据访问类上(由于与 MyBatis 整合,用的少)
| 💡 注意事项
| * 声明 Bean 的时候,可以通过 value 属性指定 Bean 的名字,如果没有指定,默认为类名首字母小写。
| * 使用以上四个注解都可以声明 Bean,但是在 SpringBoot 集成 Web 开发中,声明控制器 Bean 只能用 @Controller。- Bean 组件扫描
- 前面声明 Bean 的四大注解,要想生效,还需要被组件扫描注解 @ComponentScan 扫描。
- @ComponentScan 注解虽然没有显式配置,但是实际上已经包含在了启动类声明注解 @SpringBootApplication 中,默认扫描的范围是启动类所在包及其子包。
-
-
DI 详解
- @Autowired 注解,默认是按照类型进行,如果存在多个相同类型的 Bean,将会报错。
- 通过以下几种方案来解决:
- 在希望注入的 Bean 上添加 @Primary 注解。
- @Autowired + @Qualifier("Bean 的名称")
- @Resource(name = "Bean 的名称")
- @Resource 与 @Autowired区别
- @Autowired 是 Spring 框架提供的注解,而 @Resource 是 JDK 提供的注解。
- @Autowired 默认按照类型注入,而 @Resource 默认按照名称注入。