Spring5从入门到入坟:使用注解开发

jdk1.5开始支持注解,spring2.5开始全面直接注解

准备工作:利用注解的方式注入属性

1、在spring配置文件中引入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
                    http://www.springframework.org/schema/beans/spring-beans-2.5.xsd
       http://www.springframework.org/schema/context
        http://www.springframework.org/schema/context/spring-context.xsd">

2、开启注解支持

    <context:annotation-config/>

@Autowired

·@Autowired是按类型自动装配的,不支持id匹配

·需要导入spring-aop的包

测试:

1、将people类中的set方法去掉,使用@Autowired注解

package pojo;
import org.springframework.beans.factory.annotation.Autowired;
public class People {
    @Autowired
    private  Cat cat;
    @Autowired
    private  Dog dog;
    private  String name;
//使用注解以后 可以省略 set方法
    public Cat getCat() {
        return cat;
    }
    public Dog getDog() {
        return dog;
    }
    public String getName() {
        return name;
    }
    @Override
    public String toString() {
        return "People{" +
                "cat=" + cat +
                ", dog=" + dog +
                ", name='" + name + '\'' +
                '}';
    }
}

2、此时的配置文件内容

     <bean id="dog" class="pojo.Dog"/>
    <bean id="cat" class="pojo.Cat"/>
      <bean  id="people" class="pojo.People" >
     </bean>

3、测试

import org.junit.Test;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import pojo.People;

public class Test01 {
    @Test
    public void  test01(){
        ApplicationContext context=new ClassPathXmlApplicationContext("beans.xml");
        People people=context.getBean("people",People.class);
        people.getDog().shout();
        people.getCat().shout();
    }
}

Spring5从入门到入坟:使用注解开发

 @Qualifier

·@Autowired根据类型自动装配,加上 @Qualifier则可以根据byName的方式自动装配

· @Qualifier不能单独使用。

测试步骤:

1、配置文件修改内容,保证类型存在对象。且名字不为类的默认名字

   <bean id="dog1" class="pojo.Dog"/>
    <bean id="cat1" class="pojo.Cat"/>
    <bean id="dog2" class="pojo.Dog"/>
    <bean id="cat2" class="pojo.Cat"/>

2、不加Qualifier测试,直接报错

Spring5从入门到入坟:使用注解开发

3、在属性上加上Qualifier注解


public class People {
    @Autowired
    @Qualifier(value = "cat2")
    private  Cat cat;
    @Autowired
    @Qualifier(value = "dog2")
    private  Dog dog;
    private  String name;

4、测试

Spring5从入门到入坟:使用注解开发

 @Resource

·@Resource如有指定的name属性,先按该属性进行byName方式查找装配

·其次再进行默认的byName方式进行装配

·如果以上都不成功,则按byType的方式自动装配

·都不成功,则报异常

实体类:

  //如果允许对象为null,设置required=false,默认为true
  @Resource(name = "cat2")
    private  Cat cat;
    @Resource
    private  Dog dog;
    private  String name;

beans.xml

    <bean id="dog1" class="pojo.Dog"/>
    <bean id="cat1" class="pojo.Cat"/>
    <bean id="dog2" class="pojo.Dog"/>
    <bean id="cat2" class="pojo.Cat"/>
      <bean  id="people" class="pojo.People" >

测试成功!

配置文件:beans.xml  删掉cat2

people.java  只保留注解

测试:ok

结论:先进性byName查找,失败;再进行byType查找,成功!

小结

@Autowired和@Resource

1、二者都可以用来装配bean。都可以写在字段上,或写在setter方法上

2、@Autowired默认按类型装配(属于spring规范),默认情况下必须要求依赖对象必须存在,如果允许null值,可以设置它的required属性为false,如:@Autowired(required=false),如果我们想使用名称装配可以结合@Qualifier注解进行使用

3、@Resource(属于J2EE复返),默认按照名称进行装配,名称可以通过name属性进行指定。如果没有指定name属性,当注解写在字段上时,默认取字段名进行按照名称查找,如果注解写在setter方法上默认取属性名进行装配。当找不到与名称匹配的bean时才按照类型进行装配,但需要注意的是,如果name属性一旦指定,就会按照名称进行装配

他们的作用相同:都是用注解方式注入对象,但执行顺序不同。@Autowired 先byTyoe,   @Resource先byname

使用注解开发

在配置文件当中,引入一个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
       http://www.springframework.org/schema/beans/spring-beans.xsd
       http://www.springframework.org/schema/context
       http://www.springframework.org/schema/context/spring-context.xsd">
</beans>

Bean的实现

我之前都是使用Bean的标签进行bean注入,但是实际开发中,我们一般都会使用注解

1、配置扫描包下的注解

 <!--指定注解扫描包-->
    <context:component-scan base-package="pojo"/>

2、在指定类下编写类,增加注解

相当于配置文件中<bean id="user" class="当前注解下的类"


import org.springframework.stereotype.Component;
@Component("user")
public class User {
   
    public  String name="花泽生菜";
}

3、测试


import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import pojo.User;
public class Mytest1 {
    public static void main(String[] args) {
        ApplicationContext context=new ClassPathXmlApplicationContext("applicationContext.xml");
        User user=(User)context.getBean("user");
        System.out.println(user.name);
    }

}

属性注入

使用注解注入属性

1、可以不用提供set方法,直接在直接名上添加@value("值")

import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Component;
@Component("user")
public class User {
@Value("花泽生菜")
    public  String name=;
}

2、如果提供了set方法,在set方法上添加@Value("值");

衍生注解

@Component三个衍生注解

为了更好的进行分层,Spring可以使用其他三个注解,功能一样,目前使用哪一个功能都一样

·@Controller:web层

·@Service:service层

·@Repository:dao层

写上这些注解,就相当于将这个类交给Spring管理装配了

自动装配注解

@scope

·singleton:默认的,Spring会采用单例模式创建这个对象。关闭工厂,所有的对象都会销毁

·prototype:多例模式。关闭工厂所有的对象不会校会。内部的垃圾回收机制会回收

小结

XML与注解比较

·XML可以使用任何场景,结构清晰,维护方便

·注解不是自己提供的类使用不了,开发简单方便

xml与注解整合开发:推荐最佳实践

`xml管理Bean

·注解完成属性注入

·使用过程中,可以不用扫描,扫描是为了类上的注解

作用:

·进行注解驱动注册,从而使注解生效

·用于激活那些在spring容器里注册过得Bean上面的注解,也就是显示的向Spring注册

·如果不扫描包,就需要手动配置bean

·亲如果不加注解驱动,则注入的值为null

上一篇:静态方法中调用@Autowired


下一篇:Spring学习笔记——Spring原始注解