【Spring 高级注解】,linux视频剪辑

【Spring 高级注解】,linux视频剪辑,第1张

【Spring 高级注解】,linux视频剪辑

@Configuration:配置 Bean

=========================================================================================

1、Spring 在 3.x 提供的新的注解@Configuration,用于替换 XML 配置文件

@Configuration

public class AppConfig {

}

  • 配置 Bean 在应用的过程中替换了 XML 具体什么内容呢?

2、使用了 @Configuration 后,用 AnnotationConfigApplicationContext 创建工厂:

方法1: 指定配置bean的Class

ApplicationContext ctx = new AnnotationConfigApplicationContext(AppConfig.class);

方法2: 指定配置bean所在的路径(某个包及其子包)

ApplicationContext ctx = new AnnotationConfigApplicationContext(“com.yusael”);

@Configuration 注解的本质:查看源码可知,它也是 @Component 注解的衍生注解

因此我们可以用

基于注解开发使用日志 logback


1、引入相关 jar:

org.slf4j

slf4j-api

1.7.25

org.slf4j

jcl-over-slf4j

1.7.25

ch.qos.logback

logback-classic

1.2.3

ch.qos.logback

logback-core

1.2.3

org.logback-extensions

logback-ext-spring

0.1.4

2、引入 logback 配置文件:logback.xml

%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n

@Bean 注解

===========================================================================

@Bean 注解在配置 bean 中进行使用,等同于 XML 配置文件中的

@Bean 注解的基本使用


对象的创建:

简单对象:直接能够通过 new 方式创建的对象

  • User、UserService、UserDAO

复杂对象:不能通过 new 的方式直接创建的对象

  • Connection、SqlSessionFactory

@Bean 注解创建复杂对象的注意事项:遗留系统整合

@Bean

public Connection conn1() {

Connection conn = null;

try {

ConnectionFactoryBean factoryBean = new ConnectionFactoryBean();

conn = factoryBean.getObject();

} catch (Exception e) {

e.printStackTrace();

}

return conn;

}

@Bean 注解创建对象,自定义 id 值

@Bean(“id”)

@Bean 注解创建对象,控制对象创建次数

@Bean

@Scope(“singleton|prototype”) // 默认值 singleton

@Bean 注解的注入与细节


用户自定义类型:

@Bean

public UserDAO userDAO() {

return new UserDAOImpl();

}

@Bean

public UserService userService(UserDAO userDAO) {

UserServiceImpl userService = new UserServiceImpl();

userService.setUserDAO(userDAO);

return userService;

//简化写法

@Bean

public UserService userService() {

UserServiceImpl userService = new UserServiceImpl();

userService.setUserDAO(userDAO());

return userService;

}

JDK类型:

@Bean

public Customer customer() {

Customer customer = new Customer();

customer.setId(1);

customer.setName(“xiaohei”);

return customer;

}


如果直接在代码中进行 set 方法的调用,会存在耦合的问题,通过配置文件解决:

@Configuration

@PropertySource(“classpath:/init.properties”)

public class AppConfig1 {

@Value("${id}")

private Integer id;

@Value("${name}")

private String name;

@Bean

public Customer customer() {

Customer customer = new Customer();

customer.setId(id);

customer.setName(name);

return customer;

}

}

@ComponentScan 注解

====================================================================================

@ComponentScan 注解在配置 bean 中进行使用,等同于 XML 配置文件中的 标签

目的:进行相关注解的扫描(@Component、@Value、@Autowired …)

基本使用:

  • XML 方式:

  • 注解方式:

@Configuration

@ComponentScan(basePackages = “com.yusael.scan”)

public class AppConfig2 {

}

排除策略的的使用:

  • XML 方式:

  • 注解方式:

排除特定的注解:type = FilterType.ANNOTATION, value={}

排除特定的类型:type = FilterType.ASSIGNABLE_TYPE , value={]

切入点表达式:type = FilterType.ASPECTJ, pattern=""

正则表达式:type = FilterType.REGEX, pattern=""

自定义排除策略:type = FilterType.CUSTOM, pattern=""

@ComponentScan(basePackages = “com.yusael.scan”,

excludeFilters = {@ComponentScan.Filter(type= FilterType.ANNOTATION, value={Service.class}),

@ComponentScan.Filter(type= FilterType.ASPECTJ, pattern = “*…User1”)})

包含策略的使用:

  • XML 方式:

  • 注解方式:参数与排除策略中一样

@ComponentScan(basePackages = “com.yusaael.scan”,

useDefaultFilters = false,

includeFilters = {@ComponentScan.Filter(type= FilterType.ANNOTATION,value={Service.class})})

Spring 工厂创建对象的多种方式

=====================================================================================

多种配置方式的应用场景:

配置优先级:@Component 及其衍生注解 < @Bean < 配置文件标签

  • 优先级高的配置,会覆盖优先级低配置

  • 配置覆盖:id 值需要保持一致

@Component

public class User{

}

@Bean

public User user(){

return new User();

}

通过配置优先级,可以解决基于注解进行配置的耦合问题:

@Configuration

//@importResource(“applicationContext.xml”)

public class AppConfig4 {

@Bean

public UserDAO userDAO() {

return new UserDAOImpl();

}

}

@Configuration

@importResource(“applicationContext.xml”)

public class AppConfig5{

}

applicationContext.xml

整合多个配置信息

===========================================================================

为什么会有多个配置信息?

  • 拆分多个配置 bean 的开发,是一种模块化开发的形式,也体现了面向对象各司其职的设计思想

多配置信息整合的方式:

  • 多个配置 Bean 的整合

  • 配置 Bean 与 @Component 相关注解的整合

  • 配置 Bean 与 SpringXML 配置文件的整合

整合多种配置需要关注那些要点:

  • 如何使多配置的信息汇总成一个整体

  • 如何实现跨配置的注入

多个配置 Bean 的整合


多配置的信息汇总:

  1. 基于 basePackegs 包扫描的方式整合多个配置 Bean

  1. @import 在一个配置 Bean 中引入另一个配置 Bean

![在这里插入图片描述](https://img-blog.csdnimg.cn/20210423134738997.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3dlaXhpbl8

【一线大厂Java面试题解析+后端开发学习笔记+最新架构讲解视频+实战项目源码讲义】

开源分享完整内容戳这里

0MzczNDA5NQ==,size_16,color_FFFFFF,t_70)

  1. 在工厂创建时,指定多个配置 Bean 的 Class 对象【了解】

ApplicationContext ctx = new AnnotationConfigApplicationContext(AppConfig1.class, AppConfig2.class);

跨配置进行注入:

  • 在应用配置 Bean 的过程中,不管使用哪种方式进行配置信息的汇总,其 *** 作方式都是通过成员变量加入 @Autowired 注解完成。。

@Configuration

@import(AppConfig2.class)

public class AppConfig1 {

@Autowired

private UserDAO userDAO;

@Bean

public UserService userService() {

UserServiceImpl userService = new UserServiceImpl();

userService.setUserDAO(userDAO);

return userService;

}

}

@Configuration

public class AppConfig2 {

@Bean

public UserDAO userDAO() {

return new UserDAOImpl();

}

}

配置 Bean 与 @Component 相关注解的整合


@Component(@Repository)

public class UserDAOImpl implements UserDAO{

}

@Configuration

@ComponentScan("")

public class AppConfig3 {

@Autowired

private UserDAO userDAO;

@Bean

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5562668.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-14
下一篇 2022-12-14

发表评论

登录后才能评论

评论列表(0条)

保存