Spring通过注解来配置bean

本文深入探讨Spring框架中如何使用注解配置Bean,包括@Component、@Responsitory、@Service和@Controller等注解的使用,以及<context:component-scan>元素的详细配置,如base-package、resource-pattern和filter的使用,同时介绍了@Autowired、@Resource和@Inject注解在属性自动装配中的应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Spring通过注解配置bean
  基于注解配置bean
  基于注解来配置bean的属性

在classpath中扫描组件
  组件扫描(component scanning):Spring能够从classpath下自动扫描,侦测和实例化具有特定注解的组件。
  特定的组件包括:
    -@Component:基本注解,标识了一个受Spring管理的组件
    -@Responsitory:标识持久层组件
    -@Service:标识服务层(业务层)组件
    -@Controller:标识表现层组件
  对于扫描到的组件,Spring有默认的命名策略:使用非限定类名,第一个字母小写。也可以在注解中通过value属性值标识组件的名称。
  当在组件类上使用了特定的注解之后,还需要在Spring的配置文件中声明<context:component-scan>:
    base-package属性指定一个需要扫描的基类包,Spring容器将会扫描这个基类包里及其子包中的所有类
    当需要扫描多个包时,可以使用逗号分隔
    如果仅希望扫描特定的类而非基包下的所有类,可使用resource-pattern属性过滤特定的类,示例:
    <context:component-sacn base-package="com.yl.spring.beans" resource-pattern="autowire/*.class"/>
    <context:include-filter>子节点表示要包含的目标类
    <context:exclude-filter>子节点表示要排除在外的目标类
    <context:component-sacn>下可以拥有若干个<context:include-filter>和<context:exclude-filter>子节点


<context:include-filter>和<context:exclude-filter>子节点支持多种类型的过滤表达式:

类别示例说明
annotation com.yl.XxxAnnotation所有标注了XxxAnnotation的类,该类型采用目标类是否标注了某个注解进行过滤
assinable com.yl.XxxService所有继承或扩展XxxService的类,该类型采用了目标类是否继承或扩展某个特定类进行过滤
aspectj com.yl.*Service所有类名义Service结束的类及继承或扩展它们的类,该类型采用AspectJ表达式进行过滤
regex com.yl.anno.*所有com.yl.anno包下的类。该类型采用正则表达式,根据类的类名进行过滤
custom com.yl.XxxTypeFilter 采用XxxTypeFilter通过代码的方式定义过滤原则。该类必须实现org.springframework.core.type.TypeFilter接口


组件装配
<context:component-scan>元素还会自动注册AutowiredAnnotationBeanPostProcessor实例,该实例可以自动装配具有@Autowired和@Resource、和@Inject注解的属性

使用@Autowired自动装配bean
  @Autowired注解自动装配具有兼容类型的单个bean属性
  -构造器,普通字段(即使是非public),一切只有参数的方法都可以应用@Autowired
  -默认情况下,所有使用@Autowired注解的属性都需要被设置,当Spring找不到匹配的bean装配属性时,会抛出异常。若某一属性允许不被设置,可以设置@Autowired注解的required属性为false
  -默认情况下,当IOC容器里存在多个类型兼容的bean时,通过类型的自动装配将无法工作。此时可以在@Qualifiter注解里提供bean的名称,Spring允许对方法的入参标注 @Qualifiter已指定注入bean的名称
  -@Autowired注解也可以应用在数组类型的属性上,此时Spring将会把所有匹配的bean进行自动匹配
  -@Autowired注解也可以应用在集合属性上,此时Spring读取该集合的类型信息,然后自动装配所有与之兼容的bean
  -@Autowired注解用在java.util.Map上时,若该Map的键值作为String,那么Spring将自动装配与之Map值类型兼容的bean,此时bean的名称作为键值

TestObject.java:

package com.yl.annotation;

import org.springframework.stereotype.Component;

@Component
public class TestObject {
    
}

UserRepository.java接口:

public interface UserRepository {
     public void save();
     
 }

UserRepositoryImpl.java:

package com.yl.annotation.repository;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Repository;

import com.yl.annotation.TestObject;

@Repository
//@Repository("userRepository")
public class UserRepositoryImpl implements UserRepository {
    
    @Autowired(required=false)
    private TestObject testObject;
    
    @Override
    public void save() {
        System.out.println("UserRepository save...");
        System.out.println(testObject);
    }

}

UserJdbcRepository.java:

package com.yl.annotation.repository;

import org.springframework.stereotype.Repository;

@Repository
public class UserJdbcRepository implements UserRepository {

    @Override
    public void save() {
        System.out.println("UserJdbcRepository save...");
    }

}

UserService.java:

package com.yl.annotation.service;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.stereotype.Service;

import com.yl.annotation.repository.UserRepository;

@Service
public class UserService {
    @Autowired
    @Qualifier("userJdbcRepository")
    private UserRepository userRepository;
    
    /*@Autowired
    @Qualifier("userJdbcRepository")
    public void setUserRepository(UserRepository userRepository) {
        this.userRepository = userRepository;
    }*/
    
    public void add() {
        System.out.println("UserService add...");
        userRepository.save();
    }
}

UserController.java:

package com.yl.annotation.controller;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;

import com.yl.annotation.service.UserService;

@Controller
public class UserController {
    @Autowired
    private UserService userService;
    
    public void execute() {
        System.out.println("UserController execute...");
        userService.add();
    }
}

beans-annotation.xml:

<?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-4.1.xsd">

    <!-- 指定Spring IOC容器扫描的包 -->
    <!-- 可以通过resource-pattern指定扫描的资源 -->
    <!-- <context:component-scan 
        base-package="com.yl.annotation"
        resource-pattern="repository/*.class"></context:component-scan> -->
    
    <!-- context:exclude-filter 子节点指定排除哪些指定表达式的组件 -->    
    <!-- context:include-filter 子节点指定包含哪些指定表达式的组件, 该子节点需要use-default-filters配合使用 -->    
    <context:component-scan 
        base-package="com.yl.annotation" >
        <!-- use-default-filters="false"> -->
        <!-- <context:exclude-filter type="annotation" 
            expression="org.springframework.stereotype.Repository"/> -->
        
        <!-- <context:include-filter type="annotation" 
            expression="org.springframework.stereotype.Repository"/> -->
            
        <!-- <context:exclude-filter type="assignable" 
            expression="com.yl.annotation.repository.UserRepository"/> -->
        
        <!-- <context:include-filter type="annotation" 
            expression="com.yl.annotation.repository.UserRepository"/> -->
    </context:component-scan>
</beans>

使用@Resource或@Inject自动装配bean
  Spring还支持@Resource和@Inject注解,这两个注解和@Autowired注解的功用类似
  @Resource注解要求提供一个bean名称的属性,若该属性为空,则自动采用标注处的变量或方法名作为bean的名称
  @Inject和@Autowired注解一样也是按类型注入的bean,但是没有required属性
  建议使用@Autowired注解

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

金州饿霸

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值