Java Web之Spring核心之IOC的解析和实战以及bean的使用

本文涉及的产品
全局流量管理 GTM,标准版 1个月
云解析 DNS,旗舰版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
简介: Java Web之Spring核心之IOC的解析和实战以及bean的使用

前言


Spring是一个开源框架 它能够降低开发企业应用程序的复杂性 它以IOC(控制反转)和AOP(面向切面编程)两种先进的技术为基础 完美地简化了企业级开发的复杂度


一、Spring的简介和获取

image.png

Spring有七大模块


1:核心模块


Spring Core模块是Spring的核心容器 它实现了IOC模式 提供了Spring框架的基础功能,在模块中包含最重要的BeanFactory类是Spring的核心类  负责对JavaBean的配置与管理


2:Context模块


Spring Context模块继承BeanFactory类并且添加了事件处理 国际化 资源装载 透明装载等功能


3:AOP模块


Spring集成了所有AOP功能 通过事务管理可以使任意Spring管理的对象AOP化


4:DAO模块


提供了JDBC的抽象层 简化了数据库厂商的异常错误


5:O/R模块


提供了对现有ORM框架的支持


6:Web模块


Spring Web模块建立在Spring Context基础之上 它提供了Servlet监听器的Context和Web应用的上下文


7:MVC模块


Spring Web MVC模块建立在Spring核心功能之上 使得它拥有Spring框架的所有特性


Spring的获取


Spring官网


Spring内置了日志组件log4.jar 所以在正式使用Spring之前需要对log4j进行简单的配置


在项目的src根目录下创建log4j.properties属性文件 代码如下

