springboot 常用扩展点

springboot 常用扩展点

1、FactoryBean:本身为Bean,当向spring容器中注入Bean时,最终生成的Bean是通过Factory的getObject方法获取的。通常用于较为复杂的对象的注册。

    FactoryBean是一个能生产或修饰对象生成的工厂Bean。一个Bean如果实现了FactoryBean接口,那么根据该bean名称获取到的实际上是getObject方法返回的对象。如果要获取Bean自身实例,那么需要在名称前加上‘&’符号。

application.getBean("&myBean");

      框架中对于FactoryBean的使用:

      Mybatis整合spring框架时,使用FactoryBean用于将JDK动态代理生成的MapperProxy代理对象注入到spring容器中。

      OpenFeign框架中,FeignClient接口的动态代理也是通过FactoryBean注入到spring容器中。

2、@Import注解:向spring容器中注入Bean

      配置类实现ImportSelector接口,可以向spring容器注入特定的Bean

      配置类实现ImportBeanDefinitionRegistrar接口,可以向spring容器注入自定义逻辑的Bean

      配置类未实现任何接口,将配置类注入到spring容器中

3、Bean生命周期的回调

      构造方法——>@Autowired——>Aware接口——>@PostConstruct——>InitializingBean#afterPropertiesSet——>@Bean#initMethod——>@PreDestroy——>DisposableBean#destroy——>@Bean#destroyMethod

4、BeanPostProcesssor:Bean后置处理器。在springbean的扩展中扮演者重要角色,通过它可以在任意一个阶段扩展自己想要的东西。

      Dubbo中当Bean在创建的某个阶段,进入到ReferenceAnnotationBeanPostProcessor类时,就会根据反射判断该类是否有@DubboReference注解,有的话会构建动态代理注入到spring容器中。

5、BeanFactoryPostProcessor:对spring容器进行处理。

      可以禁止spring循环依赖

      实现BeanFactoryPostProcessor接口,获取beanFactory并进行设置:beanFactory.setAllowCircularReferences(false).

6、SPI(service provider Interface):动态替换机制,可以灵活的让接口和实现进行分离,让API提供者只提供接口,让第三方来实现,然后通过配置文件的方式来实现替换或扩展。

  • springboot自动装配:项目启动时,会从所有spring.factories文件中读取@enableAutoConfiguration键值对,在进行去冲突决定使用哪些配置。@SpringbootApplication—>@enableAutoConfiguration—>@Import

  • PropertySourceLoader:springboot环境中,外部配置文件支持properties和yaml格式,可以通过PropertySourceLoader实现支持json格式的配置文件。实现PropertySourceLoader接口,处理json解析逻辑,将自己的实现类加入到spring.factories文件中。

           nacos注册配置中心就是通过实现PropertySourceLoader接口完成对json、xml格式文件的支持

  • ApplicationcontextInitailizer:是springboot启动过程中的扩展点,传入ConfigurableApplicationContext,此时还没调用refresh方法,没有Bean,一般该接口是用来配置ConfigurableApplicationContext的。

  • EnvironmentPostProcessor:用于处理配置信息。

7、ApplicationRunner和CommandLineRunner:在springboot启动成功之后调用,可以获取启动时 的参数。

