Spring-02--注解

基于注解整合时 先把src--main--resources--bean.xml中的约束改成下面的,导入约束时需要多导入一个 context名称空间下的约束。 由于我们使用了注解配置,此时不能在继承 JdbcDaoSupport,需要自己配置一个 JdbcTemplate 。


 


     
 
  
    
    
 
  
   
   
   
   
   


以往的XML配置:

 
      scope="" init-method="" destroy-method="">
      

用于创建对象:相当于在XML中编写了一个标签实现的功能一样。
@Component:把当前类对象存入到spring容器中 让spring来管理, 相当于XML中配置一个bean。
为了更加清晰 于是Spring提供了以下3个注解 效果与Component是一样的
@Controller:一般用于表现层的注解
@Service:一般用在业务层的注解
@Repository:一般用于在持久层的注解


注意
如果注解里有一个value属性,那么这个属性是可以不写的,如果有两个属性,那么value就得写,例如: @Component(value="accountService") 等同于 @Component("accountService")
value:用于指定bean的ID,当我们不写时,它的默认值是当前类名且首字母改小写。


用于注入数据的:相当于在XML中的中编写了一个标签是一样的
@Autowired:自动按照类型注入 只要容器中有唯一的一个bean对象类型和要注入的变量类型匹配就可以注入成功
@Qualifier:按照类型的注入基础之上再按名称注入 它在给类成员注入时不能单独使用 ,必须配合和@Autowired使用。但是给方法参数注入时可以
@Resource:直接按照bean的id注入 它可以独立使用 name属性是bean的id 例如:@Resource(name=accountDao)


注意:
Value:用于注入基本类型和String类型的数据
value属性:用于指定数据的值。它可以使用spring中SpEL (也就是spring中的EL表达式)
SpEL的写法:${表达式}


用于改变作用范围的:相当于在标签中使用了scope一样。
Scope:与于指定bean的作用范围
属性:value:指定范围的取值,常用取值:singleton(默认)(单例)和prototype(多例)

和生命周期相关的:相当于在标签中使用了init-menthoddestriy-menthod一样。
PreDestroy:指定销毁方法。
PostConstruct:指定初始化方法。


Spring新注解

@Configurtion:指定当前类是一个spring配置类(配置类的意思就是它的作用和bean.xml是一样的)
@ComponentScan:通过注解指定是Spring在创建容器时要扫描的包。。作用和在 spring 的 xml 配置文件中的:是一样的。
实例代码:

@Configuration 
@ComponentScan("com.itheima") 
        public class SpringConfiguration { 
  
    } 

@Bean:该注解只能写在方法上,用于把当前方法的返回值作为bean对象存入到Spring的ioc容器中,name:给当前@Bean 注解方法创建的对象指定一个名称(即 bean 的 id)。

@PropertySource:用于加载.properties 文件中的配置。例如我们配置数据源时,可以把连接数据库的信息写到 properties 配置文件中,就可以使用此注解指定 properties 配置文件的位置.value[]:用于指定 properties 文件位置。如果是在类路径下,需要写上 classpath:

@PropertySource("classpath:jdbc.properties") 
      public class JdbcConfig{

   }

@Import:用于导入其他配置类,在引入其他配置类时,可以不用再写@Configuration 注解。当然,写上也没问 题,value[]:用于指定其他配置类的字节码。

@Import({ JdbcConfig.class})
     public class SpringConfiguration {

   } 

Spring 整合 Junit

在测试类中,每个测试方法都有以下两行代码:

  ApplicationContext ac = new ClassPathXmlApplicationContext("bean.xml");  IAccountService as = ac.getBean("accountService",IAccountService.class); 

这两行代码的作用是获取容器,如果不写的话,直接会提示空指针异常。所以又不能轻易删掉。

junit 是无法实现的,因为它自己都无法知晓我们是否使用了 spring 框架,更不用说帮我们创建 spring 容器了。不过好在,junit 给我们暴露 了一个注解,可以让我们替换掉它的运行器。 这时,我们需要依靠 spring 框架,因为它提供了一个运行器,可以读取配置文件(或注解)来创建容器。我 们只需要告诉它配置文件在哪就行了.
第一步:导入spring整合的junit的jar包坐标。
第二步:使用junit提供的一个注解把原有的main方法替换,替换成spring提供的@Runwith

@RunWith(SpringJUnit4ClassRunner.class) 
      public class AccountServiceTest { 
        }

第三步:告诉spring的运行器,spring和ioc创建是基于xml还是注解 并说明位置。

@RunWith(SpringJUnit4ClassRunner.class) 
@ContextConfiguration(locations= {"classpath:bean.xml"}) 
    public class AccountServiceTest { 

  } 

@ContextConfiguration注解:
locations 属性:用于指定配置文件的位置。如果是类路径下,需要用 classpath:表明
classes 属性:用于指定注解的类。当不使用 xml 配置时,需要用此属性指定注解类的位置。

第四步:使用@Autowired 给测试类中的变量注入数据

@RunWith(SpringJUnit4ClassRunner.class) 
@ContextConfiguration(locations= {"classpath:bean.xml"}) 
    public class AccountServiceTest {
      @Autowired 
       private IAccountService as ;
 }

你可能感兴趣的:(Spring-02--注解)