Spring框架核心技术解析

📕我是廖志伟,一名Java开发工程师、《Java项目实战——深入理解大型互联网企业通用技术》(基础篇)(进阶篇)、(架构篇)、《解密程序员的思维密码——沟通、演讲、思考的实践》作者、清华大学出版社签约作家、Java领域优质创作者、CSDN博客专家、阿里云专家博主、51CTO专家博主、产品软文专业写手、技术文章评审老师、技术类问卷调查设计师、幕后大佬社区创始人、开源项目贡献者。

📘拥有多年一线研发和团队管理经验,研究过主流框架的底层源码(Spring、SpringBoot、SpringMVC、SpringCloud、Mybatis、Dubbo、Zookeeper),消息中间件底层架构原理(RabbitMQ、RocketMQ、Kafka)、Redis缓存、MySQL关系型数据库、 ElasticSearch全文搜索、MongoDB非关系型数据库、Apache ShardingSphere分库分表读写分离、设计模式、领域驱动DDD、Kubernetes容器编排等。

📙不定期分享高并发、高可用、高性能、微服务、分布式、海量数据、性能调优、云原生、项目管理、产品思维、技术选型、架构设计、求职面试、副业思维、个人成长等内容。

Java程序员廖志伟

💡在这个美好的时刻,笔者不再啰嗦废话,现在毫不拖延地进入文章所要讨论的主题。接下来,我将为大家呈现正文内容。

CSDN

一、IoC容器核心依赖注入实现模式

Spring框架的IoC容器是实现依赖注入的核心,它通过控制反转(IoC)原理,将对象的创建与依赖关系的配置分离,使得开发者能够专注于业务逻辑的实现。

构造器注入

构造器注入在对象创建阶段就将依赖注入到对象中,这种方式确保了对象的依赖关系在对象生命周期开始时就得到满足。在Spring中,可以通过在构造函数中注入依赖来实现,例如:

public class Service {
    private Dependency dependency;

    public Service(Dependency dependency) {
        this.dependency = dependency;
    }
}

通过这种方式,Spring容器会在创建Service对象时自动注入Dependency实例。

Setter注入

Setter注入是在对象创建之后通过setter方法注入依赖。这种方式的优点是灵活性高,可以在对象创建后根据需要修改依赖关系。在Spring中,可以通过在setter方法中注入依赖来实现,例如:

public class Service {
    private Dependency dependency;

    public void setDependency(Dependency dependency) {
        this.dependency = dependency;
    }
}

Spring容器会通过调用setter方法来注入Dependency实例。

字段注入

字段注入是通过在类中声明依赖关系的字段,并使用@Autowired注解来自动注入依赖。这种方式简单直接,但需要注意字段必须是非私有的,且没有其他构造器。

public class Service {
    @Autowired
    private Dependency dependency;
}

Spring容器会在创建Service对象时自动注入Dependency实例。

方法注入

方法注入是通过定义一个注入方法,并在该方法中使用注解来自动注入依赖。这种方式在Spring中不常用,但在某些特定场景下可能有用。

public class Service {
    @Autowired
    public void init(Dependency dependency) {
        this.dependency = dependency;
    }
}

Spring容器会在调用init方法时注入Dependency实例。

组件扫描机制

Spring的组件扫描机制允许自动扫描指定包下的类,并将它们注册为Bean。通过在类上使用@Component注解,Spring容器可以识别并管理这些类。

@Component
public class Service {
    // ...
}
Bean作用域

Spring提供了多种Bean作用域,包括Singleton(单例)和Prototype(原型)等。Singleton表示每个Spring容器中只有一个Bean实例,而Prototype表示每次请求都会创建一个新的Bean实例。

@Component
@Scope("prototype")
public class Service {
    // ...
}
条件化配置(@Conditional)

@Conditional注解允许基于特定条件来注册Bean。例如,可以根据类路径存在与否或特定的属性值来决定是否注册Bean。

