使用注解开发
在Spring4之后,要使用注解开发,必须保证aop的包导入了
使用注解需要导入context约束,增加注解的支持!
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="http://www.springframework.org/schema/beans
https://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context
https://www.springframework.org/schema/context/spring-context.xsd">
<!-- 指定要扫描的包,这个包下的注解就会生效 -->
<context:compoent-scan base-package="com.kuang.pojo/">
<!-- 开启注解的支持 -->
<context:annotation-config/>
</beans>
user类:
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Scope;
import org.springframework.stereotype.Component;
// 等价于 <bean id="user" class="com.kuang.pojo.User"/>
// @Component 组件
@Component
@Scope("prototype")
public class User {
public String name;
// 相当于 <property name="name" value="张三"/>
@Value("张三")
public void setName(String name) {
this.name = name;
}
}
// 也可将value("张三")放到public String name;上面
测试类:
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
public class MyTest {
public static void main(String[] args) {
//初始化Spring容器,加载applicationContext.xml文件
ApplicationContext context = new ClassPathXmlApplicationContext("applicationContext.xml");
//获取实例
User user = (User) context.getBean("user");
System.out.println(user.name);
}
}
常用依赖:
<!-- https://mvnrepository.com/artifact/org.springframework/spring-webmvc -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>5.2.6.RELEASE</version>
</dependency>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.12</version>
</dependency>
注解说明
-
@Autowired : 自动装配通过类型。名字
如果Autowired不能唯一自动装配上属性,则需要通过@Qualifier(value=“xxx”) -
@Nullable : 字段标记了这个注解,说明这个字段可以为null;
-
@Resource : 自动装配通过名字。类型
-
@Component : 组件,放在类上,说明这个类被Spring管理了,就是bean!
- bean
- 属性如何注入
@Component
public class User {
public String name;
// 相当于 <property name="name" value="张三"/>
@Value("张三")
public void setName(String name) {
this.name = name;
}
}
- 衍生的注解
@Component有几个衍生注解,我们在web开发中,会按照mvc三层架构分层!
- dao 【@Repository】
- service 【@Service】
- controller 【@Controller】
这四个注解功能是一样的,都是代表将某个类注册到Spring中,装配Bean
- 自动装配 配置
- @Autowired : 自动装配通过类型。名字
如果Autowired不能唯一自动装配上属性,则需要通过@Qualifier(value="xxx")
- @Nullable : 字段标记了这个注解,说明这个字段可以为null;
- @Resource : 自动装配通过名字。类型
- 作用域
@Component
@Scope("prototype")
public class User {
public String name;
// 相当于 <property name="name" value="张三"/>
@Value("张三")
public void setName(String name) {
this.name = name;
}
}
- 小结
xml与注解:
- xml更加万能,适用于任何场合!维护简单方便
- 注解不是自己的类使用不了,维护相对复杂!
xml与注解最佳实践:
- xml用来管理bean;
- 注解只负责完成属性的注入;
- 我们在使用的过程中,只需要注意一个问题:必须让注解生效,就需要开启注解的支持
<!-- 指定要扫描的包,这个包下的注解就会生效 -->
<context:component-scan base-package="com.kuang"/>
<!-- 开启注解的支持-->
<context:annotation-config/>
使用Java的方式配置Spring
我们现在要完全不使用Spring的xml配置了,全权交给Java来做!
JavaConfig是Spring的一个子项目,在Spring 4之后,它成为了一个核心功能!
实体类:
// 这个注解的意思,就是说明这个类被Spring接管了,注册到了容器中
@Component
public class User {
private String name;
public String getName() {
return name;
}
@Value("张三") // 属性注入值
public void setName(String name) {
this.name = name;
}
@Override
public String toString() {
return "User{" +
"name='" + name + '\'' +
'}';
}
}
配置文件:
import com.kuang.pojo.User;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Import;
// 这个也会被Spring容器托管,注册到容器中,因为它本来就是一个@Component,
// @Configuration代表这是一个配置类,就和我们之前看的beans.xml
@Configuration
@ComponentScan("com.kuang.pojo")
@Import(KuangConfig2.class)
public class KuangConfig {
// 注册是一个bean,就相当于我们之前写的一个bean标签
// 这个方法的名字,就相当于bean标签中的id属性
// 这个方法的返回值,就相当于bean标签中的class属性
@Bean
public User user() {
return new User(); // 就是返回要注入到bean的对象中
}
}
测试类:
public class MyTest {
public static void main(String[] args) {
// 如果完全使用了配置类方式去做,我们就只能通过AnnotationConfig上下文来获取容器,通过配置类的class对象加载!
ApplicationContext context = new AnnotationConfigApplicationContext(KuangConfig.class);
User getUser = (User) context.getBean("user");
System.out.println(getUser.getName());
}
}
这种纯Java的配置方式,在SpringBoot中随处可见!