1、spring传统配置与注解
传统的Spring做法是使用.xml文件来对bean进行注入或者是配置aop、事物,这么做有两个缺点:
1、如果所有的内容都配置在.xml文件中,那么.xml文件将会十分庞大;如果按需求分开.xml文件,那么.xml文件又会非常多。总之这将导致配置文件的可读性与可维护性变得很低。
2、在开发中在.java文件和.xml文件之间不断切换,是一件麻烦的事,同时这种思维上的不连贯也会降低开发的效率。为了解决这两个问题,Spring引入了注解,通过"@XXX"的方式,让注解与JavaBean紧密结合,既大大减少了配置文件的体积,又增加了Java Bean的可读性与内聚性。
2、spring常用注解认识
- @Controller:这个注解用在MVC模式下的的
controllerc层(控制层)
,使用@Controller
注解标识一个controller后,表示将该controller交给spring容器来管理,spring容器中会存在一个controller实例。 - @Service:这个注解对应的是mvc模式下的'service层(业务层)',使用
@Service
注解标识一个业务层bean时,表示将该bean交友spring容器管理,当controller层需要调用service时,只需在controller层声明service变量,然后注入即可 - @Repository:这个注解用在mvc模式下的
dao层(持久层)
。实际开发中则用在操作数据库的dao实现类和model上。 - @Component:这个注解是一个通用注解,它可以代表
@Controller
、@Service
、Repository
,当你不知道一个类要用什么来注解时,就用它 - @Scope:这个注解和spring配置文件中的
scope
属性是一个意思,它代表这一个bean的作用域 - @value:这个属性用在给
pojo类
属性赋值时使用,如果注解标识在属性上面则sspring底层是用java反射机制来给属性赋值,如果注解标识在setter方法上,则调用set方法来赋值,与配置文件中的<property>
标签注入时一样的效果。 - @Resource:这个注解用法和
@value
很像,当在一个bean中要注入另外一个bean时就用这个注解,同样是可以在属性上,也可以在setter方法上去标识。它有属性name
,可以用来指定注入的bean,使用byName的自动注入策略,'type'属性可以用来指定注入的类型,使用byType自动注入策略,当该类型有两个或以上实例时就会出错。如果不指定属性的话,默认使用反射机制byName的自动注入策略。 - @Autowired:这个注解是spring提供的注解,同样可以在属性字段和setter方法上使用。它属于自动注入,只支持
byType
装配依赖对象,默认情况下它要求依赖对象必须存在,不可为null,可以通过设置它的属性required
为false
,来使依赖对象允许为空。如果想通过byName
来装配依赖对象,可以与@Qualifier
注解结合使用。 - @Qualifier:这个注解常与
@Autowired
结合使用,在自动装配时可以用来支持byName
装配策略
3、常用注解的使用
在使用注解之前,要在spring配置文件中插入
<context:component-scan base-package="priv.wfq.spring" />
它表示扫描这个路径下的包和类的注解,即表示这个路径下的类可以使用注解
1、@Controller、@Service、@Repository、@Component、@Scope
User
@Component
@Scope("prototype")
public class User {
}
UserController
@Controller
public class UserController {
}
UserService
@Service("userService")
public class UserServiceImpl implements UserService {
}
UserDao
@Repository("userDao")
public class UserDaoImpl implements UserDao {
}
测试结果
2、@value
User
@Component
@Scope("prototype")
public class User {
@Value("小明")
private String name;
private String sex;
public User() {
super();
System.out.println("User类构造器被调用");
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
System.out.println("调用setName方法");
}
public String getSex() {
return sex;
}
@Value("男")
public void setSex(String sex) {
this.sex = sex;
System.out.println("调用setSex方法");
}
@Override
public String toString() {
return "User [name=" + name + ", sex=" + sex + "]";
}
}
测试结果
3、@Resource(这里先介绍简单的使用,后续博客在详细介绍)
Pet
@Component
public class Pet {
@Value("1000")
private int id;
//宠物类型
@Value("小狗")
private String type;
@Override
public String toString() {
return "Pet [id=" + id + ", type=" + type + "]";
}
}
User
@Component
@Scope("prototype")
public class User {
@Value("小明")
private String name;
@Value("男")
private String sex;
@Resource
private Pet pet;
@Override
public String toString() {
return "User [name=" + name + ", sex=" + sex + ", pet=" + pet + "]";
}
}
测试结果
4、@Autowired、@Qualifier
主体代码与3相同,稍做修改即可,结果也一样