1.
1.1 XML和注解的区别
xml优点:
缺点:
注解优点:
缺点:
Autowired 注解的意思


- "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
- http://www.springframework.org/schema/beans/spring-beans.xsd
- http://www.springframework.org/schema/context
- http://www.springframework.org/schema/context/spring-context.xsd">
-
-
- <context:annotation-config />
- <context:component-scan base-package="需要扫描的包名"/>
- beans>
业务类内容不变,只是要多加几个注解
- //类名上添加Component注解
- @Component
- public class UserService {
- private IUserDao userDao;
- //需要注入的变量上添加@Autowired
- @Autowired
- public void setUserDao(IUserDao userDao) {
- this.userDao = userDao;
- }
- }//获取bean时需要类名小驼峰
- application.getBean("addressServiceImpl")
-
该注解可以加在set方法上或者直接加载属性上,如果写在setter方法上,就会通过setter方法进行注入,如果写在变量上,就直接通过反射设置变量的值,不经过setter方法。
注入时,会从spring容器中,找到一个和这个属性数据类型匹配的实例化对象注入进来,默认使用byType,根据类型匹配。
如果只能找到一个这个数据类型的对象的时候,就直接注入该对象。
如果找到了多个同一个类型的对象的时候,就会自动更改为byName来进行匹配,根据set方法对应的参数列表的局部变量名来匹配。
如
- private IUserDao userDao;
- @Autowired
- public void setUserDao(IUserDao userDao){};
- 会先找符合IUserDao类型的对象有多少,一个的话就直接拿过来
- 多个的话,就按照setUserDao方法的参数列表的局部变量名来找
- 找不到就报错
- @Autowired(required=false) 就说明 这个值可以为null,如果Spring容器中没有对应的对象,不会报错
- 默认为true,比如beans.xml中没有创建dao对象,就会报错,加上required=false就不会报错
以指定名字进行匹配
- private IUserDao userDao;
-
- @Autowired
-
- public void setUserDao(@Qualifier(“userDao2”)IUserDao userDao){};
@Resource默认使用byName的方式,按照名字匹配,可以写在setter方法上也可以写在变量上
匹配不上再匹配方法参数列表的名字
如果还是匹配不上就会转换为byType,根据类型匹配
当然我们也可以指定名字
@Resource(name=”userDao”)
就相当于 Autowired和Qualifier 一起使用
@Controller :WEB 层 ,就是和页面交互的类
@Service :业务层 ,主要处理逻辑
@Repository :持久层 ,就是Dao操作数据库
这三个注解是为了让标注类本身的用途清晰,Spring 在后续版本会对其增强
@Component: 最普通的组件,可以被注入到spring容器进行管理
@Value :用于注入普通类型. 可以写在变量上和setter方法上
@Autowired :自动装配,上面描述比较详细,可以参照上面
@Qualifier:强制使用名称注入.
@Resource 相当于: @Autowired 和@Qualifier 一起使用
@Scope: 设置对象在spring容器中的生命周期取值 :
singleton:单例
prototype:多例
@PostConstruct :相当于 init-method
@PreDestroy :相当于 destroy-method
作用: 用于指定当前类是一个 spring 配置类,当创建容器时会从该类上加载注解。获取容器时需要使用AnnotationApplicationContext(有@Configuration 注解的类.class)。
属性: value:用于指定配置类的字节码
- package com.tledu.zrz.config;
- import org.springframework.context.annotation.Configuration;
- @Configuration
- public class SpringConfiguration {
- }
作用: 用于指定 spring 在初始化容器时要扫描的包。
作用和在 spring 的 xml 配置文件中的:
@ComponentScan("com.wxx.SpringDay02Test")
作用: 该注解只能写在方法上,表明使用此方法创建一个对象,并且放入 spring 容器。
属性: name:给当前@Bean 注解方法创建的对象指定一个名称(即 bean 的 id)。
作用: 用于加载.properties 文件中的配置。例如我们配置数据源时,可以把连接数据库的信息写到properties 配置文件中,就可以使用此注解指定 properties 配置文件的位置。
属性: value[]:用于指定 properties 文件位置。如果是在类路径下,需要写上 classpath
@PropertySource("jdbc.properties")
- @AllArgsConstructor
- @Data
- @NoArgsConstructor
- @PropertySource("jdbc.properties")
- @Component(value = "JdbcConfig")
- public class JdbcConfig {
- @Value("${jdbc.driver}")
- private String driver;
- @Value("${jdbc.url}")
- private String url;
- @Value("${jdbc.username}")
- private String username;
- @Value("${jdbc.password}")
- private String password;
-
- }
ApplicationContext applicationContext =newAnnotationConfigApplicationContext(SpringConfiguration.class);