【Spring】注解
Spring支持使用注解代替xml配置,注解开发可以简化配置.注解相对于XML配置的优点主要体现在编写的简洁性和代码量的减少上。由于注解直接写在源代码中,使得代码看起来更直观和清晰。不过,这也是注解的一个缺点,即一旦需要在源代码中进行维护或修改,就必须改动源代码,并重新编译和部署。相比之下,XML配置有其独特的优势。首先,XML是集中式的元数据,不需要与代码绑定,这使得我们可以独立于源代码进行配置
文章目录
1. 前言
Spring支持使用注解代替xml配置,注解开发可以简化配置.
注解和XML配置文件的对比:
- 注解相对于XML配置的优点主要体现在编写的简洁性和代码量的减少上。由于注解直接写在源代码中,使得代码看起来更直观和清晰。不过,这也是注解的一个缺点,即一旦需要在源代码中进行维护或修改,就必须改动源代码,并重新编译和部署。
- 相比之下,XML配置有其独特的优势。首先,XML是集中式的元数据,不需要与代码绑定,这使得我们可以独立于源代码进行配置修改,而无需重新编译和部署。其次,使用XML可以进行灵活的配置调整,并且当需要对软件进行扩展时,利用XML可以方便地实现。此外,XML还具有较好的可读性和易懂性。
2.注解开发的准备工作
如果要使用注解开发必须要开始组件扫描,这样加了注解的类才能被扫描出来,Spring才能去解析其中的注解
如下:
<context:component-scan base-package="com.example"></context:component-scan>
这样Spring就能够扫描com.example
包下所有的类
3. IOC相关注解
@Component @Controller @Service @Repository 这四个注解都可以加到类上
他们都可以起到类似bean标签的作用。可以把加了该注解类的对象放入Spring容器中.实际再使用时选择任意一个都可以。但是后3个注解是语义化注解。
示例:
在之前管理bean对象都是使用xml配置文件中bean标签来管理的,例如:
<bean class="com.example.entity.Student" id="student"></bean>
如今学习了注解,就可以使用注解来代替xml配置文件了
如下:
@Data
@AllArgsConstructor
@Component("student")
public class Student {
private int age;
private String name;
public Student() {
System.out.println("执行了空参构造方法");
}
}
只需要添加一个注解,并加上标识就可以了. 同样可以获取到bean对象
⭐注意不要忘记加注解扫描以及确认路径是否正确
虽然说上面四个注解用法是相同的,但也不要随便用,就像变量名不能随便取一样:
- 如果是Service类要求使用@Service。
- 如果是Dao类要求使用@Repository
- 如果是Controllerl类(SpringMVC中会学习到)要求使用@Controller
- 如果是其他类可以使用@Component
DI相关注解
4. DI相关注解
DI依赖注入就是要让Spring来给Bean对象的属性进行赋值,可以使用注解来完成
4.1 @Value
主要用于String,int等可以直接赋值的属性注入。
示例1:
@Component("student")
public class Student {
@Value("20")
private int age;
@Value("张三")
private String name;
public Student() {
System.out.println("执行了空参构造方法");
}
}
用法并不难,就不多说了
⭐注意:@Value注解并不需要setter方法,但支持SpEL表达式
示例2:
@Component("student")
public class Student {
@Value("#{20+6}")
private int age;
@Value("张三")
private String name;
public Student() {
System.out.println("执行了空参构造方法");
}
}
4.2 @AutoWired
@Autowired
用于自动装配bean。它可以应用于字段、setter方法和构造函数上。当一个类被Spring容器管理时,可以使用@Autowired
注解来注入其他bean
@Value注入的都是一些简单类型的值,如果Student中有其它类的实例,要如何注入? 这时候就需要用到@AutoWired注解
示例:
@Component("student")
public class Student {
@Value("#{20+6}")
private int age;
@Value("张三")
private String name;
@Autowired
private StudentDao studentDao;
public Student() {
System.out.println("执行了空参构造方法");
}
}
⭐需要注意的是:当一个类被Spring容器管理时,才可以使用@Autowired
注解来注入其他bean
@Repository
public class StudentDao {
@Value("111")
private int num;
}
接下来介绍**@AutoWired中的属性**
默认值为true.
如果required属性值为false,那么即使要被注入的类没有被Spring容器管理,也不会报错
示例:
@Component("student")
public class Student {
@Value("#{20+6}")
private int age;
@Value("张三")
private String name;
@Autowired(required = false)
private StudentDao studentDao;
public Student() {
System.out.println("执行了空参构造方法");
}
}
//@Repository
public class StudentDao {
@Value("111")
private int num;
}
4.3 @Qualifier
如果相同类型的bean在容器中有多个时,单独使用@AutoWired就不能满足要求,这时候可以再加上
@Qualifier来指定bean的名字从容器中获取bean注入。
⭐注意:@Qualifier是不能单独使用的
5. xml配置文件相关注解
上面的注解中,虽然可以使用注解替换掉bean,但是xml配置文件还在,接下来学习的注解就可以把xml配置文件替换掉
5.1 @Configuration
标注在类上,表示当前类是一个配置类。我们可以用注解类来完全替换掉xml配置文件。
⭐注意: 如果使用配置类替换了xml配置,spring容器要使用: AnnotationConfigApplicationContext
5.2 @ComponensScan
@ComponensScan 可以用来代替context:component-scan标签来配置组件扫描,@ComponensScan中的basePackages
属性用于指定需要扫描的基础包路径。
示例:
@Configuration
@ComponentScan(basePackages = "com.example")
public class ApplicationConfig {
}
@Data
@AllArgsConstructor
@NoArgsConstructor
@Component("student")
public class Student {
@Value("#{20+6}")
private int age;
@Value("张三")
private String name;
}
注意这里的Spring容器类型,以及创建实例时,传递的参数是配置类的字节码文件
6.@Bean注解
@Bean可以用来代替bean标签,主要用于第三方类的注入。
例如之前的jdbc的数据源,像这种对象就不能使用注解进行配置,因为这些类的源码是在jar包里的.
这时就可以用@Bean注解
@Configuration
@ComponentScan(basePackages = "com.example")
public class ApplicationConfig {
@Bean("dataSource")
public DataSource getDataSource(){
DataSource dataSource = new MysqlDataSource();
((MysqlDataSource)dataSource).setURL("jdbc:mysql://127.0.0.1:3306/test?characterEncoding=utf8&useSSL=false;");
((MysqlDataSource)dataSource).setUser("root");
((MysqlDataSource)dataSource).setPassword("123456");
return dataSource;
}
}
此时就可以通过getBean方法传入dataSource
来获取数据源对象
7. @PropertySource
可以用来代替context:property-placeholder,让Spring读取指定的properties文件。
然后可以使用@Value来获取读取到的值。
示例:
jdbc.properties文件:
jdbc.url=jdbc:mysql://127.0.0.1:3306/test?characterEncoding=utf8&useSSL=false;
jdbc.user=root
jdbc.password=123123
配置类:
@Configuration
@ComponentScan(basePackages = "com.example")
@PropertySource("jdbc.properties")
public class ApplicationConfig {
@Value("${jdbc.url}")
private String url;
@Value("${jdbc.user}")
private String user;
@Value("${jdbc.password}")
private String password;
@Bean
public DataSource getDataSource(){
DataSource dataSource = new MysqlDataSource();
((MysqlDataSource)dataSource).setURL(url);
((MysqlDataSource)dataSource).setUser(user);
((MysqlDataSource)dataSource).setPassword(password);
return dataSource;
}
}
由上述结果可以看出properties文件中的键值对已经成功被读取到了
⭐注意: 使用@Value来获取读取到的值时,使用的是${}
开放原子开发者工作坊旨在鼓励更多人参与开源活动,与志同道合的开发者们相互交流开发经验、分享开发心得、获取前沿技术趋势。工作坊有多种形式的开发者活动,如meetup、训练营等,主打技术交流,干货满满,真诚地邀请各位开发者共同参与!
更多推荐
所有评论(0)