Spring常用注解(注解对应的XML标签)
项目结构
配置文件
-
pom.xml
<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>com.xiaoge</groupId> <artifactId>annotation_ioc</artifactId> <version>1.0-SNAPSHOT</version> <packaging>jar</packaging> <dependencies> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-context</artifactId> <version>5.0.2.RELEASE</version> </dependency> </dependencies> </project>
-
bean.xml注意这里的约束–这里使用注解来开发
<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"> <!-- 告知spring在创建容器时要扫描的包, 配置所需要的标签不是在bean的约束中, 而是一个名称为context名称空间和约束中 --> <!-- base-package: 指定了包, 它就会扫描这个包下及其子包, 所有类上和接口上的注解 --> <context:component-scan base-package="com.xiaoge"></context:component-scan> </beans>
持久层
-
AccountDao接口
package com.xiaoge.dao; /** * @Author: 潇哥 * @DateTime: 2020/3/19 下午7:31 * @Description: TODO */ public interface AccountDao { public void saveAccount(); }
-
AccountDaoImpl实现类
package com.xiaoge.dao.impl; import com.xiaoge.dao.AccountDao; import org.springframework.stereotype.Repository; /** * @Author: 潇哥 * @DateTime: 2020/3/19 下午7:31 * @Description: TODO */ @Repository("accountDao1") public class AccountDaoImpl implements AccountDao { public void saveAccount() { System.out.println("保存成功11111!"); } }
-
AccountDaoImpl2实现类
package com.xiaoge.dao.impl; import com.xiaoge.dao.AccountDao; import org.springframework.stereotype.Repository; /** * @Author: 潇哥 * @DateTime: 2020/3/19 下午7:31 * @Description: TODO * * 这样 AccountDaoImpl 和 AccountDaoImpl2都瞒足 */ @Repository("accountDao2") public class AccountDaoImpl2 implements AccountDao { public void saveAccount() { System.out.println("保存成功22222!"); } }
业务层
-
AccountService接口
package com.xiaoge.service; /** * @Author: 潇哥 * @DateTime: 2020/3/19 下午7:26 * @Description: 账户业务层接口 */ public interface AccountService { /** * 模拟保存 */ public void saveAccount(); }
-
AccountServiceImpl实现类(重点注释中的注解对应的xml标签)
package com.xiaoge.service.impl; import com.xiaoge.dao.AccountDao; import com.xiaoge.service.AccountService; import org.springframework.context.annotation.Scope; import org.springframework.stereotype.Service; import javax.annotation.PostConstruct; import javax.annotation.PreDestroy; import javax.annotation.Resource; /** * @Author: 潇哥 * @DateTime: 2020/3/19 下午7:28 * @Description: 账户业务层实现类 * * XML的配置 * <bean id="accountService" class="com.xiaoge.service.impl.AccountServiceImpl" * scope="" init-method="" destroy-method=""> * <property name="" value="" ref=""></property> * </bean> * * 用于创建对象的 * 他们的作用就和在XML配置文件中编写一个<bean>标签实现的功能是一样的 * @Component * 作用: 用于把当前类对象存入spring容器中 * 属性: * value: 用于指定bean的id. 当我们不写时, 它的默认值是当前类名, 且首字母改小写. * @Controller: 一般用在表现层 * @Service: 一般用在业务层 * @Respository: 一般用在持久层 * 以上三个注解他们的作用和属性与Component是一模一样. * 他们三个是spring框架为我们提供明确的三层使用的注解, 使我们三层对象更加清晰 * * * * * * 用于注入数据的 * 他们的作用就和在XML配置文件中的bean标签中写一个<property>标签的作用是一样的 * @Autowired: * 作用: 自动按照类型注入. 只要容器中有唯一的一个bean对象类型和要注入的变量类型匹配. 就可以注入成功. * 如果IOC容器中没有任何bean的类型和要注入的变量类型匹配, 则报错. * 如果IOC容器中有多个类型匹配时: * 出现位置: * 可以在变量上, 也可以是方法上. * 细节: * 在使用注解注入时, set方法就不是必须的了. * * @Qualifier:(不能独立使用, 依赖@Autowired) * 作用: 在按照类中注入的基础之上在按照名称注入. 它在给类成员注入时不能单独使用. 但是在给方法参数注入时可以 * 属性: * value: 用于指定注入bean的id. * * @Resource * 作用: 直接按照bean的id注入. 它可以独立使用 * 属性: * name: 用于指定bean的id. * * 以上三个注入都只能注入其他bean类型的数据, 而基本类型和String类型无法使用上述注解实现. * 另外, 集合类型的注入只能通过XML实现. * * @Value * 作用: 用于注入基本类型和String类型的数据 * 属性: * value: 用于指定数据的值. 它可以使用spring中SpEL(也就是spring的el表达式) * SpEL的写法: ${表达式} * * * 用于改变作用范围的 * 他们的作用就和在bean标签中使用scope属性实现的功能是一样的 * @Scope: 跟XML里一样 5 个取值 默认是singleton(单例) * 作用: 用于指定bean的作用范围 * 属性: * value: 指定范围的取值. 常用取值: singleton prototype * * * 和生命周期相关 * 他们的作用就和在bean标签中使用init-method和destroy-method的作用是一样的 * @PreDestroy * 作用: 用于指定销毁方法 * @PostConstruct * 作用: 用于指定初始化方法 */ @Service("accountService") @Scope("singleton") public class AccountServiceImpl implements AccountService { // @Autowired // 它会自动取核心容器(map集合 找值, 键都不会匹配的)中找AccountDao类型匹配的唯一个bean, 那就是我们用注解修饰了的@Repository AccountDaoImpl类 // @Qualifier("accountDao1") @Resource(name = "accountDao2") private AccountDao accountDao; @PostConstruct public void init(){ System.out.println("初始化成功!"); } @PreDestroy public void destroy(){ System.out.println("销毁成功!"); } public void saveAccount() { accountDao.saveAccount(); } }
入口
-
Client
package com.xiaoge.ui; import com.xiaoge.service.AccountService; import com.xiaoge.service.impl.AccountServiceImpl; import org.springframework.context.support.ClassPathXmlApplicationContext; /** * @Author: 潇哥 * @DateTime: 2020/3/19 下午7:35 * @Description: 模拟表现层, 调用业务层 */ public class Client { /** * @param args */ public static void main(String[] args) { // 1. 获取核心容器对象 ClassPathXmlApplicationContext ac = new ClassPathXmlApplicationContext("bean.xml"); // 2. 获取service对象 AccountService as = ac.getBean("accountService", AccountServiceImpl.class); // System.out.println(as); as.saveAccount(); // 释放容器 ac.close(); // AccountDao ad = ac.getBean("accountDao", AccountDaoImpl.class); // System.out.println(ad); // 运行结果 初始化成功! 保存成功22222! 销毁成功! } }