@Component
@Conditional(OnClass.class)
public class Service {
    // ...
}

二、AOP技术体系

Spring AOP通过代理模式实现面向切面编程,将横切关注点与业务逻辑分离,使得代码更加清晰、可维护。

代理模式实现

Spring AOP支持两种代理模式:JDK动态代理和CGLIB代理。JDK动态代理适用于实现了至少一个接口的类,而CGLIB代理适用于没有实现接口的类。

JDK动态代理

JDK动态代理通过实现接口的方式创建代理类,拦截方法调用。这种方式性能较高,但只能代理实现了接口的类。

CGLIB代理

CGLIB代理通过生成类的子类来实现代理,适用于没有实现接口的类。这种方式可以拦截所有方法,包括私有方法,但性能相对较低。

切点表达式语法

切点表达式用于定义哪些方法应该被拦截。Spring AOP提供了丰富的表达式语法,例如:

execution(* com.example.service.*.*(..))

这个表达式表示拦截com.example.service包下所有类的所有方法。

通知类型

Spring AOP提供了多种通知类型,包括前置通知、后置通知、环绕通知、异常通知和最终通知。

  • 前置通知:在目标方法执行之前执行。
  • 后置通知:在目标方法执行之后执行。
  • 环绕通知:在目标方法执行前后都执行。
  • 异常通知:在目标方法抛出异常时执行。
  • 最终通知:在目标方法正常或异常完成后执行。
AOP应用场景

AOP广泛应用于日志管理、性能监控、安全控制等领域。例如,可以使用AOP实现统一的日志记录功能,将日志记录的逻辑从业务代码中分离出来。

三、数据持久化

Spring框架提供了强大的数据持久化支持,包括JDBC模板、事务管理、ORM集成等。

JDBC模板

Spring JDBC模板简化了JDBC操作,提供了执行SQL语句、查询结果等便捷方法。例如,可以使用JdbcTemplate执行查询:

public List<Map<String, Object>> queryData(String sql) {
    return jdbcTemplate.queryForList(sql);
}
事务管理

Spring支持声明式和编程式事务管理。声明式事务使用@Transactional注解,而编程式事务则通过编程方式控制事务。

@Transactional
public void updateData() {
    // ...
}

Spring事务管理器会确保事务的原子性、一致性、隔离性和持久性。

ORM集成

Spring支持多种ORM框架,如Hibernate。它通过集成Hibernate,提供了会话管理和事务管理。

public class MyRepository extends JpaRepository<MyEntity, Long> {
    // ...
}

通过使用JpaRepository接口,可以简化数据访问层的实现。

JPA规范实现

Spring Data JPA是Spring对JPA规范的支持,它简化了JPA的使用。例如,可以使用@Entity注解来标记实体类:

@Entity
public class MyEntity {
    // ...
}
多数据源配置

Spring支持配置多个数据源,并允许根据不同的数据源执行不同的操作。例如,可以使用AbstractRoutingDataSource来实现多数据源路由。

public class MyRoutingDataSource extends AbstractRoutingDataSource {
    // ...
}

通过设置不同的数据源路由规则,可以实现根据不同的请求路由到不同的数据源。

四、Web开发体系

Spring MVC是Spring框架的Web模块,它提供了一个模型-视图-控制器(MVC)架构,使得Web应用的开发更加简单和高效。

MVC架构组件
  • 控制器:处理用户请求,返回响应。例如,可以使用@Controller注解来标记控制器类:
@Controller
public class MyController {
    // ...
}
  • 视图解析器:解析视图名称,返回相应的视图。例如,可以使用InternalResourceViewResolver来解析视图:
public class MyViewResolver implements ViewResolver {
    // ...
}
  • 数据绑定:将请求参数绑定到模型对象。例如,可以使用@RequestParam注解来绑定请求参数:
public class MyController {
    @RequestParam("name") String name;
    // ...
}
RESTful支持