8、springEvent事件机制

  •    spring事件传播机制:父子容器中,子容器发布的事件,父容器也可以进行监听。

   传播特性的坑:在springcloud环境中,spring发布的事件的监听器可能会执行多次。原因如下:为了使FeignClient和RibbonClient不同的服务配置相互隔离,会创建很多子容器,有一个共同的付容器,就会导致上述问题。

  •    解决方案:判断监听器是否执行过。增加判断标志或者监听类似的事件,比如ApplicationStartedEvent

  •    事件机制的框架应用:Mybatis 的SQLSessionFactoryBean监听ContextRefreshedEvent。

  • springcloud环境中,当项目启动成功,会发布ServletWebServerInitailizedEvent事件,服务注册中心通过监听该事件就可以向注册中心注册事例。

  

     

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
# 基于springboot的web项目最佳实践 + [web](#web) + [单元测试](#test) + [actuator应用监控](#actuator) + [lombok](#lombok) + [baseEntity](#baseEntity) + [统一响应返回值](#result) + [异常](#exception) + [数据校验](#validation) + [日志](#log) + [swagger](#swagger) + [数据库连接池](#datasource) + [spring jdbc](#jdbc) + [jpa](#jpa) + [redis](#redis) + [spring cache](#springcache) + [mogodb](#mogodb) + [mybatis](#mybatis) + [spring security](#security) + [项目上下文](#ContextHolder) + [单登录](#sso) + [邮件](#mail) + [maven](#maven) + [总结](#总结) `springboot` 可以说是现在做`javaweb`开发最火的技术,我在基于`springboot`搭建项目的过程中,踩过不少坑,发现整合框架时并非仅仅引入`starter` 那么简单。 要做到简单,易用,扩展性更好,还需做不少二次封装,于是便写了个基于`springboot`的web项目脚手架,对一些常用的框架进行整合,并进行了简单的二次封装。 项目名`baymax`取自动画片超能陆战队里面的大白,大白是一个医护充气机器人,希望这个项目你能像大白一样贴心,可以减少你的工作量。 ## 项目备注 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 2、本项目适合计算机相关专业(如计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载学习,也适合小白学习进阶,当然也可作为毕设项目、课程设计、作业、项目初期立项演示等。 3、如果基础还行,也可在此代码基础上进行修改,以实现其他功能,也可用于毕设、课设、作业等。 下载后请首先打开README.md文件(如有),仅供学习参考, 切勿用于商业用途。
学习尚硅谷视频整理的文档 Spring Boot 1 1 Spring Boot入门 4 1.1 简介 4 1.2 微服务(martin fowler发表了一篇文章) 5 1.3 环境约束 7 1.4 第一个Spring Boot项目(jar):HelloWorld 8 1.5 入门案例详解 11 1.5.1 POM文件 11 1.5.2 主程序类,主入口类 12 1.6 使用Spring Initializer向导快速创建Spring Boot 16 2 Spring Boot配置 18 2.1 配置文件 18 2.2 YML语法 19 2.3 YML配置文件值获取 21 2.4 properties配置文件乱码问题 24 2.5 @ConfigurationProperties与@Value的区别 25 2.6 配置@PropertySource、@ImportResource、@Bean 27 2.7 配置文件占位符 30 2.8 Profile多环境支持 31 2.9 配置文件的加载位置 33 2.10 外部配置加载顺序 36 2.11 自动配置原理 37 2.12 @Conditional派生注解 41 3 Spring Boot与日志 42 3.1 日志框架分类和选择 42 3.2 SLF4j使用 43 3.3 其他日志框架统一转换成slf4j+logback 44 3.4 Spring Boot日志使用 45 3.5 Spring Boot默认配置 47 3.6 指定日志文件和日志Profile功能 52 3.7 切换日志框架(不使用SLF4j+LogBack) 54 4 Spring Boot与Web开发 55 4.1 Web开发简介 55 4.2 静态资源映射规则 56 4.3 引入Thymeleaf 60 4.4 Thymeleaf语法 61 4.5 SpringMVC自动配置原理 67 4.6 SpringBoot扩展与全面接管 70 4.7 如何修改SpringBoot的默认配置 72 4.8 【实验】CRUD操作 73 4.8.1 默认访问首页 73 4.8.2 登录页面国际化 74 4.8.3 登录 80 4.8.4 拦截器进行登录检查 81 4.8.5 实验要求(没按要求做,不想改了!) 82 4.8.6 CRUD-员工列表 83 4.8.7 CRUD-员工修改 86 4.8.8 CRUD-员工添加 87 4.8.9 CRUD-员工删除 88 4.9 错误处理原理&错误页面定制 90 4.10 配置嵌入式Servlet容器(springboot 1.50版本) 97 4.10.1 如何定制和修改Servelt容器的相关配置 97 4.10.2 注册servlet三大组件【servlet,filter,listener】 98 4.10.3 替换为其他嵌入式容器 102 4.10.4 嵌入式servlet容器自动配置原理 103 4.10.5 嵌入式servlet容器启动原理 103 4.11 使用外置的Servlet容器 104 4.11.1 步骤 104 4.11.2 原理 107 5 Spring Boot与Docker(虚拟化容器技术) 110 5.1 简介 110 5.2 核心概念 111 5.3 安装Docker 112 5.4 Docker常用命令&操作 113 5.5 安装MySQL示例 114 6 Spring Boot与数据访问 115 6.1 JDBC 115 6.1.1 实现 115 6.1.2 自动配置原理 116 6.2 整合Durid数据源 117 6.3 整合Mybatis 122 6.3.1 注解版 123 6.3.2 配置文件版 124 6.4 整合SpringData JPA 125 6.4.1 SpringData简介 125 6.4.2 整合 126 7 Spring Boot启动配置原理 128 7.1 启动流程(Springboot 1.50版本) 128 7.1.1 创建SpringApplication对象 129 7.1.2 运行run方法 130 7.1.3 编写事件监听机制 132 8 Spring Boot自定义starters 136 8.1 概述 136 8.2 步骤 137 9 更多Springboot整合示例 144 10 Spring Boot与缓存 145 10.1 JSR107缓存规范 145 10.2 Spring的缓存抽象 146 10.2.1 基本概念 146 10.2.2 整合项目 146 10.2.3 CacheEnable注解 148 10.2.4 Cache注解 150 10.3 整合redis 154 10.3.1 在Docker上安装redis 154 10.3.2 Redis的Template 154 10.3.3 整合(百度) 155
登录(Single Sign-On,简称 SSO)是一种身份验证和授权机制,它允许用户使用一组凭据(如用户名和密码)来访问多个应用程序而无需重复登录。OAuth 2.0 是一种常用的用于实现单登录的协议。 在 Spring Boot 中实现 OAuth 2.0 单登录,可以使用 Spring Security 提供的相关功能。以下是一个简单的示例: 1. 添加依赖: 在 pom.xml 文件中添加相关依赖,包括 Spring Security 和 OAuth 2.0 相关的库。 ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-security</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-oauth2-client</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-oauth2-resource-server</artifactId> </dependency> ``` 2. 配置认证服务器: 在 application.properties 或 application.yml 文件中配置认证服务器的相关信息,包括客户端 ID、客户端密钥、授权服务器 URL 等。 ```yaml spring: security: oauth2: client: registration: my-client-id: client-id: your-client-id client-secret: your-client-secret # 其他配置项... provider: my-auth-server: authorization-uri: https://example.com/oauth/authorize token-uri: https://example.com/oauth/token # 其他配置项... ``` 3. 配置安全规则: 创建一个类继承 `WebSecurityConfigurerAdapter`,并重写 `configure(HttpSecurity http)` 方法来配置安全规则。 ```java @Configuration @EnableWebSecurity public class SecurityConfig extends WebSecurityConfigurerAdapter { @Override protected void configure(HttpSecurity http) throws Exception { http .authorizeRequests() .antMatchers("/login").permitAll() .anyRequest().authenticated() .and() .oauth2Login() .defaultSuccessUrl("/home") .and() .logout() .logoutSuccessUrl("/login") .and() .csrf().disable(); } } ``` 以上示例中,`/login` 是登录页面的 URL,`/home` 是登录成功后跳转的页面 URL。 4. 创建控制器: 创建一个控制器类,用于处理登录成功后的回调和其他业务逻辑。 ```java @Controller public class HomeController { @GetMapping("/home") public String home() { // 处理登录成功后的逻辑 return "home"; } } ``` 5. 编写前端页面: 根据实际需求,编写登录页面和其他需要登录权限的页面。 以上是一个简单的示例,实际的单登录场景可能涉及更复杂的配置和逻辑。具体的实现方式取决于你使用的身份认证和授权服务器。你可以根据自己的需求进行相应的设置和扩展。 注意:这只是一个基本的示例,实际应用中需要根据具体情况进行配置和开发。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值