log4j.rootLogger=WARN,stdout
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%d%p[[%c]-%m%n


Spring配置结构如下

1666442551939.jpg

使用BeanFactory管理Bean


以装载Bean为例 代码如下

Resource resource=new ClassPathResource("applicationContext.xml");
BeanFactory factory=new XmlBeanFactory(resource);
Test test=(Test)factory.getBean("test");


AplicationContext的应用


在Spring中大多采用AplicationContext容器来开发企业级的程序 接下来介绍它的三个实现类


1:ClassPathXmlApplicationContext类


它从当前类路径中检索配置文件并装载它来创建容器的实例

ApplicationContext context=new ClassPathXmlApplicationContext(String configLocation);


2:FileSystemXmlApplicationContext类


它和上面的区别在于读取Spring配置文件的方式 它不再从类路径中获取配置文件 而是通过参数指定配置文件的位置

ApplcationContext context=new FileSystemXmlApplicationContext(String configLocation);


3:WebApplicationContext类


它是Spring的Web应用容器


二、依赖注入与IOC


什么是控制反转与依赖注入?


IOC 控制反转 它使程序组件或类之间尽量形成一种松耦合的结构,开发者在使用类的实例之前,需要先创建类的实例,但是IOC将创建实例的任务交给IOC容器,这样开发应用代码时只需要直接使用类的实例 这就是IOC


依赖注入有三种形式 Spring支持后两种


1:接口注入


基于接口将调用与实现分离


2:Setter注入


基于JavaBean的Setter方法为属性赋值 在实际开发中得到了最广泛的应用

public class User{
private String name;
public String getName(){
return name;
}
public void setName(String name){
this.name=name;
}
}


3:构造器注入


基于构造方法为属性赋值 容器通过调用类的构造方法 将其所需的依赖关系注入其中

public class User{
private String name;
public User(String name){
this.name=name;
}
}


bean的配置


<bean id="test" class="com.mr.Test"/>

id属性为bean的名称 class属性为对应的类名

引用其他的bean


在Spring中可以通过配置文件使用<ref>元素引用其他的JavaBean的实例对象

<ref local="user"/>


三、自动装配


<bean>元素的autowise属性负责自动装备<bean>标签定义的JavaBaen的属性 这样做可以省去很多配置JavaBean属性的标签代码


1:按Bean名称装配


<bean>元素的byname属性以属性名区分自动装配,在容器中寻找与JavaBean的属性名相同的JavaBean并将其自动装配到JavaBean中

<bean auotwise="byName" id="printInfo" class="com.mr.user.PringInfo"/>


2:按bean类型装配


Spring以bean类型区分自动装配 容器会自动寻找与JavaBean属性类型相同的JavaBean的定义 并将其注入到需要自动装配的JavaBean中

<bean auotwise="byType" id="printInfo" class="com.mr.user.PringInfo"/>


四、bean的作用域


在Spring中,那些组成应用的主题及由Spring IOC容器所管理的对象被称为bean,简单地讲,bean就是由Spring容器初始化,装备及被管理的对象


1:singleton的作用域


当Spring中一个bean作用域为singleton时,那么Spring IOC容器中只会存在一个共享的该bean实例,并且所有对该bean的引用 只要id与该bean定义相匹配,则只会返回bean的单一实例

1666442741460.jpg

<bean id="test" class="com.mr.Test"/>
<bean id="test" class="com.mr.Test"/ singleton="true"/>
<bean id="test" class="com.mr.Test"/scope="singleton"/>


2:prototype作用域


prototype作用域的bean会导致在每次对该bean请求时都会创建一个新的bean实例,


对所有有状态的bean应该使用prototype作用域 无状态的bean应该使用singleton作用域

1666442775475.jpg

<bean id="test" class="com.mr.Test" singleton="false"/>
<bean id="test" class="com.mr.Test" scope="prototype"/>


相关文章
|
22天前
|
XML Java 数据格式
【SpringFramework】Spring IoC-基于XML的实现
本文主要讲解SpringFramework中IoC和DI相关概念,及基于XML的实现方式。
108 69
|
20天前
|
人工智能 自然语言处理 Java
FastExcel:开源的 JAVA 解析 Excel 工具,集成 AI 通过自然语言处理 Excel 文件,完全兼容 EasyExcel
FastExcel 是一款基于 Java 的高性能 Excel 处理工具,专注于优化大规模数据处理,提供简洁易用的 API 和流式操作能力,支持从 EasyExcel 无缝迁移。
96 9
FastExcel:开源的 JAVA 解析 Excel 工具,集成 AI 通过自然语言处理 Excel 文件,完全兼容 EasyExcel
|
1天前
|
存储 Java 计算机视觉
Java二维数组的使用技巧与实例解析
本文详细介绍了Java中二维数组的使用方法
24 15
|
1天前
|
算法 搜索推荐 Java
【潜意识Java】深度解析黑马项目《苍穹外卖》与蓝桥杯算法的结合问题
本文探讨了如何将算法学习与实际项目相结合,以提升编程竞赛中的解题能力。通过《苍穹外卖》项目,介绍了订单配送路径规划(基于动态规划解决旅行商问题)和商品推荐系统(基于贪心算法)。这些实例不仅展示了算法在实际业务中的应用,还帮助读者更好地准备蓝桥杯等编程竞赛。结合具体代码实现和解析,文章详细说明了如何运用算法优化项目功能,提高解决问题的能力。
23 6
|
7天前
|
SQL Java 数据库连接
如何在 Java 代码中使用 JSqlParser 解析复杂的 SQL 语句?
大家好,我是 V 哥。JSqlParser 是一个用于解析 SQL 语句的 Java 库,可将 SQL 解析为 Java 对象树,支持多种 SQL 类型(如 `SELECT`、`INSERT` 等)。它适用于 SQL 分析、修改、生成和验证等场景。通过 Maven 或 Gradle 安装后,可以方便地在 Java 代码中使用。
98 11
|
1天前
|
存储 算法 搜索推荐
【潜意识Java】期末考试可能考的高质量大题及答案解析
Java 期末考试大题整理:设计一个学生信息管理系统,涵盖面向对象编程、集合类、文件操作、异常处理和多线程等知识点。系统功能包括添加、查询、删除、显示所有学生信息、按成绩排序及文件存储。通过本题,考生可以巩固 Java 基础知识并掌握综合应用技能。代码解析详细,适合复习备考。
10 4
|
1天前
|
存储 Java
【潜意识Java】期末考试可能考的选择题(附带答案解析)
本文整理了 Java 期末考试中常见的选择题,涵盖数据类型、控制结构、面向对象编程、集合框架、异常处理、方法、流程控制和字符串等知识点。每道题目附有详细解析,帮助考生巩固基础,加深理解。通过这些练习,考生可以更好地准备考试,掌握 Java 的核心概念和语法。
|
6天前
|
存储 分布式计算 Hadoop
基于Java的Hadoop文件处理系统:高效分布式数据解析与存储
本文介绍了如何借鉴Hadoop的设计思想,使用Java实现其核心功能MapReduce,解决海量数据处理问题。通过类比图书馆管理系统,详细解释了Hadoop的两大组件:HDFS(分布式文件系统)和MapReduce(分布式计算模型)。具体实现了单词统计任务,并扩展支持CSV和JSON格式的数据解析。为了提升性能,引入了Combiner减少中间数据传输,以及自定义Partitioner解决数据倾斜问题。最后总结了Hadoop在大数据处理中的重要性,鼓励Java开发者学习Hadoop以拓展技术边界。
30 7
|
28天前
|
存储 缓存 Java
Java 并发编程——volatile 关键字解析
本文介绍了Java线程中的`volatile`关键字及其与`synchronized`锁的区别。`volatile`保证了变量的可见性和一定的有序性,但不能保证原子性。它通过内存屏障实现,避免指令重排序,确保线程间数据一致。相比`synchronized`,`volatile`性能更优,适用于简单状态标记和某些特定场景,如单例模式中的双重检查锁定。文中还解释了Java内存模型的基本概念,包括主内存、工作内存及并发编程中的原子性、可见性和有序性。
Java 并发编程——volatile 关键字解析
|
10天前
|
Kubernetes Java 持续交付
小团队 CI/CD 实践:无需运维,Java Web应用的自动化部署
本文介绍如何使用GitHub Actions和阿里云Kubernetes(ACK)实现Java Web应用的自动化部署。通过CI/CD流程,开发人员无需手动处理复杂的运维任务,从而提高效率并减少错误。文中详细讲解了Docker与Kubernetes的概念,并演示了从创建Kubernetes集群、配置容器镜像服务到设置GitHub仓库Secrets及编写GitHub Actions工作流的具体步骤。最终实现了代码提交后自动构建、推送镜像并部署到Kubernetes集群的功能。整个过程不仅简化了部署流程,还确保了应用在不同环境中的稳定运行。
48 9