10.3学习

1.循环依赖

循环依赖其实就是循环引用,也就是两个或者两个以上的 Bean 互相持有对方,最终形成闭环。比如A 依赖于B,B又依赖于A

Spring中循环依赖场景有:

prototype 原型 bean循环依赖

构造器的循环依赖(构造器注入)

Field 属性的循环依赖(set注入)

其中,构造器的循环依赖问题无法解决,在解决属性循环依赖时,可以使用懒加载,spring采用的是提前暴露对象的方法。

2.三级缓存解决循环依赖问题

①Spring容器初始化ClassA通过构造器初始化对象后提前暴露到Spring容器中的singletonFactorys(三级缓存中)。

②ClassA调用setClassB方法,Spring首先尝试从容器中获取ClassB,此时ClassB不存在Spring 容器中。

③Spring容器初始化ClassB,ClasssB首先将自己暴露在三级缓存中,然后从Spring容器一级、二级、三级缓存中一次中获取ClassA 。

④获取到ClassA后将自己实例化放入单例池中,实例 ClassA通过Spring容器获取到ClassB,完成了自己对象初始化操作。

⑤这样ClassA和ClassB都完成了对象初始化操作,从而解决了循环依赖问题。

3.Bean的注解

@Component 通⽤的注解,可标注任意类为 Spring 组件

@Service 在业务逻辑层使用(service层)

@Repository 在数据访问层使用(dao层)

@Controller 在展现层使用,控制器的声明(controller层)

​●注入bean的注解

@Autowired:默认按照类型来装配注入,@Qualifier:可以改成名称

@Resource:默认按照名称来装配注入,JDK的注解,新版本已经弃用

●@Autowired注解原理

@Autowired的使用简化了我们的开发,实现 AutowiredAnnotationBeanPostProcessor 类,该类实现了 Spring 框架的一些扩展接口。​ 实现 BeanFactoryAware 接口使其内部持有了 BeanFactory(可轻松的获取需要依赖的的 Bean)。​ 实现 MergedBeanDefinitionPostProcessor 接口,实例化Bean 前获取到 里面的 @Autowired 信息并缓存下来;​ 实现 postProcessPropertyValues 接口, 实例化Bean 后从缓存取出注解信息,通过反射将依赖对象设置到 Bean 属性里面。

●@SpringBootApplication注解等同于下面三个注解:

✮@SpringBootConfiguration: 底层是Configuration注解,说白了就是支持JavaConfig的方式来进行配置

✮@EnableAutoConfiguration:开启自动配置功能

✮@ComponentScan:就是扫描注解,默认是扫描当前类下的package

4.@SpringMVC

@Controller 声明该类为SpringMVC中的Controller

@RequestMapping 用于映射Web请求

@ResponseBody 支持将返回值放在response内,而不是一个页面,通常用户返回json数据

@RequestBody 允许request的参数在request体中,而不是在直接连接在地址后面。

@PathVariable 用于接收路径参数

@RequestMapping("/hello/{name}")申明的路径,将注解放在参数中前,即可获取该值,通常作为Restful的接口实现方法。

●SpringMVC原理

①客户端(浏览器)发送请求,直接请求到 DispatcherServlet 。

②DispatcherServlet 根据请求信息调⽤ HandlerMapping ,解析请求对应的 Handler 。

③解析到对应的 Handler (也就是 Controller 控制器)后,开始由HandlerAdapter 适配器处理。

④HandlerAdapter 会根据 Handler 来调⽤真正的处理器开处理请求,并处理相应的业务逻辑。

⑤处理器处理完业务后,会返回⼀个 ModelAndView 对象, Model 是返回的数据对象

⑥ViewResolver 会根据逻辑 View 查找实际的 View 。

⑦DispaterServlet 把返回的 Model 传给 View (视图渲染)。

⑧把 View 返回给请求者(浏览器)

5.@SpringMybatis

@Insert : 插入sql ,和xml insert sql语法完全一样

@Select : 查询sql, 和xml select sql语法完全一样

@Update : 更新sql, 和xml update sql语法完全一样

@Delete : 删除sql, 和xml delete sql语法完全一样

@Param : 入参

@Results : 设置结果集合@Result : 结果

@ResultMap : 引用结果集合

@SelectKey : 获取最新插入id

Q:mybatis如何防止sql注入?

A:简单的说就是#{}是经过预编译的,是安全的,{}是未经过预编译的,仅仅是取变量的值,是非安全的,存在SQL注入。在编写mybatis的映射语句时,尽量采用\*\*"#{xxx}"这样的格式。如果需要实现动态传入表名、列名,还需要做如下修改:添加属性statementType="STATEMENT",同时sql里的属有变量取值都改成{xxxx}**

●Mybatis和Hibernate的区别

✮Hibernate 框架:

Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,建立对象与数据库表的映射。是一个全自动的、完全面向对象的持久层框架。

✮Mybatis框架:

Mybatis是一个开源对象关系映射框架,原名:ibatis,2010年由谷歌接管以后更名。是一个半自动化的持久层框架。

●区别:

★开发方面

在项目开发过程当中,就速度而言:

hibernate开发中,sql语句已经被封装,直接可以使用,加快系统开发;

Mybatis 属于半自动化,sql需要手工完成,稍微繁琐;

但是,凡事都不是绝对的,如果对于庞大复杂的系统项目来说,复杂语句较多,hibernate 就不是好方案。

★sql优化方面

Hibernate 自动生成sql,有些语句较为繁琐,会多消耗一些性能;

Mybatis 手动编写sql,可以避免不需要的查询,提高系统性能;

★对象管理比对

Hibernate 是完整的对象-关系映射的框架,开发工程中,无需过多关注底层实现,只要去管理对象即可;

Mybatis 需要自行管理映射关系

相关推荐
行然梦实14 分钟前
学习日记_20241110_聚类方法(K-Means)
学习·kmeans·聚类
马船长20 分钟前
制作图片木马
学习
秀儿还能再秀31 分钟前
机器学习——简单线性回归、逻辑回归
笔记·python·学习·机器学习
WCF向光而行36 分钟前
Getting accurate time estimates from your tea(从您的团队获得准确的时间估计)
笔记·学习
wang09071 小时前
工作和学习遇到的技术问题
学习
Li_0304062 小时前
Java第十四天(实训学习整理资料(十三)Java网络编程)
java·网络·笔记·学习·计算机网络
心怀梦想的咸鱼2 小时前
ue5 蓝图学习(一)结构体的使用
学习·ue5
kali-Myon3 小时前
ctfshow-web入门-SSTI(web361-web368)上
前端·python·学习·安全·web安全·web
龙中舞王3 小时前
Unity学习笔记(4):人物和基本组件
笔记·学习·unity
Hncj20223 小时前
MySQL学习/复习2库的操作
学习