Spring-xml配置
这里先简单回顾一下Spring的xml配置,我们是通过过下列步骤来进行xml的配置。(使用的工具为IDEA)
1、在resources文件下创建一个xml文件
2、导入xml的配置约束
3、使用bean标签来配置程序中的类
4、根据成员变量的类型,是依据set方法是构造函数完成成员变量的方 式,选择合适的依赖注入方式。
以下是基于xml配置的一个对数据库完成增删改查的Spring例子,将通过改写这个例子,来介绍注解配置,同时介绍常用的注解。
目录结构:
用户类
public class User {
private Integer id;
private String name;
private Integer age;
...
}
业务层
public class UserServiceImpl implements UserService {
UserDao userDao = null;
public void setUserDao(UserDao userDao) {
this.userDao = userDao;
}
public void save(User user) {
userDao.save(user);
}
public void update(User user) {
userDao.update(user);
}
public void delete(Integer id) {
userDao.delete(id);
}
public User fingById(Integer id) {
return userDao.fingById(id);
}
public List<User> fingALl() {
return userDao.fingALl();
}
}
dao层
public class UserDaoImpl implements UserDao {
DBAssit dbAssit = null;
public void setDbAssit(DBAssit dbAssit) {
this.dbAssit = dbAssit;
}
public void save(User user) {
dbAssit.update("insert Users(name,age) values(?,?)",user.getName(),user.getAge());
}
public void update(User user) {
dbAssit.update("update Users set name=?,money=? where id = ?",user.getName(),user.getAge(),user.getId());
}
public void delete(Integer id) {
dbAssit.update("delete from Users where id = ?",id);
}
public User fingById(Integer id) {
return (User) dbAssit.query("select * from Users where id = ?",new BeanHandler<User>(User.class),id);
}
public List<User> fingALl() {
return (List<User>) dbAssit.query("select * from Users where id = ?",new BeanHandler<User>(User.class));
}
}
配置文件
测试结果
以上就是基于xml配置的一个例子,完成数据库的增删查改功能。接下来通过将这个例子改为基于注解配置,来介绍spring的注解配置。
Spring-注解配置
注解准备
项目中导入aop jar包,如果是maven工程,导入spring依赖时会自动导入改jar包,在xml文件中添加context:component-scan标签
base-package的值是包名,表明扫描该包及子包里的注解
更改xml配置-改造一
我们知道程序中的类资源在bean.xml文件中由bean标签配置交由spring管理,所以第一步用注解更改这一配置
@Component相当于在xml中配置一个bean
将在bean.xml文件中用bean配置的类上写上注解@Component,然后在xml文件中删除bean标签完成第一步改造。
bean.xml文件
由于连接池是在jar包里我们无法在jar包里添加注解,所以目前xml文件中还留有一个bean标签。
这里还有三个和@Component标签一样的功能
@Controller @Service @Repository,为了三层结构有清晰的界限,这是哪个标签分别用在表现层、业务层、持久层。
更改xml配置-改造二
接下来需解决用注解的方法解决成员变量的赋值问题,也就是用注解方式完成后数据注入。
@Autowired用在成员变量上。
作用:自动类型注入。当使用注解注入属性时,可以省略set方法。但这只能注入其他bean类型。当有多个类型配置时,使用要注入的对象变量名称作为bean的id(好比xml中ref的值为变量的名称),在spring容器中查找,找到了也可以注入成功。找不到就报错
测试方法
接下来在介绍几个关于数据注入的几个注解:
@Qualifier
作用:在自动按照类型注入的基础之上,再按照Bean的id注入。它在给字段注入时不能独立使用,必须和@Autowire一起使用。但是给方法参数注入时,可以独立使用
属性:指定的bean的id
@Resource
作用:直接按照bean的id注入。它只能注入其他bean类型
属性:指定bean的id
@Value
作用:用于注入基本类型和String类型
属性:value:用于指定值
经过前两步的改造,xml文件只剩下两个标签,接下来就进行第三步改造,将这两个标签从xml文件中删除,最终删除整个xml文件,完成纯注解的配置
更改xml配置-改造三
经过上面两步改造之后,由于连接池的类在jar包中,无法对它使用@Component标签。接下来介绍一个新标签来解决这个问题。
@Configuration
作用:用于指定当前类是一个spring配置类,当创建容器的时候回从该类上加载注解。获取容器时需要使用AnnotationApplicationContext
属性:value:用关于指定配置类的字节码
我们定义一个配置类,这个配置类将产生一个DataSource
@Configuration
@ComponentScan("spring")
public class SpringConfiguration {
@Bean(name="dataSource")
public DataSource createDataSource() {
try {
ComboPooledDataSource ds = new ComboPooledDataSource();
ds.setUser("root");
ds.setPassword("zyp281552");
ds.setDriverClass("com.mysql.jdbc.Driver");
ds.setJdbcUrl("jdbc:mysql:///eesy");
return ds;
} catch (Exception e) {
throw new RuntimeException(e);
}
}
}
当把xml文件中最后一个bean移除后,只剩一个context:component-scan标签,通过在配置类使用@ComponentScan标签替换xml中剩下的最后一个标签
@ComponenScan
作用:用于指定spring在初始化容器时要扫描的包。作用和spring的xml配置文件中的context:component-scan标签一样。
在配置类中还有一个注解@Bean,该注解只能写在方法上,表明使用此方法创建一个对象,并且放入spring容器。它的属性:name:给当前@Bean注解方法创建的对象指定一个名称(即bean的id)
(以上是初学spring的理解,了解还教浅,如有不对的地方,欢迎交流,一起学习,一起进步)