Spring MVC支持RESTful风格的应用开发,允许使用HTTP方法(如GET、POST、PUT、DELETE)来操作资源。例如,可以使用@RestController注解来创建RESTful控制器:

@RestController
public class MyRestController {
    // ...
}
异常处理机制

Spring MVC提供了异常处理机制,允许自定义异常处理策略。例如,可以使用@ExceptionHandler注解来处理特定类型的异常:

@ControllerAdvice
public class MyExceptionHandler {
    @ExceptionHandler(Exception.class)
    public ResponseEntity<String> handleException(Exception e) {
        // ...
    }
}
文件上传下载

Spring MVC支持文件上传和下载,通过MultipartFile接口处理上传的文件,通过HttpServletResponse处理下载。

public class MyController {
    @PostMapping("/upload")
    public ResponseEntity<String> uploadFile(@RequestParam("file") MultipartFile file) {
        // ...
    }
}

五、安全框架

Spring Security是一个功能强大的安全框架,它提供了认证、授权和CSRF防护等功能。

认证流程

Spring Security通过用户名和密码、OAuth2等方式进行用户认证。例如,可以使用表单登录来实现用户认证:

<form action="/login" method="post">
    <input type="text" name="username" />
    <input type="password" name="password" />
</form>

Spring Security会处理登录请求,并进行用户认证。

授权模型

Spring Security使用基于角色的访问控制(RBAC)模型来授权。例如,可以使用@PreAuthorize注解来指定方法需要哪些角色权限:

@PreAuthorize("hasRole('ADMIN')")
public void adminMethod() {
    // ...
}
CSRF防护

Spring Security通过添加CSRF令牌来防止跨站请求伪造。例如,可以使用@EnableCsrfProtection注解来启用CSRF保护:

@EnableCsrfProtection
public class MySecurityConfig extends WebSecurityConfigurerAdapter {
    // ...
}
OAuth2集成

Spring Security支持OAuth2,允许用户使用第三方服务进行认证。例如,可以使用OAuth2Client来集成OAuth2认证:

public class MyOAuth2Client {
    // ...
}
方法级安全

Spring Security允许在方法级别上指定安全约束,如@PreAuthorize@PostAuthorize

@PreAuthorize("hasAuthority('READ')")
public void readMethod() {
    // ...
}

六、高级特性

Spring框架还提供了一系列高级特性,如事件发布/监听机制、SpEL表达式、响应式编程等。

事件发布/监听机制

Spring允许发布和监听事件,这有助于实现解耦和模块化。例如,可以使用ApplicationEvent来发布事件:

public class MyEvent extends ApplicationEvent {
    public MyEvent(Object source) {
        super(source);
    }
}

public class MyPublisher {
    @Autowired
    private ApplicationEventPublisher publisher;

    public void publishEvent() {
        publisher.publishEvent(new MyEvent(this));
    }
}
SpEL表达式

Spring表达式语言(SpEL)提供了一种强大的表达式求值机制,可以用于在运行时计算值。例如,可以使用SpEL表达式来计算属性值:

public class MyBean {
    private String name;

    public void setName(String name) {
        this.name = name;
    }

    public String getName() {
        return SpEL表达式计算结果;
    }
}
响应式编程(WebFlux)

Spring WebFlux是一个响应式Web框架,它允许异步和非阻塞的处理。例如,可以使用WebFlux来处理HTTP请求:

public class MyWebFluxController {
    @GetMapping("/reactive")
    public Flux<String> reactive() {
        return Flux.just("Hello, WebFlux!");
    }
}
测试框架集成

Spring支持与JUnit、TestNG等测试框架集成,简化了单元测试和集成测试。例如,可以使用Mockito来模拟依赖:

@Service
public class MyService {
    @Autowired
    private Dependency dependency;

    public void doSomething() {
        dependency.doSomething();
    }
}

