目录
系列文章
Java Web开发_异步处理以及前端中Vue框架的简单使用(Day3)
Java Web开发_Maven以及SpringBootWeb入门(Day4)
前言
此博客主要记录在学习黑马程序员2023版JavaWeb开发课程的一些笔记,方便总结以及复习。
一、请求
在之前的学习当中,我们学到过,当前最为主流的开发模式便是前后端分离开发。
那么在接口测试的时候我们会使用的工具一般是Postman、Apipost、Apifox等工具。
现在这里我们使用的便是Postman:一款功能强大的网页调试与发送网页HTTP请求的Chrome插件。官网:Postman
在官网上下载安装最新版即可,点开注册账号即可使用。一般是点开workspace工作台开始调试。
1、简单参数:定义方法形参,请求参数名与形参变量名一致。如果不一致,通过@RequestParam手动映射。
2、实体参数:请求参数名,与实体对象的属性名一致,会自动接收封装。
3、数组集合参数:数组:请求参数名与数组名一致,直接封装;集合:请求参数名与集合名一致,@RequestParam绑定关系。
4、日期参数:@DateTimeFormat
5、JSON参数:@RequestBody
6、路径参数:@PathVariable
二、响应
@ResponseBody:
- 类型:方法注解、类注解
- 位置:Controller方法上/类上
- 作用:将方法返回值直接响应,如果返回值类型是 实体对象/集合 ,将会转换为JSON格式响应
- 说明:@RestController = @Controller + @ResponseBody 。
在我们响应的内容里面返回的值也不要说有的是数组,有的字符串,有的是集合,多样多式不便于管理维护。我们可以统一规范定义一个响应结果。
public class Result {
//响应码,1 代表成功; 0 代表失败
private Integer code;
//提示信息
private String msg;
//返回的数据
private Object data;
//…
}
三、分层解耦
三层架构
这样把响应的信息一个注释一个内容全部写在一个函数里面,能够很好地完成需求功能,但是呢,复用性差,难以维护,如果功能较多的话,维护起来便很繁琐困难。我们可以将他拆分开来,通常会分成三层架构:
- controller:控制层,接收前端发送的请求,对请求进行处理,并响应数据。
- service:业务逻辑层,处理具体的业务逻辑。
- dao:数据访问层(Data Access Object)(持久层),负责数据访问操作,包括数据的增、删、改、查。
这样就能很好地解决刚才提到的问题,复用性增强,便于维护,利于拓展。
分层解耦
内聚:软件中各个功能模块内部的功能联系。
耦合:衡量软件中各个层/模块之间的依赖、关联的程度。
软件设计原则:高内聚低耦合。意思就是说我们尽量地让每个层与模块之间的依赖程度降低,尽量减少说这个代码出问题了导致其他的代码文件也一起出错。我们的解决办法一般就是控制反转以及依赖注入。
控制反转: Inversion Of Control,简称IOC。对象的创建控制权由程序自身转移到外部(容器),这种思想称为控制反转。
Bean的声明:要把某个对象交给IOC容器管理,需要在对应的类上加上如下注解之一:
声明bean的时候,可以通过value属性指定bean的名字,如果没有指定,默认为类名首字母小写。使用以上四个注解都可以声明bean,但是在springboot集成web开发中,声明控制器bean只能用@Controller。
依赖注入: Dependency Injection,简称DI。容器为应用程序提供运行时,所依赖的资源,称之为依赖注入。
Bean对象:IOC容器中创建、管理的对象,称之为bean。
Bean组件扫描:bean的注解要想生效,还需要被组件扫描注解@ComponentScan扫描。@ComponentScan注解虽然没有显式配置,但是实际上已经包含在了启动类声明注解、 @SpringBootApplication 中,默认扫描的范围是启动类所在包及其子包。
@Autowired注解,默认是按照类型进行,如果存在多个相同类型的bean,将会报出错误。可以通过以下三种方案来解决:@Primary(在bean中标注出优先选择的)、@Qualifier(Autowired中选择确定的名字,即@Autowired + @Qualifier("bean的名称"))、@Resource(JDK提供的注解,按照名称注入bean)。
小结
这节主要讲解了请求响应的简单示范,更偏向于实际的业务逻辑的学习,算是真正入门的一节课。