public class MyServiceTest {
    @Test
    public void testDoSomething() {
        Dependency mockDependency = Mockito.mock(Dependency.class);
        MyService service = new MyService();
        service.setDependency(mockDependency);
        service.doSomething();
        Mockito.verify(mockDependency).doSomething();
    }
}
缓存抽象

Spring提供了缓存抽象,允许使用不同的缓存提供者,如EhCache、Redis等。例如,可以使用Spring Cache抽象来缓存方法结果:

@Service
public class MyService {
    @Cacheable("myCache")
    public String doGetSomething() {
        // ...
    }
}

七、Spring Boot生态

Spring Boot是Spring框架的一个模块,它简化了Spring应用的创建和部署。

自动配置原理

Spring Boot通过自动配置来简化应用配置,它根据类路径、属性和依赖关系自动配置Bean。例如,如果类路径下有HikariCP依赖,Spring Boot会自动配置HikariCP数据源。

Starter机制

Spring Boot提供了Starter依赖,这些依赖包含了创建特定类型应用所需的所有依赖。例如,spring-boot-starter-web包含了Spring MVC和Tomcat依赖。

Actuator监控

Spring Boot Actuator提供了应用监控和管理功能,如健康检查、指标收集等。例如,可以使用Actuator来收集应用的运行时指标:

management.endpoints.web.exposure.include=health,info
配置文件体系

Spring Boot使用配置文件(如application.propertiesapplication.yml)来管理应用配置。例如,可以使用配置文件来配置数据源:

spring.datasource.url=jdbc:mysql://localhost:3306/mydb
spring.datasource.username=root
spring.datasource.password=123456

总结来说,Spring框架是一个功能丰富、高度可扩展的Java企业级应用开发框架。通过理解上述知识点,开发者可以构建高效、可维护的Java应用。这些知识点的学习和应用将有助于提升开发者的技能,并促进他们在Java企业级应用开发领域的成长。

CSDN

博主分享

📥博主的人生感悟和目标

Java程序员廖志伟

📙经过多年在CSDN创作上千篇文章的经验积累,我已经拥有了不错的写作技巧。同时,我还与清华大学出版社签下了四本书籍的合约,并将陆续出版。

面试备战资料

八股文备战
场景描述链接
时间充裕(25万字)Java知识点大全(高频面试题)Java知识点大全
时间紧急(15万字)Java高级开发高频面试题Java高级开发高频面试题

理论知识专题(图文并茂,字数过万)

技术栈链接
RocketMQRocketMQ详解
KafkaKafka详解
RabbitMQRabbitMQ详解
MongoDBMongoDB详解
ElasticSearchElasticSearch详解
ZookeeperZookeeper详解
RedisRedis详解
MySQLMySQL详解
JVMJVM详解

集群部署(图文并茂,字数过万)

技术栈部署架构链接
MySQL使用Docker-Compose部署MySQL一主二从半同步复制高可用MHA集群Docker-Compose部署教程
Redis三主三从集群(三种方式部署/18个节点的Redis Cluster模式)三种部署方式教程
RocketMQDLedger高可用集群(9节点)部署指南
Nacos+Nginx集群+负载均衡(9节点)Docker部署方案
Kubernetes容器编排安装最全安装教程

开源项目分享

项目名称链接地址
高并发红包雨项目https://gitee.com/java_wxid/red-packet-rain
微服务技术集成demo项目https://gitee.com/java_wxid/java_wxid

管理经验

【公司管理与研发流程优化】针对研发流程、需求管理、沟通协作、文档建设、绩效考核等问题的综合解决方案:https://download.csdn.net/download/java_wxid/91148718

希望各位读者朋友能够多多支持!

现在时代变了,信息爆炸,酒香也怕巷子深,博主真的需要大家的帮助才能在这片海洋中继续发光发热,所以,赶紧动动你的小手,点波关注❤️,点波赞👍,点波收藏⭐,甚至点波评论✍️,都是对博主最好的支持和鼓励!

🔔如果您需要转载或者搬运这篇文章的话,非常欢迎您私信我哦~

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值